docker elasticsearch 和elasticsearch-head两个镜像安装

本文记录了作者在Docker环境下安装Elasticsearch及其Head插件的过程及遇到的问题。通过直接使用官方镜像并进行少量配置修改,最终实现了集群状态的正常查看。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这两天我一直在安装elasticsearch和elasticsearch-head这个插件,本来是在elasticsearch这个官方镜像上安装,但是安装elasticsearch-head这个插件的时候,不知道为什么只要是下载下来的,(使用git or cp进去)都直接exit的时候容器就启动不下来了,这让我删了启动,启动了又从新加载,可气死我了

各种文章各种找啊,但是就是不行,真心不知道这是why?

下面是我直接下载官方的elasticsearch和mobz/elasticsearch-head这两个镜像

docker pull elasticsearch:lastet
docker pull mobz/elasticsearch-head:5

elsasticsearch.yml

# head插件设置
http.cors.enabled: true
http.cors.allow-origin: "*"

修改head里面的Gruntfile.js

connect: {
        server: {
            options: {
                /* 默认监控:127.0.0.1,修改为:0.0.0.0 */
                hostname: '0.0.0.0',
                port: 9100,
                base: '.',
                keepalive: true
            }
        }

创建容器

 # es
docker run -d --name es -p 9200:9200 -p 9300:9300 -v /root/es_docker/es1.yml:/usr/share/elasticsearch/config/elasticsearch.yml  elasticsearch:latest
 # head
docker run -d --name head -p 9100:9100 -v /root/es_docker/head/Gruntfile.js:/usr/src/app/Gruntfile.js mobz/elasticsearch-head:5

查看Head集群状态

127.0.0.1:9100

就这么简单,我还自己安装傻了吧唧安装两天光出问题了,我争取自己写一个在一个容器安装多个插件

### 如何在 Docker安装配置 Elasticsearch Head 插件 #### 获取镜像并启动容器 为了使 Elasticsearch Head 正常工作,需先拉取对应的 Docker 镜像。命令如下: ```bash docker pull mobz/elasticsearch-head:5 ``` 随后通过 `docker run` 命令来创建并启动容器,指定端口映射其他必要参数[^2]。 ```bash docker run -d \ --name es-head \ --restart=always \ --network=host \ docker.io/mobz/elasticsearch-head:5-alpine ``` 此操作会以后台模式运行名为 `es-head` 的新容器,并将其绑定到主机网络上以便于访问[^4]。 #### 修改文件挂载路径 (可选) 如果希望自定义某些配置文件或脚本,则可以考虑将本地目录中的特定文件挂载至容器内部相应位置。例如修改 JavaScript 文件时可用下面的方式启动容器[^3]: ```bash docker run -d \ --name es-head \ -p 9100:9100 \ -v /usr/local/docker/elasticsearch-head/app.js:/usr/src/app/_site/app.js \ -v /usr/local/docker/elasticsearch-head/vendor.js:/usr/src/app/_site/vendor.js \ mobz/elasticsearch-head:5 ``` 这允许外部编辑 `_site/vendor.js` 其他资源而不必每次都重建整个容器实例[^1]。 #### 使用 Docker Compose 方便管理服务组合 对于更复杂的部署场景,推荐采用 `docker-compose.yml` 来简化多服务环境下的设置过程。一个简单的例子可能看起来像是这样[^5]: ```yaml version: '3' services: es-head: restart: always image: elasticsearch-head:5 container_name: es-head ports: - "9100:9100" volumes: - ./config/vendor.js:/usr/src/app/_site/vendor.js ``` 保存上述 YAML 文档后,在同一目录下执行 `docker-compose up -d` 即可一键完成所有相关组件的一次性构建与激活。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值