使用 docker 進行 ElasticSearch + Kibana 集群搭建

在Docker容器中運行Elasticsearch Kibana和Cerebro

機器資訊

10.160.13.139
10.160.9.162
10.160.11.171

1. 安裝docker和docker compose

安裝docker

# 安裝 docker 社區版
yum -y install docker-ce docker-ce-cli containerd.io
# 啟動 Docker
systemctl start docker
# 查看 docker 版本
docker version
# 開機啟動 Docker
systemctl enable docker

安裝docker-compose

sudo curl -L //github.com/docker/compose/releases/download/1.27.4/docker-compose-`uname -s`-`uname -m` \
> /usr/local/bin/docker-compose
# 添加執行許可權
sudo chmod +x /usr/local/bin/docker-compose
# 驗證
docker-compose --version
docker-compose version 1.27.4, build 40524192

2. 下載鏡像

docker pull elasticsearch:7.10.1
docker pull kibana:7.10.1

3. 將 kibana 上傳到私有harbor

[@master software]# docker images |grep kibana
kibana                           7.10.1              3e014820ee3f        3 weeks ago         992MB
[@master software]# docker tag 3e014820ee3f www.test.com/elk/kibana:7.10.1
[@master software]# docker login www.test.com
Username: song
Password:
Login Succeeded
[@master software]# docker push www.test.com/elk/kibana:7.10.1
The push refers to repository [www.test.com/elk/kibana]
00cfe116c0b3: Pushed
20889a7593bc: Pushed
d1409dea493d: Pushed
3448a6e61306: Pushed
f3a4630cb1b0: Pushed
0e3f51adbdfe: Pushed
7bb6eb357f15: Pushed
0263a48f9a3a: Pushed
5acb536ef82f: Pushed
58d51bd5abeb: Pushed
e116279745ca: Pushed
cc33c1bea858: Pushed
5ec5e9c8cf6f: Pushed
291f6e44771a: Pushed
7.10.1: digest: sha256:1731793b7f3e453c65ebaf92ec0b55f4029310ba8abae9e04753a4680dd8210b size: 3247
[@master software]#

4. 將 elasticsearch 上傳到私有harbor

[@master software]# docker images |grep elastic
elasticsearch                    7.10.1              558380375f1a        3 weeks ago         774MB
[@master software]# docker tag 558380375f1a www.test.com/elk/elasticsearch:7.10.1
[@master software]# docker push www.test.com/elk/elasticsearch:7.10.1
The push refers to repository [www.test.com/elk/elasticsearch]
d6208dd58075: Pushed
9117213e7470: Pushed
b662ef6f4fc1: Pushed
3f481e912123: Pushed
b456348ecd84: Pushed
e2834bada95f: Pushed
8f84abff69b8: Pushed
911490c8ab00: Pushed
291f6e44771a: Mounted from elk/kibana
7.10.1: digest: sha256:e9a1fe65f68b2d2b9583287d1190f67f23af08582eac4d2a8dc342e4219c7306 size: 2202
[@master software]#

5 .作業系統優化

作業系統以及JVM調優主要是針對安裝elasticsearch的機器。對於作業系統,需要調整幾個內核參數

vim /etc/sysctl.conf
# fs.file-max主要是配置系統最大打開文件描述符數,建議修改為655360或者更高
fs.file-max=655360
# vm.max_map_count影響Java執行緒數量,用於限制一個進程可以擁有的VMA(虛擬記憶體區域)的大小
# 系統默認是65530,建議修改成262144或者更高。
vm.max_map_count = 262144
sysctl -p
sysctl -a

另外,還需要調整進程最大打開文件描述符(nofile)、最大用戶進程數(nproc)和最大鎖定記憶體地址空間(memlock),

vim /etc/security/limits.conf
*        soft    nproc           20480
*        hard    nproc           20480
*        soft    nofile          65536
*        hard    nofile          65536
*        soft    memlock         unlimited
*        hard    memlock         unlimited
# 備註: * 代表Linux所有用戶名稱(比如es),保存,退出,重新登錄才可生效
# 查看
ulimit -a

最後,還需要修改

# /etc/security/limits.d/90-nproc.conf(centos6.x系統)
# /etc/security/limits.d/20-nproc.conf(centos7.x系統)

vim /etc/security/limits.d/20-nproc.conf
*          soft    nproc     4096
# 修改為:
*          soft    nproc     20480

或者直接刪除/etc/security/limits.d/20-nproc.conf文件也行。

6. JVM調優

JVM調優主要是針對elasticsearch的JVM記憶體資源進行優化,elasticsearch的記憶體資源配置文件為jvm.options,7.1下載的默認設置是1GB
從ES 6開始,只支援64位的JVM(配置config/jvm.options)

配置的建議

  • 將記憶體Xms和Xmx設置成一樣,避免heap resize時引發停頓
  • Xmx設置不要超過物理記憶體的50%,單個節點上,最大記憶體建議不要超過32G記憶體
  • 生產環境,JVM必須使用Server模式
  • 關閉JVM Swapping
vim /usr/local/elasticsearch/config/jvm.options
-Xms30g
-Xmx30g

7. 安裝 elasticsearch

你可以先新建一個 elasticsearch 文件夾。然後在這個文件夾中,新建一個 docker-compose.yml 文件。

運行docker-compose,本地構建更高效的開發環境,更直觀地了解 Elasticsearch 分散式特性

集成Cerebro,方便查看集群狀態

mkdir -p /search/odin/elasticsearch/{data01,data02,data03}

mkdir -p /Users/song/study/elasticsearch/plugins/ik

# ES_JAVA_OPTS="-Xms64m -Xmx512m" 記憶體限制,最小64m,最大512m,可根據需要自行調整,除此之外其他的配置不用做修改

cat /search/odin/elasticsearch/docker-compose.yml

version: '2.2'

services:
  cerebro:
    image: lmenezes/cerebro:0.8.3
    container_name: cerebro
    ports:
      - "9000:9000"
    command:
      - -Dhosts.0.host=//elasticsearch:9200
    networks:
      - elastic
  kibana:
    image: kibana:7.10.1
    container_name: kibana7
    environment:
      - I18N_LOCALE=zh-CN
      - XPACK_GRAPH_ENABLED=true
      - TIMELION_ENABLED=true
      - XPACK_MONITORING_COLLECTION_ENABLED="true"
    ports:
      - "5601:5601"
    networks:
      - elastic
  elasticsearch:
    image: elasticsearch:7.10.1
    container_name: es01
    environment:
      - node.name=es01
      - cluster.name=es-docker-cluster
      - discovery.seed_hosts=es02,es03
      - cluster.initial_master_nodes=es01,es02,es03
      - bootstrap.memory_lock=true
      - "ES_JAVA_OPTS=-Xms1024m -Xmx1024m"
    ulimits:
      nproc: 65535
      memlock:
        soft: -1
        hard: -1
    volumes:
      - data01:/usr/share/elasticsearch/data
      - /Users/song/study/elasticsearch/plugins/ik:/usr/share/elasticsearch/plugins/ik
    ports:
      - 9200:9200
      - 9300:9300
    networks:
      - elastic
  elasticsearch2:
    image: elasticsearch:7.10.1
    container_name: es02
    environment:
      - node.name=es02
      - cluster.name=es-docker-cluster
      - discovery.seed_hosts=es01,es03
      - cluster.initial_master_nodes=es01,es02,es03
      - bootstrap.memory_lock=true
      - "ES_JAVA_OPTS=-Xms1024m -Xmx1024m"
    ulimits:
      nproc: 65535
      memlock:
        soft: -1
        hard: -1
    volumes:
      - data02:/usr/share/elasticsearch/data
      - /Users/song/study/elasticsearch/plugins/ik:/usr/share/elasticsearch/plugins/ik
    ports:
      - 9201:9201
      - 9301:9301
    networks:
      - elastic
  elasticsearch3:
    image: elasticsearch:7.10.1
    container_name: es03
    environment:
      - node.name=es03
      - cluster.name=es-docker-cluster
      - discovery.seed_hosts=es01,es02
      - cluster.initial_master_nodes=es01,es02,es03
      - bootstrap.memory_lock=true
      - "ES_JAVA_OPTS=-Xms1024m -Xmx1024m"
    ulimits:
      nproc: 65535
      memlock:
        soft: -1
        hard: -1
    volumes:
      - data03:/usr/share/elasticsearch/data
      - /Users/song/study/elasticsearch/plugins/ik:/usr/share/elasticsearch/plugins/ik
    ports:
      - 9202:9202
      - 9302:9302
    networks:
      - elastic
  elastichd:
    image: containerize/elastichd:latest
    container_name: elasticsearch-hd
    networks:
      - elastic
    ports:
      - 9800:9800
    depends_on:
      - "elasticsearch"
    links:
      - "elasticsearch:demo"

volumes:
  data01:
    driver: local
  data02:
    driver: local
  data03:
    driver: local

networks:
  elastic:
    driver: bridge

運行docker-compose,安裝Elasticsearch

啟動

screen
docker-compose up

訪問測試

curl -X GET "localhost:9200/_cat/nodes?v&pretty"

停止容器

docker-compose down

停止容器並且移除數據

docker-compose down -v

刪除單個容器

$docker rm 容器名/容器ID
-f, –force=false; 
-l, –link=false Remove the specified link and not the underlying container; 
-v, –volumes=false Remove the volumes associated to the container

刪除所有容器

$docker rm `docker ps -aq` 

停止、啟動、殺死、重啟一個容器

$ docker stop 容器名/容器ID 
$ docker start 容器名/容器ID  
$ docker kill 容器名/容器ID 
$ docker restart 容器名/容器ID

顯示容器資源使用統計

docker stats 容器ID
Tags: