Docker 安装 ElasticSearch 及 挂载目录

1 拉取ES镜像

docker pull elasticsearch:7.7.0

2 安装临时ES容器,用于拷贝挂载文件

docker run --name es -d -e ES_JAVA_OPTS="-Xms512m -Xmx512m" -e "discovery.type=single-node" -p 9200:9200 -p 9300:9300 elasticsearch:7.7.0

3 拷贝挂载目录下的文件

docker cp -a es:/usr/share/elasticsearch/config/ /opt/es

docker cp -a es:/usr/share/elasticsearch/data/ /opt/es

docker cp -a es:/usr/share/elasticsearch/logs/ /opt/es

docker cp -a es:/usr/share/elasticsearch/plugins/ /opt/es

4 停止es服务,并删除临时容器

docker stop es

docker rm es

5 创建正式es容器

docker run -p 9200:9200 -p 9300:9300 \

--privileged=true --name es \

-e "discovery.type=single-node" \

-e ES_JAVA_OPTS="-Xms256m -Xmx256m" \

-v /opt/es/plugins:/usr/share/elasticsearch/plugins \

-v /opt/es/data:/usr/share/elasticsearch/data \

-v /opt/es/logs:/usr/share/elasticsearch/logs \

-v /opt/es/config:/usr/share/elasticsearch/config \

-d elasticsearch:7.7.0

说明

1 privileged=true 允许访问挂载目录

2 "discovery.type=single-node" 单机版

3 ES_JAVA_OPTS="-Xms256m -Xmx256m" 设置内存,如果服务器内存不是很大,这里设置小点,否则服务将起不来

6 设置允许跨域

打开es配置文件 elasticsearch.yml,添加如下,这样head插件就可以访问 es服务器了

http.cors.enabled: true

http.cors.allow-origin: "*"

http.cors.allow-headers: Authorization,X-Requested-With,Content-Length,Content-Type

7 kibana远程访问

如果你本地已经安装了kibana就无需在远程服务器上安装kibana了,只要做如下的设置就可以通过本地的kibana访问远程的es,打开本地的kibana的配置文件 kibana.yml,添加如下语句

elasticsearch.hosts: ["<此处填写自己的远程服务器ip:9200>"]

相关推荐
做运维的阿瑞6 小时前
Docker 从入门到精通:完整通关笔记
笔记·docker·容器
❀͜͡傀儡师8 小时前
使用docker 安装dragonfly带配置文件(x86和arm)版本
运维·docker·容器
Mr. Cao code11 小时前
Dockerfile 指令详解与实战指南
linux·运维·ubuntu·docker·容器
风清再凯11 小时前
05-企业级私有仓库Harbor
docker
失因11 小时前
Docker 镜像结构与 Dockerfile 案例
运维·docker·云原生·容器·tomcat
九皇叔叔12 小时前
Docker 镜像维护指南:从配置优化到 MySQL 实战运行
mysql·adb·docker
X-Dragon烟雨任平生12 小时前
Elasticsearch
大数据·elasticsearch·搜索引擎
INFINI Labs12 小时前
Elasticsearch 备份:snapshot 镜像使用篇
大数据·elasticsearch·搜索引擎·snapshot·backup
JAVA学习通13 小时前
JetLinks设备接入的认识与理解
运维·docker·容器·rocketmq
jyan_敬言13 小时前
【Docker】docker存储配置与管理
docker·容器·dubbo·学习方法