婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > docker安裝ElasticSearch:7.8.0集群的詳細教程

docker安裝ElasticSearch:7.8.0集群的詳細教程

熱門標簽:南昌外呼系統定制 海外工廠地圖標注 株洲電銷 宿州外呼系統公司 南充電銷外呼系統 陜西辦理400電話 地圖標注小程序 信陽電銷外呼系統怎么樣 貴陽網絡外呼系統軟件

ElasticSearch集群支持動態請求的方式搭建集群和靜態配置文件搭建集群

關于集群的動態連接方式官方的文檔:https://www.elastic.co/guide/en/elasticsearch/reference/current/cluster-update-settings.html

前置準備工作

關于參數的官網說明:
https://www.elastic.co/guide/en/elasticsearch/reference/current/modules-discovery-settings.html

下載elsticsearch 7.8.0

docker pull elasticsearch:7.8.0

創建一個網絡es_net 用來放elasticsearch集群

docker network create --subnet=172.18.0.0/24 es_net

根據官網的dockerFile文件中的信息 WORKDIR /usr/share/elasticsearch可以得知 elasticsearch 的安裝位置在/usr/share/elasticsearch目錄下,為了方便后面的操作,創建數據卷將elasticsearch產生的數據映射到主機中,防止es宕機數據無法恢復。

創建數據卷

docker volume create es_data01
docker volume create es_data02
docker volume create es_data03
#公共配置文件,以及插件存放位置
docker volume create es_conf
docker volume create es_plugins

分別存放數據、配置、插件
創建3個yml配置文件

動態的方式搭建ElasticSearch集群(推薦)

意味著只要啟動ElasticSearch然后通過ES自帶的RestFul風格的操作既可以完成集群的搭建
dockerhub中官方的啟動方式是單節點的啟動
先單獨啟動3個ElasticSearch節點

啟動es01

docker run -it -d --restart always -p 9201:9200 -p 9301:9300 \

--name es01 --network=es_net --ip=172.18.0.101 \

-v es_data01:/usr/share/elasticsearch/data \

-v es_conf:/usr/share/elasticsearch/conf \

-v es_plugins:/usr/share/elasticsearch/plugins \

-e "discovery.type=single-node" \

-e ES_JAVA_OPTS="-Xms64m -Xmx128m" elasticsearch:7.8.0

啟動es02

docker run -it -d --restart always -p 9202:9200 -p 9302:9300 \

--name es02 --network=es_net --ip=172.18.0.102 \

-v es_data02:/usr/share/elasticsearch/data \

-v es_conf:/usr/share/elasticsearch/conf \

-v es_plugins:/usr/share/elasticsearch/plugins \

-e "discovery.type=single-node" \

-e ES_JAVA_OPTS="-Xms64m -Xmx128m" elasticsearch:7.8.0

啟動es03

docker run -it -d --restart always -p 9203:9200 -p 9303:9300 \

--name es03 --network=es_net --ip=172.18.0.103 \

-v es_data03:/usr/share/elasticsearch/data \

-v es_conf:/usr/share/elasticsearch/conf \

-v es_plugins:/usr/share/elasticsearch/plugins \

-e "discovery.type=single-node" \

-e ES_JAVA_OPTS="-Xms64m -Xmx128m" elasticsearch:7.8.0

通過PUT方式
通過linux的curl命令操作即可
在es02和es03上通過

curl -X PUT "localhost:9200/_cluster/settings?pretty" -H 'Content-Type: application/json' -d'
{
 "persistent" : {
 "cluster" : {
 "remote" : {
 "leader" : {
  "seeds" : [
  "127.0.0.1:9300" 
  ]
 }
 }
 }
 }
}
'

更新persistent

curl -X PUT "localhost:9200/_cluster/settings?pretty" -H 'Content-Type: application/json' -d'
{
 "persistent" : {
 "indices.recovery.max_bytes_per_sec" : "50mb"
 }
}
'

更新transient

curl -X PUT "localhost:9200/_cluster/settings?flat_settings=true&pretty" -H 'Content-Type: application/json' -d'
{
 "transient" : {
 "indices.recovery.max_bytes_per_sec" : "20mb"
 }
}
'

刪除transient配置內容

curl -X PUT "localhost:9200/_cluster/settings?pretty" -H 'Content-Type: application/json' -d'
{
 "transient" : {
 "indices.recovery.max_bytes_per_sec" : null
 }
}
'

刪除所有transient設置

curl -X PUT "localhost:9200/_cluster/settings?pretty" -H 'Content-Type: application/json' -d'
{
 "transient" : {
 "indices.recovery.*" : null
 }
}
'

ElasticSearch通過靜態配置文件的方式啟動集群

失敗的原因應該是啟動容器的時候應該少了參數。
官網文檔 上說將來的版本不再使用discovery.zen.ping.unicast.hosts也就變成discovery.seed_hosts

es-node1節點的配置文件信息

vim /var/lib/docker/volumes/es_conf/_data/es01.yml

請修改注釋行宿主機ip,以及es集群通信的端口地址

cluster.name: elasticsearch-cluster
node.name: es-node1
network.bind_host: 0.0.0.0
network.publish_host: 192.168.117.231 #修改為docker的宿主機ip
http.port: 9200 #這個是容器內部的,所以不用改
transport.tcp.port: 9300 #這個是容器內部的,所以不用改
http.cors.enabled: true
http.cors.allow-origin: "*"
node.master: true 
node.data: true 
discovery.seed_hosts: ["192.168.117.231:9300","192.168.117.231:9301","192.168.117.232:9302"] 
discovery.zen.minimum_master_nodes: 2
indices.query.bool.max_clause_count: 10240
#使用一臺主機的不同端口搭建,在啟動docker容器的時候通過-p指定映射端口

通過上述配置文件中可知需要映射端口分別是9300、9301、9302,這些端口是用來進行集群通信的
也就是三個節點綁定端口分別是-p 9300:9300,-p 9301:9300,-p 9302:9300,
同時我們可以推出使用-p 9200:9200,-p 9201:9200,-p 9202:9200


做成表格:

節點 綁定宿主機端口1 綁定宿主機端口2
es-node1 9200 9300
es-node2 9201 9301
es-node3 9202 9301
作用 對外提供服務的端口 es1-es3集群間進行通訊的端口
也就是說宿主機(192.168.117.231)的9200-9202,9300-9302端口都會被es集群使用


es-node2節點的配置文件信息

vim /var/lib/docker/volumes/es_conf/_data/es02.yml

與es-node1不同的地方就是節點名改一下

cluster.name: elasticsearch-cluster
node.name: es-node2
network.bind_host: 0.0.0.0
network.publish_host: 192.168.117.231 #修改為docker的宿主機ip
http.port: 9200 #這個是容器內部的,所以不用改
transport.tcp.port: 9300 #這個是容器內部的,所以不用改
http.cors.enabled: true
http.cors.allow-origin: "*"
node.master: true 
node.data: true 
discovery.seed_hosts: ["192.168.117.231:9300","192.168.117.231:9301","192.168.117.232:9302"]
discovery.zen.minimum_master_nodes: 2
indices.query.bool.max_clause_count: 10240
#使用一臺主機的不同端口搭建,在啟動docker容器的時候通過-p指定映射端口

es-node3節點的配置文件信息

vim /var/lib/docker/volumes/es_conf/_data/es02.yml

與es-node1不同的地方就是節點名改一下

cluster.name: elasticsearch-cluster
node.name: es-node3
network.bind_host: 0.0.0.0
network.publish_host: 192.168.117.231 #修改為docker的宿主機ip
http.port: 9200 #這個是容器內部的,所以不用改
transport.tcp.port: 9300 #這個是容器內部的,所以不用改
http.cors.enabled: true
http.cors.allow-origin: "*"
node.master: true 
node.data: true 
discovery.seed_hosts: ["192.168.117.231:9300","192.168.117.231:9301","192.168.117.232:9302"]
discovery.zen.minimum_master_nodes: 2
indices.query.bool.max_clause_count: 10240
#使用一臺主機的不同端口搭建,在啟動docker容器的時候通過-p指定映射端口

依次啟動集群

es-node1啟動命令,docker進程別名es01

使用的網絡是上面創建的網卡es_net,指定節點的內部網絡ip 172.18.0.100需要和es_net同網段

docker run -it -d --restart always -p 9200:9200 -p 9300:9300 \

--name es01 --network=es_net --ip=172.18.0.100 \

-v es_data01:/usr/share/elasticsearch/data \

-v /var/lib/docker/volumes/es_conf/_data/es01.yml:/usr/share/elasticsearch/config/elasticsearch.yml \

-v es_plugins:/usr/share/elasticsearch/plugins \

-e ES_JAVA_OPTS="-Xms64m -Xmx128m" elasticsearch:7.8.0

ES_JAVA_OPTS指定使用的es的內存,防止啟動es占用太多內存空間
--restart always開機自啟
數據卷映射略,唯一需要注意的是配置文件es01.yml映射到了內部的es啟動時,引使用的配置文件。


es-node2啟動命令

docker run -it -d --restart always -p 9201:9200 -p 9301:9300 \

--name es02 --network=es_net --ip=172.18.0.101 \

-v es_data02:/usr/share/elasticsearch/data \

-v /var/lib/docker/volumes/es_conf/_data/es02.yml:/usr/share/elasticsearch/config/elasticsearch.yml \

-v es_plugins:/usr/share/elasticsearch/plugins \

-e ES_JAVA_OPTS="-Xms64m -Xmx128m" elasticsearch:7.8.0

es-node3啟動命令

docker run -it -d --restart always -p 9202:9200 -p 9302:9300 \

--name es03 --network=es_net --ip=172.18.0.102 \

-v es_data03:/usr/share/elasticsearch/data \

-v /var/lib/docker/volumes/es_conf/_data/es03.yml:/usr/share/elasticsearch/config/elasticsearch.yml \

-v es_plugins:/usr/share/elasticsearch/plugins \

-e ES_JAVA_OPTS="-Xms64m -Xmx128m" elasticsearch:7.8.0

到此這篇關于docker安裝ElasticSearch:7.8.0集群的文章就介紹到這了,更多相關docker安裝ElasticSearch集群內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

標簽:汕頭 玉林 晉城 石嘴山 開封 拉薩 三明 鄭州

巨人網絡通訊聲明:本文標題《docker安裝ElasticSearch:7.8.0集群的詳細教程》,本文關鍵詞  docker,安裝,ElasticSearch,7.8.0,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《docker安裝ElasticSearch:7.8.0集群的詳細教程》相關的同類信息!
  • 本頁收集關于docker安裝ElasticSearch:7.8.0集群的詳細教程的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 清新县| 汝州市| 来宾市| 余江县| 柳林县| 隆林| 东方市| 万源市| 汽车| 金沙县| 临沂市| 双鸭山市| 孝义市| 浮山县| 玉溪市| 开封市| 通化县| 长顺县| 高碑店市| 泰宁县| 淮滨县| 贡嘎县| 吉木萨尔县| 宜川县| 左权县| 康保县| 江川县| 乳源| 兴隆县| 天津市| 万盛区| 荆州市| 天津市| 治多县| 兴宁市| 米泉市| 南投市| 永和县| 南阳市| 望谟县| 宜兰县|