docker 安装elasticsearch
1 拉取elasticsearch镜像
docker pull elasticsearch:7.13.2
2 创建用于挂载的目录
mkdir -p /data/elasticsearch/conf
mkdir -p /data/elasticsearch/data
mkdir -p /data/elasticsearch/plugins
#将http.host: 0.0.0.0写入elasticsearch.yml
echo "http.host: 0.0.0.0" >> /data/elasticsearch/conf/elasticsearch.yml
3 将文件夹赋权
chmod -R 777 /data/elasticsearch/
4 使用镜像创建容器
docker run --name elasticsearch --restart=always
-p 9200:9200 -p 9300:9300 \
-e "discovery.type=single-node" \
-e ES_JAVA_OPTS="-Xms128m -Xmx256m" \
-v /data/elasticsearch/conf/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml \
-v /data/elasticsearch/data:/usr/share/elasticsearch/data \
-v /data/elasticsearch/plugins:/usr/share/elasticsearch/plugins \
-d elasticsearch:7.13.2
-e "discovery.type=single-node" :单节点运行
-e ES_JAVA_OPTS="-Xms64m -Xmx128m":设初始内存64m 最大内存128m
–p:映射宿主主机端口
-v:挂载宿主目录到容器目录
-d:后台运行容器
--restart=always: 开机启动
5 配置ik分词器
5.1 下载elasticsearch-analysis-ik-7.13.2
github下载地址 下载对应的版本
5.2 将下载的ik解压重命名到/data/elasticsearch/plugins下
#解压
tar -zxvf elasticsearch-analysis-ik.tar.gz /data/elasticsearch/plugins/
#重命名
mv elasticsearch-analysis-ik ik
#授权
chmod -R 777 /data/elasticsearch/ik
5.3 配置自定义远程扩展字典
vi /data/elasticsearch/plugins/ik/config/IKAnalyzer.cfg.xml
<properties>
<comment>IK Analyzer 扩展配置</comment>
<!--用户可以在这里配置自己的扩展字典 -->
<entry key="ext_dict"></entry>
<!--用户可以在这里配置自己的扩展停止词字典-->
<entry key="ext_stopwords"></entry>
<!--
用户可以在这里配置远程扩展字典
http://192.168.56.10/es/fenci.txt 这里为nginx对应的路径
-->
<entry key="remote_ext_dict">http://192.168.56.10/es/fenci.txt</entry>
<!--用户可以在这里配置远程扩展停止词字典-->
<!-- <entry key="remote_ext_stopwords">words_location</entry> -->
</properties>
注意:这里需要安装nginx,在nginx的html/es目录下创建fenci.txt