Docker下安装ES和kibana详细教程

Docker下安装ES和kibana详细教程

  • 前言
  • 一、前提准备
    • [1.1创建 Docker 网络: 允许两个容器相互通信。](#1.1创建 Docker 网络: 允许两个容器相互通信。)
    • [1.2 创建数据卷 (Volume): 用于持久化 Elasticsearch 的数据。](#1.2 创建数据卷 (Volume): 用于持久化 Elasticsearch 的数据。)
    • [1.3 为了让 Elasticsearch 正常运行,Linux 系统需要调整虚拟内存限制。](#1.3 为了让 Elasticsearch 正常运行,Linux 系统需要调整虚拟内存限制。)
  • 二、启动es和kibana
    • [2.1 ES启动命令如下](#2.1 ES启动命令如下)
    • [2.2 启动kibana](#2.2 启动kibana)
  • 总结

前言

最近工作需要,原来把项目日志数据存入mysql,导致mysql宕机,现在想着试试把日志数据存入es中,减轻mysql压力,以下是本人在测试环境的操作过程。

下面是详细的步骤,包含创建网络、创建卷、运行 ES 和运行 Kibana。


一、前提准备

1.1创建 Docker 网络: 允许两个容器相互通信。

bash 复制代码
docker network create elastic-stack-7

1.2 创建数据卷 (Volume): 用于持久化 Elasticsearch 的数据。

bash 复制代码
docker volume create esdata-7

1.3 为了让 Elasticsearch 正常运行,Linux 系统需要调整虚拟内存限制。

bash 复制代码
# 在宿主机终端执行此命令
sudo sysctl -w vm.max_map_count=262144

二、启动es和kibana

2.1 ES启动命令如下

注意,我用的是7.17.5版本,如果用了8.x以上的版本需要SSL证书认证

bash 复制代码
docker run -d \
--name elasticsearch-7 \
--net elastic-stack-7 \
-p 9200:9200 -p 9300:9300 \
-e "discovery.type=single-node" \
-e "ES_JAVA_OPTS=-Xms1g -Xmx1g" \
-e "xpack.security.enabled=true" \
-e "ELASTIC_PASSWORD=NDpaper@2025" \
-v esdata-7:/usr/share/elasticsearch/data \
docker.elastic.co/elasticsearch/elasticsearch:7.17.15

关键持久化参数:

-v esdata-7:/usr/share/elasticsearch/data: 数据持久化的关键,将数据卷挂载到容器内的数据目录。 这样,即使容器被删除,数据也会保留在 Docker 卷中。

完了docker ps 检查一下,如下,我的已经运行成功了

在浏览器输入ip:9200端口访问一下,如出现如下页面则安装成功了

2.2 启动kibana

  • 前提准备
    Kibana 的版本必须与 ES 版本一致(7.17.15)。在 7.x中,Kibana 连接 ES 同样简单,只需指定 ES 的地址即可。
bash 复制代码
docker run -d \
--name kibana-7 \
--net elastic-stack-7 \
-p 5601:5601 \
-e "ELASTICSEARCH_HOSTS=http://elasticsearch-7:9200" \
-e "ELASTICSEARCH_USERNAME=elastic" \
-e "ELASTICSEARCH_PASSWORD=NDpaper@2025" \
docker.elastic.co/kibana/kibana:7.17.15

参数解释:

ELASTICSEARCH_HOSTS: 在 Docker 网络中,使用 ES 容器的名称 elasticsearch-7 即可。

启动成功

在页面访问:输入你的ip:5601

总结

以上就是ES和kibana的安装过程,希望对读者有帮助。

相关推荐
阿虎儿15 小时前
Docker安装(非sudo用户可用)
docker
洛森唛15 小时前
ElasticSearch查询语句Query String详解:从入门到精通
后端·elasticsearch
洛森唛2 天前
Elasticsearch DSL 查询语法大全:从入门到精通
后端·elasticsearch
fetasty2 天前
rustfs加picgo图床搭建
docker
蝎子莱莱爱打怪2 天前
GitLab CI/CD + Docker Registry + K8s 部署完整实战指南
后端·docker·kubernetes
小p4 天前
docker学习7:docker 容器的通信方式
docker
小p4 天前
docker学习5:提升Dockerfile水平的5个技巧
docker
小p4 天前
docker学习3:docker是怎么实现的?
docker
Elasticsearch4 天前
如何使用 Agent Builder 排查 Kubernetes Pod 重启和 OOMKilled 事件
elasticsearch
Elasticsearch5 天前
通用表达式语言 ( CEL ): CEL 输入如何改进 Elastic Agent 集成中的数据收集
elasticsearch