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

相关推荐
weixin_466844 分钟前
K8S-特殊容器
云原生·容器·kubernetes
QT 小鲜肉1 小时前
【Linux命令大全】001.文件管理之git命令(实操篇)
linux·服务器·笔记·git·elasticsearch
半夏知半秋1 小时前
docker常用指令整理
运维·笔记·后端·学习·docker·容器
INFINI Labs2 小时前
Easy-Es 2.1.0-easysearch 版本发布
大数据·elasticsearch·搜索引擎·easysearch·easy-es
lhrimperial3 小时前
Elasticsearch核心技术深度解析
大数据·elasticsearch·搜索引擎
没有bug.的程序员3 小时前
Nacos vs Eureka 服务发现深度对比
jvm·微服务·云原生·容器·eureka·服务发现
记得记得就1514 小时前
docker作业
运维·docker·容器
HaSaKing_7215 小时前
EMQX 多机集群部署完整实践(Docker + 社区版 5.8.8)
运维·docker·容器·emqx
❀͜͡傀儡师6 小时前
Docker部署WebDB数据库开发环境
docker·容器·数据库开发
南山nash6 小时前
企业级docker镜像仓库harbor安装与使用
运维·docker·容器·镜像仓库