本篇主要讲解使用Docker如何部署ElasticSearch:6.8.4 版本,讲解了从Docker拉取到最终运行ElasticSearch 以及 安装 ElasticSearch-Head 用来管理ElasticSearch相关信息的一个小工具,本博客系统首页的搜索正是使用了ElasticSearch来实现的,因为ElasticSearch 更新太快 以致于SpringData-ElasticSearch都跟不上 Es的更新 我也是一开始下载8.x的版本 致使SpringData-ElasticSearch 报错 最终我选择了6.8.4 在此记录一下node
docker pull docker.elastic.co/elasticsearch/elasticsearch:6.8.4
ElasticSearch的默认端口是9200,咱们把宿主环境9200端口映射到Docker容器中的9200端口,就能够访问到Docker容器中的ElasticSearch服务了,同时咱们把这个容器命名为es。docker
docker run -d --name es -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" -e ES_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启动的内存大小,这个真的要设置,否则后时候会内存不够,好比我本身的辣鸡服务器!后端
centos下载完elasticsearch并修改完配置后运行docker命令:centos
发现没有启动成功,去除命令的-d后打印错误以下跨域
Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x0000000085330000, 2060255232, 0) failed; error=’Cannot allocate memory’ (errno=12)
通过一番查找发现这是因为elasticsearch6.0默认分配jvm空间大小为2g,内存不足以分配致使。浏览器
解决方法就是修改jvm空间分配 运行命令:bash
find /var/lib/docker/overlay/ -name jvm.options 查找jvm.options文件,找到后进入使用vi命令打开jvm.options以下: 将 -Xms2g -Xmx2g 修改成 -Xms512m -Xmx512m
保存退出便可。再次运行建立运行elasticsearch命令,成功启动。服务器
docker pull mobz/elasticsearch-head:5
docker create --name elasticsearch-head -p 9100:9100 mobz/elasticsearch-head:5
docker start elasticsearch-head
发现链接不上,是由于有跨域问题,由于先后端分离开发的因此须要设置一下escors
docker exec -it es /bin/bash
vi config/elasticsearch.yml 添加 http.cors.enabled: true http.cors.allow-origin: "*"
其实就是SpringBoot的yml文件 添加跨域支持前后端分离
exit docker restart es
本篇只是简单的讲解了如何用Docker安装ElasticSearch 而且会遇到的坑,包括内存不足,或者版本过高等问题,以及ElasticSearch-Heard的安装和跨域的配置 ,下一篇将讲解ElasticSearch如何安装中文分词器
我的博客系统:https://www.askajohnny.com 欢迎访问! 本文由博客一文多发平台 OpenWrite 发布!