集群部署
文檔:https://www.elastic.co/guide/en/elasticsearch/reference/7.6/index.html
下載:https://elasticsearch.cn/download/
主機 | ip | 角色 |
k8s1 | 192.168.92.11 | cerebro |
elk1 | 192.168.92.31 | elasticsearch |
elk2 | 192.168.92.32 | elasticsearch |
elk3 | 192.168.92.33 | elasticsearch |
elk4 | 192.168.92.34 | logstash |
elk5 | 192.168.92.35 | kibana |
配置解析
[root@elk1 ~]# cat /etc/hosts
軟件安裝
[root@elk1 ~]# rpm -ivh elasticsearch-7.6.1-x86_64.rpm
修改配置
[root@elk1 ~]# cd /etc/elasticsearch/[root@elk1 elasticsearch]# vim elasticsearch.yml
cluster.name: my-esnetwork.host: 0.0.0.0http.port: 9200discovery.seed_hosts: ["elk1", "elk2", "elk3"]cluster.initial_master_nodes: ["elk1", "elk2", "elk3"]
系統設置
[root@elk1 ~]# vim /etc/security/limits.confelasticsearch soft memlock unlimited
elasticsearch hard memlock unlimited
elasticsearch - nofile 65535
elasticsearch - nproc 4096[root@elk1 ~]# vim /usr/lib/systemd/system/elasticsearch.service[service]
...
LimitMEMLOCK=infinity[root@elk1 ~]# systemctl daemon-reload
[root@elk1 ~]# swapoff -a[root@elk1 ~]# vim /etc/fstab
[root@elk1 ~]# systemctl daemon-reload[root@elk1 ~]# systemctl enable --now elasticsearch
elk1配置好后,直接把配置復制到elk2和elk3
配置ssh免密
[root@elk1 ~]# ssh-keygen[root@elk1 ~]# ssh-copy-id server2[root@elk1 ~]# ssh-copy-id server3
復制軟件
[root@elk1 ~]# scp elasticsearch-7.6.1-x86_64.rpm server2:[root@elk1 ~]# scp elasticsearch-7.6.1-x86_64.rpm server3:
elk2和elk3軟件安裝
[root@elk2 ~]# rpm -ivh elasticsearch-7.6.1-x86_64.rpm[root@elk3 ~]# rpm -ivh elasticsearch-7.6.1-x86_64.rpm
從elk1復制配置
[root@elk1 ~]# cd /etc/elasticsearch/[root@elk1 elasticsearch]# scp elasticsearch.yml elk2:/etc/elasticsearch/[root@elk1 elasticsearch]# scp elasticsearch.yml elk3:/etc/elasticsearch/[root@elk1 elasticsearch]# scp /etc/security/limits.conf elk2:/etc/security/[root@elk1 elasticsearch]# scp /etc/security/limits.conf elk3:/etc/security/[root@elk1 elasticsearch]# scp /usr/lib/systemd/system/elasticsearch.service elk2:/usr/lib/systemd/system/[root@elk1 elasticsearch]# scp /usr/lib/systemd/system/elasticsearch.service elk3:/usr/lib/systemd/system/
server2上啟動服務
[root@elk2 ~]# swapoff -a[root@elk2 ~]# vim /etc/fstab
[root@elk2 ~]# systemctl daemon-reload[root@elk2 ~]# systemctl enable --now elasticsearch
server3上啟動服務
[root@elk3 ~]# swapoff -a[root@elk3 ~]# vim /etc/fstab
[root@elk3 ~]# systemctl daemon-reload[root@elk3 ~]# systemctl enable --now elasticsearch
cerebro部署
cerebro官方:https://github.com/lmenezes/cerebro/
使用docker啟動服務
[root@k8s1 ~]# docker pull lmenezes/cerebro[root@k8s1 ~]# docker run -d --name cerebro -p 9000:9000 lmenezes/cerebro
訪問網頁:192.168.92.11:9000
節點地址可以填寫任意ES集群節點ip
elasticsearch集群角色分類
[root@elk1 ~]# vim /etc/elasticsearch/elasticsearch.ymlnode.master: true
node.data: false
node.ingest: true
node.ml: false[root@elk1 ~]# systemctl restart elasticsearch.service
[root@elk2 ~]# vim /etc/elasticsearch/elasticsearch.ymlnode.master: true
node.data: true
node.ingest: false
node.ml: false[root@elk2 ~]# systemctl restart elasticsearch.service
[root@elk3 ~]# vim /etc/elasticsearch/elasticsearch.ymlnode.master: true
node.data: true
node.ingest: false
node.ml: false[root@elk3 ~]# systemctl restart elasticsearch.service