ElasticSearch第2天 Elasticsearch 和 elasticsearch-head的安裝配置

今日目標(biāo)

Elasticsearch 和 elasticsearch-head的安裝配置和在PHP-Laravel項(xiàng)目中集成

1.ES版本的選擇

在使用ES前,我們首先要選擇一個(gè)合適的版本,選擇最新的版本永遠(yuǎn)是一個(gè)不會(huì)錯(cuò)的選擇,目前ES官網(wǎng)最新版本是8.0.0-alpha2,發(fā)布于September 17, 2021(2021/9/17),屬于內(nèi)部測(cè)試版,距今只有一個(gè)月時(shí)間,由于網(wǎng)絡(luò)上關(guān)于其使用說(shuō)明較少且可能沒(méi)有相對(duì)應(yīng)的php擴(kuò)展包,不太利于學(xué)習(xí),故我們可以選擇7.x版本進(jìn)行學(xué)習(xí)。7.15.1是最新的Release版本,發(fā)布于2021/10/15,距今只有幾天時(shí)間,所有選擇7.15.1進(jìn)行學(xué)習(xí)是最佳的。

2.ES的下載安裝

我本地調(diào)試學(xué)習(xí)一般使用的是Windows系統(tǒng),生產(chǎn)環(huán)境使用的是Linux,所以這里兩種操作系統(tǒng)下ES的下載安裝都會(huì)用到。
官網(wǎng)下載鏈接:https://www.elastic.co/cn/downloads/elasticsearch#ga-release (屬于中國(guó)節(jié)點(diǎn),下載速度很快,3分鐘左右就可以下載完成)
Windows下:
選擇windows版本進(jìn)行下載,解壓elasticsearch-7.15.1-windows-x86_64.zip,雙擊運(yùn)行bin目錄下的elasticsearch.bat(殺毒軟件可能會(huì)進(jìn)行攔截,允許即可)
Linux下
mkdir /usr/local/software/es
cd /usr/local/software/es
curl -L -O https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.15.1-linux-x86_64.tar.gz
tar -xvf elasticsearch-7.15.1-darwin-x86_64.tar.gz
./elasticsearch-7.15.1-darwin-x86_64/bin/elasticsearch
檢測(cè)安裝:
命令行提示信息中如果出現(xiàn) publish_address {127.0.0.1:9200}, bound_addresses {127.0.0.1:9200}, {[::1]:9200}則表示安裝成功,或直接訪問(wèn) http://localhost:9200 查看es具體信息

{
  "name" : "PS2019WRLCRMZY",
  "cluster_name" : "elasticsearch",
  "cluster_uuid" : "LcZNPNroRDOdQ8f6hkw12Q",
  "version" : {
    "number" : "7.15.1",
    "build_flavor" : "default",
    "build_type" : "zip",
    "build_hash" : "83c34f456ae29d60e94d886e455e6a3409bba9ed",
    "build_date" : "2021-10-07T21:56:19.031608185Z",
    "build_snapshot" : false,
    "lucene_version" : "8.9.0",
    "minimum_wire_compatibility_version" : "6.8.0",
    "minimum_index_compatibility_version" : "6.0.0-beta1"
  },
  "tagline" : "You Know, for Search"
}

3.ES配置文件

解決CORS
找到config文件夾下的elasticsearch.yml,在文件的末尾添加如下內(nèi)容:
http.cors.enabled: true
http.cors.allow-origin: "*"

4.安裝ES可視化插件elasticsearch-head

  • elasticsearch-head是用于監(jiān)控 Elasticsearch 狀態(tài)的客戶端插件,包括數(shù)據(jù)可視化、執(zhí)行增刪改查操作等

  • 安裝node.js
    下載地址:https://nodejs.org/en/download/ 根據(jù)自己系統(tǒng)下載相應(yīng)的msi,雙擊安裝。

  • 安裝head插件
    https://github.com/mobz/elasticsearch-head 下載zip文件
    解壓至es目錄

  • 修改配置 解決跨域

  • elasticsearch-head-master\Gruntfile.js 97行左右新增 hostname: '*',

        connect: {
            server: {
                options: {
                    hostname: '*',
                    port: 9100,
                    base: '.',
                    keepalive: true
                }
            }
        }
        _node_handler: function(data) {
            if(data) {
                this.prefs.set("app-base_uri", this.cluster.base_uri) || "http://localhost:9200";
                if(data.version && data.version.number)
                    this.cluster.setVersion(data.version.number);
            }
        },
  • elasticsearch-head-master\package.json "license": "Apache2" => "license": "Apache-2.0",

  • 運(yùn)行

  • es/es-head目錄下運(yùn)行

    • npm install
    • npm run start(以后每次),如果還不成功,再執(zhí)行一次npm install
  • 瀏覽器中運(yùn)行http://localhost:9100/

    image.png

5.ES集群健康值

正常情況下,Elasticsearch 集群健康狀態(tài)分為三種:
green 最健康得狀態(tài),說(shuō)明所有的分片包括備份都可用; 這種情況Elasticsearch集群所有的主分片和副本分片都已分配, Elasticsearch集群是 100% 可用的。

yellow 基本的分片可用,但是備份不可用(或者是沒(méi)有備份); 這種情況Elasticsearch集群所有的主分片已經(jīng)分片了,但至少還有一個(gè)副本是缺失的。不會(huì)有數(shù)據(jù)丟失,所以搜索結(jié)果依然是完整的。不過(guò),你的高可用性在某種程度上被弱化。如果 更多的 分片消失,你就會(huì)丟數(shù)據(jù)了。把 yellow 想象成一個(gè)需要及時(shí)調(diào)查的警告。

red 部分的分片可用,表明分片有一部分損壞。此時(shí)執(zhí)行查詢部分?jǐn)?shù)據(jù)仍然可以查到,遇到這種情況,還是趕快解決比較好; 這種情況Elasticsearch集群至少一個(gè)主分片(以及它的全部副本)都在缺失中。這意味著你在缺少數(shù)據(jù):搜索只能返回部分?jǐn)?shù)據(jù),而分配到這個(gè)分片上的寫(xiě)入請(qǐng)求會(huì)返回一個(gè)異常。

遇到的問(wèn)題和解決

在擴(kuò)展包的選擇上,今天遇到了一些問(wèn)題,比如選了排名第一的 elasticsearch-php,但是composer安裝后發(fā)現(xiàn)其并沒(méi)有提供相對(duì)應(yīng)的config文件進(jìn)行配置,不是很友好,所以在對(duì)類庫(kù)封裝api的使用上,我們可以也封裝幾個(gè)相對(duì)應(yīng)的方法或者將類的實(shí)例化進(jìn)行封裝,以便于日后可能需要更換其他類庫(kù)時(shí)而產(chǎn)生的代碼大面積修改。
Ps:最后是通過(guò)laravel的容器注入實(shí)現(xiàn)了配置文件的手動(dòng)配置和es的單例實(shí)例化

明日目標(biāo)

Elasticsearch-PHP基本API使用

總結(jié)

到這里我們的Elasticsearch的安裝配置和簡(jiǎn)單使用就完成,我們可以將index設(shè)為數(shù)據(jù)庫(kù),type設(shè)為表名,來(lái)對(duì)數(shù)據(jù)表進(jìn)行索引管理。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容