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的安装过程,希望对读者有帮助。

相关推荐
我不是8神1 小时前
Docker知识点总结
运维·docker·容器
Wang's Blog1 小时前
Elastic Stack梳理:深度解析Elasticsearch分布式查询机制与相关性算分优化实践
分布式·elasticsearch
yumgpkpm2 小时前
腾讯TBDS和CMP(Cloud Data AI Platform,类Cloudera CDP,如华为鲲鹏 ARM 版)比较的缺陷在哪里?
hive·hadoop·elasticsearch·zookeeper·oracle·kafka·hbase
新手小白*2 小时前
K8S-Deployment 资源对象
云原生·容器·kubernetes
龙月2 小时前
dozzle监控多节点docker容器日志和指标
docker
梁萌2 小时前
微服务任务调度XXL-JOB实战(docker)
docker·微服务·xxl-job·定时任务
喜欢你,还有大家2 小时前
k8s——日志采集方案
云原生·容器·kubernetes
weixin_46682 小时前
Docker 概述与安装
docker·容器·eureka
Elasticsearch2 小时前
Elasticsearch:专用向量数据库很快就会被遗忘,事实上它从未流行过
elasticsearch