elasticsearch7如何用docker-compose部署并设置密码?

55 次浏览次阅读
没有评论

Elasticsearch 7使用Docker-Compose部署及密码配置实战指南

在当今数据驱动的技术生态中,Elasticsearch作为分布式搜索和分析引擎已成为企业级应用的核心组件。借助Docker容器化部署方案,开发者可以在5分钟内快速搭建生产级环境。本文将详解如何通过docker-compose部署Elasticsearch 7并配置账号密码认证,为您的数据安全保驾护航。

一、Docker-Compose部署Elasticsearch 7

1.1 准备docker-compose.yml文件

创建并编辑docker-compose.yml文件,使用以下配置实现单节点部署:

version: "3.8"
services:
  elasticsearch:
    container_name: es
    image: elasticsearch:7.17.3
    ports:
      "9200:9200"
      "9300:9300"
    environment:
      node.name=es
      cluster.name=elasticsearch
      discovery.type=single-node
      ES_JAVA_OPTS=-Xms1g -Xmx1g
      network.host=0.0.0.0
    volumes:
      /opt/docker/elasticsearch/data:/usr/share/elasticsearch/data
      /opt/docker/elasticsearch/config:/usr/share/elasticsearch/config
    restart: unless-stopped

关键参数说明:

  • 设置discovery.type=single-node实现单节点模式
  • 通过volumes挂载数据目录和配置文件
  • 建议根据服务器内存调整ES_JAVA_OPTS参数值

1.2 启动Elasticsearch服务

执行部署命令并验证服务状态:

 启动容器
docker-compose up -d

 检查服务健康状态
curl http://localhost:9200/_cluster/health?pretty

当看到包含“status” : “green”的JSON响应时,说明基础部署成功。

二、配置Elasticsearch账号密码认证

2.1 生成安全证书

进入容器生成X.509证书:

docker exec -it es /bin/bash
 生成CA证书
bin/elasticsearch-certutil ca --pem --out config/certs/ca.zip
 解压证书
unzip config/certs/ca.zip -d config/certs/

2.2 启用安全配置

在elasticsearch.yml中追加以下配置:

xpack.security.enabled: true
xpack.security.transport.ssl.enabled: true
xpack.security.transport.ssl.verification_mode: certificate 
xpack.security.transport.ssl.keystore.path: certs/ca/ca.p12
xpack.security.transport.ssl.truststore.path: certs/ca/ca.p12

2.3 设置初始密码

执行密码初始化命令:

bin/elasticsearch-setup-passwords auto

终端将输出包含elastic、kibana_system等系统用户的随机密码,请务必记录保存。

2.4 验证密码登录

curl -u elastic:your_password http://localhost:9200/_security/_authenticate

返回“authenticated” : true即表示密码认证生效。

三、生产环境强化建议

  • 密码管理:定期通过bin/elasticsearch-reset-password工具更换密码
  • 网络隔离:限制9200端口仅对内部网络开放
  • 备份策略:定期备份/usr/share/elasticsearch/config/certs证书目录
  • 监控告警:集成Prometheus监控登录失败次数等安全指标

四、常见问题排查

4.1 证书权限错误

若出现SSLHandshakeException错误,执行:

chmod 600 /opt/docker/elasticsearch/config/certs/

4.2 忘记密码处理

通过交互模式重置密码:

docker exec -it es bin/elasticsearch-reset-password -i -u elastic

通过本文的Docker-Compose部署+密码认证配置方案,开发者可以在保障安全性的前提下快速搭建Elasticsearch服务。建议结合Kibana可视化工具进行集群监控,并通过RBAC机制细化权限管理,构建完整的搜索服务安全体系。

正文完
 0

真人堂

一言一句话
-「
最新文章
Qwen3-32B通过Clawdbot直连Web网关时如何支持WebSocket心跳保活?

Qwen3-32B通过Clawdbot直连Web网关时如何支持WebSocket心跳保活?

Qwen3-32B通过Clawdbot直连Web网关时如何支持WebSocket心跳保活? 你有没有遇到过这样...
Qwen3-32B部署教程里Clawdbot网关支持模型版本灰度发布与AB测试的操作流程是什么?

Qwen3-32B部署教程里Clawdbot网关支持模型版本灰度发布与AB测试的操作流程是什么?

Qwen3-32B部署教程:Clawdbot网关支持模型版本灰度发布与AB测试的操作流程 Qwen3-32B作...
ClawdBot政务应用中公文格式保持、政策术语库与多级审校流程集成该如何实现?

ClawdBot政务应用中公文格式保持、政策术语库与多级审校流程集成该如何实现?

ClawdBot政务应用中公文格式保持、政策术语库与多级审校流程集成该如何实现? 在政务办公数字化转型的浪潮中...
Clawdbot+Qwen3-32B惊艳效果里支持工具调用Tool Calling的真实API集成案例如何落地?

Clawdbot+Qwen3-32B惊艳效果里支持工具调用Tool Calling的真实API集成案例如何落地?

Clawdbot+Qwen3-32B惊艳效果里支持工具调用Tool Calling的真实API集成案例如何落地...
ClawdBot测试用例编写pytest脚本自动化验证多语言翻译正确性的方法有哪些?

ClawdBot测试用例编写pytest脚本自动化验证多语言翻译正确性的方法有哪些?

ClawdBot测试用例编写pytest脚本自动化验证多语言翻译正确性的方法有哪些? 在ClawdBot与Mo...
Clawdbot+Qwen3-32B实战案例如何构建自主可控的Web大模型对话系统?

Clawdbot+Qwen3-32B实战案例如何构建自主可控的Web大模型对话系统?

Clawdbot+Qwen3-32B实战案例:如何构建自主可控的Web大模型对话系统? 在AI落地越来越快的今...
Clawdbot生产环境部署中Qwen3:32B代理网关的Token安全策略与访问审计配置有哪些要点?

Clawdbot生产环境部署中Qwen3:32B代理网关的Token安全策略与访问审计配置有哪些要点?

Clawdbot生产环境部署中Qwen3:32B代理网关的Token安全策略与访问审计配置有哪些要点? 在Cl...
Qwen3-32B开源大模型部署时Clawdbot支持OpenTelemetry分布式追踪配置该如何开启?

Qwen3-32B开源大模型部署时Clawdbot支持OpenTelemetry分布式追踪配置该如何开启?

Qwen3-32B开源大模型部署时Clawdbot支持OpenTelemetry分布式追踪配置该如何开启? Q...
ClawdBot监控集成使用Prometheus+Grafana监控vLLM GPU利用率与QPS的效果如何?

ClawdBot监控集成使用Prometheus+Grafana监控vLLM GPU利用率与QPS的效果如何?

ClawdBot监控集成:Prometheus+Grafana监控vLLM GPU利用率与QPS的效果如何? ...
Clawdbot+Qwen3:32B多场景落地在教育问答、技术文档助手、内部客服中的应用如何?

Clawdbot+Qwen3:32B多场景落地在教育问答、技术文档助手、内部客服中的应用如何?

Clawdbot+Qwen3:32B多场景落地在教育问答、技术文档助手、内部客服中的应用如何? 在AI落地越来...
Clawdbot+Qwen3:32B部署教程中Web网关SSL双向认证安全加固的配置方法是什么?

Clawdbot+Qwen3:32B部署教程中Web网关SSL双向认证安全加固的配置方法是什么?

Clawdbot+Qwen3:32B部署教程:Web网关SSL双向认证安全加固配置方法详解 在本地部署Claw...