> /idata/es/config/elasticsearch.ymlchmod -R 777 /idata/es/ #保证权限docker run --name elastics。Docker实战之ElasticSearch。" />

Docker实战之ElasticSearch

安装ElasticSearch 1、安装ElasticSearch单例模式 a.配置ES

mkdir -p /idata/es/config mkdir -p /idata/es/data echo "http.host: 0.0.0.0" >> /idata/es/config/elasticsearch.yml chmod -R 777 /idata/es/ #保证权限 docker run --name elasticsearch -p 9200:9200 -p 9300:9300 \ -e "discovery.type=single-node" \ -e ES_JAVA_OPTS="-Xms64m -Xmx512m" \ -v /idata/es/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml \ -v /idata/es/data:/usr/share/elasticsearch/data \ -v /idata/es/plugins:/usr/share/elasticsearch/plugins \ -d elasticsearch:7.4.2

docker run --name kibana -e ELASTICSEARCH_HOSTS=http://192.168.0.10:9200 -p 5601:5601 \ -d kibana:7.4.2

b.检查容器是否启动
【Docker实战之ElasticSearch】Docker实战之ElasticSearch
文章图片

c.测试ES是否安装成功
Docker实战之ElasticSearch
文章图片

2、安装ElasticSearch集群模式
#安装Es集群 所有之前先运行:sysctl -w vm.max_map_count=262144 我们只是测试,所以临时修改。永久修改使用下面 #防止 JVM 报错 echo vm.max_map_count=262144 >> /etc/sysctl.conf sysctl -p##############3-master########################## for port in $(seq 1 3); \ do \ mkdir -p /mydata/elasticsearch/master-${port}/config mkdir -p /mydata/elasticsearch/master-${port}/data chmod -R 777 /mydata/elasticsearch/master-${port} cat << EOF >/mydata/elasticsearch/master-${port}/config/elasticsearch.yml cluster.name: my-es #集群的名称,同一个集群该值必须设置成相同的 node.name: es-master-${port} #该节点的名字 node.master: true #该节点有机会成为 master 节点 node.data: false #该节点可以存储数据 network.host: 0.0.0.0 http.host: 0.0.0.0 #所有 http 均可访问 http.port: 920${port} transport.tcp.port: 930${port} discovery.zen.ping_timeout: 10s #设置集群中自动发现其他节点时 ping 连接的超时时间 discovery.seed_hosts: ["172.18.12.21:9301", "172.18.12.22:9302", "172.18.12.23:9303"] #设置集群中的 Master 节点的初始列表,可以通过这些节点来自动发现其他新加入集群的节点,es7的新增配置; cluster.initial_master_nodes: ["172.18.12.21"] #新集群初始时的候选主节点,es7 的新增配置 EOF docker run --name elasticsearch-node-${port} \ -p 920${port}:920${port} -p 930${port}:930${port} \ --network=mynet --ip 172.18.12.2${port} \ -e ES_JAVA_OPTS="-Xms300m -Xmx300m" \ -v /mydata/elasticsearch/master-${port}/config/elasticsearch.yml:/usr/share/elasticsearch/config/el asticsearch.yml \ -v /mydata/elasticsearch/master-${port}/data:/usr/share/elasticsearch/data \ -v /mydata/elasticsearch/master-${port}/plugins:/usr/share/elasticsearch/plugins \ -d elasticsearch:7.4.2 done#######################3-node####################### for port in $(seq 4 6); \ do \ mkdir -p /mydata/elasticsearch/node-${port}/config mkdir -p /mydata/elasticsearch/node-${port}/data chmod -R 777 /mydata/elasticsearch/node-${port} cat << EOF >/mydata/elasticsearch/node-${port}/config/elasticsearch.yml cluster.name: my-es #集群的名称,同一个集群该值必须设置成相同的 node.name: es-node-${port} #该节点的名字 node.master: false #该节点有机会成为 master 节点 node.data: true #该节点可以存储数据 network.host: 0.0.0.0 #network.publish_host: 192.168.56.10 #互相通信 ip,要设置为本机可被外界访问的 ip,否则 无法通信 http.host: 0.0.0.0 #所有 http 均可访问 http.port: 920${port} transport.tcp.port: 930${port} #discovery.zen.minimum_master_nodes: 2 #设置这个参数来保证集群中的节点可以知道其 它 N 个有 master 资格的节点。官方推荐(N/2)+1 discovery.zen.ping_timeout: 10s #设置集群中自动发现其他节点时 ping 连接的超时时间 discovery.seed_hosts: ["172.18.12.21:9301", "172.18.12.22:9302", "172.18.12.23:9303"] #设置集群中的 Master 节点的初始列表,可以通过这些节点来自动发现其他新加入集群的节点,es7 的新增配置 cluster.initial_master_nodes: ["172.18.12.21"] #新集群初始时的候选主节点,es7 的新增配置 EOF docker run --name elasticsearch-node-${port} \ -p 920${port}:920${port} -p 930${port}:930${port} \ --network=mynet --ip 172.18.12.2${port} \ -e ES_JAVA_OPTS="-Xms300m -Xmx300m" \ -v /mydata/elasticsearch/node-${port}/config/elasticsearch.yml:/usr/share/elasticsearch/config/ela sticsearch.yml \ -v /mydata/elasticsearch/node-${port}/data:/usr/share/elasticsearch/data \ -v /mydata/elasticsearch/node-${port}/plugins:/usr/share/elasticsearch/plugins \ -d elasticsearch:7.4.2 done

检查
  • _nodes/process?pretty 查看节点状况
  • _cluster/stats?pretty 查看集群状态
  • _cluster/health?pretty 查看集群健康状况
  • _cat/nodes 查看各个节点信息
- discovery.seed_hosts=es01,es03 - cluster.initial_master_nodes=es01,es02,es03 #还可以只开放一个实例端口.其他的都用集群内访问就可以啦。

#也可以使用自定义Docker网络的方式 docker network create --driver bridge --subnet 172.21.0.0/16 --gateway 172.21.0.1 mynet #运行容器的时候,使用 --ip --network指定网络

    推荐阅读