Docker怎么部署ElasticSearch和ElasticSearch-Head(docker,elasticsearch,elasticsearch-head,移动开发)

时间:2024-05-04 20:15:00 作者 : 石家庄SEO 分类 : 移动开发
  • TAG :

1.docker部署elasticsearch:6.8.4版本

1.1 拉取镜像

dockerpulldocker.elastic.co/elasticsearch/elasticsearch:6.8.4

1.2 运行容器

elasticsearch的默认端口是9200,我们把宿主环境9200端口映射到docker容器中的9200端口,就可以访问到docker容器中的elasticsearch服务了,同时我们把这个容器命名为es。

dockerrun-d--namees-p9200:9200-p9300:9300-e"discovery.type=single-node"-ees_java_opts="-xms=256m-xms=256m"docker.elastic.co/elasticsearch/elasticsearch:6.8.4

说明:

-e discovery.type=single-node :表示单节点启动

-e es_java_opts="-xms=256m -xms=256m" :表示设置es启动的内存大小,这个真的要设置,不然后时候会内存不够,比如我自己的辣鸡服务器!

1.3 内存不足问题

centos下载完elasticsearch并修改完配置后运行docker命令:

发现没有启动成功,去除命令的-d后打印错误如下

javahotspot(tm)64-bitservervmwarning:info:os::commit_memory(0x0000000085330000,2060255232,0)failed;error='cannotallocatememory'(errno=12)

经过一番查找发现这是由于elasticsearch6.0默认分配jvm空间大小为2g,内存不足以分配导致。

解决方法就是修改jvm空间分配
运行命令:

find/var/lib/docker/overlay/-namejvm.options查找jvm.options文件,找到后进入使用vi命令打开jvm.options如下:将-xms2g-xmx2g修改为-xms512m-xmx512m

保存退出即可。再次运行创建运行elasticsearch命令,成功启动。

2.docker部署elasticsearch-heard

2.1 拉取镜像

dockerpullmobz/elasticsearch-head:5

2.2 运行容器

dockercreate--nameelasticsearch-head-p9100:9100mobz/elasticsearch-head:5

2.3 启动容器

dockerstartelasticsearch-head

2.4 打开浏览器: http://ip:9100

发现连接不上,是因为有跨域问题,因为前后端分离开发的所以需要设置一下es

2.5 进入刚刚启动的 es 容器,容器name = es

dockerexec-ites/bin/bash

2.6 修改elasticsearch.yml文件

viconfig/elasticsearch.yml

添加

http.cors.enabled:truehttp.cors.allow-origin:"*"

其实就是springboot的yml文件 添加跨域支持

2.7 退出容器 并重启

exitdockerrestartes

2.8 访问

Docker怎么部署ElasticSearch和ElasticSearch-Head

 </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
本文:Docker怎么部署ElasticSearch和ElasticSearch-Head的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:docker安装elasticsearch和kibana实例分析下一篇:

5 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18