我们将使用Docker Compose来定义和运行ELK堆栈 。我们需要创建一个docker-compose.yml文件来指定ELK容器的配置 。
文章插图
在本文中,我们将探讨如何在Docker环境下搭建ELK(Elasticsearch,Logstash和Kibana)堆栈 。ELK是一种流行的开源日志分析平台,可用于实时搜索,分析和可视化数据 。使用Docker可以轻松地构建,部署和管理ELK堆栈 。
1、准备工作在开始之前,我们需要安装Docker和Docker Compose 。如果您还没有安装它们,请参阅Docker官方网站的文档以获取有关安装的说明 。
2、创建Docker Compose文件我们将使用Docker Compose来定义和运行ELK堆栈 。我们需要创建一个docker-compose.yml文件来指定ELK容器的配置 。以下是一个基本的docker-compose.yml文件,我们将在其中指定ELK堆栈的三个组件 。
version: '3'services:elasticsearch:image: docker.elastic.co/elasticsearch/elasticsearch:7.10.2container_name: elasticsearchenvironment:- node.name=elasticsearch- discovery.type=single-nodeports:- 9200:9200.NETworks:- elklogstash:image: docker.elastic.co/logstash/logstash:7.10.2container_name: logstashvolumes:- ./logstash/config:/usr/share/logstash/pipeline/command: logstash -f /usr/share/logstash/pipeline/logstash.confenvironment:- pipeline.batch.size=500- pipeline.workers=4ports:- 5000:5000networks:- elkkibana:image: docker.elastic.co/kibana/kibana:7.10.2container_name: kibanaports:- 5601:5601networks:- elknetworks:elk:
让我们一步一步地看看每个服务的配置是什么意思 。Elasticsearch服务我们将使用Elasticsearch作为我们的日志存储和搜索引擎 。在这个服务中,我们使用Elasticsearch的官方Docker镜像 。我们将该容器命名为elasticsearch,并将其映射到主机的9200端口上 。
我们还在环境变量中设置了一些参数,以指定节点名称和单节点发现 。这将在我们运行多个节点的情况下很有用 。
最后,我们将该服务连接到名为elk的网络 。
Logstash服务Logstash是一个数据处理管道,它可以从各种来源接收数据,并将其转换为Elasticsearch可读取的格式 。在此服务中,我们将使用Elasticsearch的官方Docker镜像 。
我们将该容器命名为logstash,并将其映射到主机的5000端口上 。我们还将容器中的配置文件夹挂载到主机上的一个文件夹中 。这将允许我们在容器外部编辑Logstash配置文件 。
我们在环境变量中还设置了一些参数,例如批量大小和工作线程数 。这些参数将有助于优化Logstash的性能 。
最后,我们将该服务连接到名为elk的网络 。
Kibana服务Kibana是一个用于可视化和分析日志数据的Web界面 。在此服务中,我们将使用Elasticsearch的官方Docker镜像 。
我们将该容器命名为kibana,并将其映射到主机的5601端口上 。这将允许我们通过Web浏览器访问Kibana界面 。
最后,我们将该服务连接到名为elk的网络 。
网络配置我们使用名为elk的自定义网络来连接我们的ELK容器 。这将允许我们容易地进行通信,并防止容器暴露到公共网络中 。
3、创建Logstash配置文件在Logstash服务中,我们将使用一个配置文件来指定从哪里接收日志数据,如何处理它们,并将其发送到Elasticsearch中 。以下是一个基本的logstash.conf文件的示例:
input {tcp {port => 5000codec => json}}output {elasticsearch {hosts => ["elasticsearch:9200"]index => "logstash-%{+YYYY.MM.dd}"}}
【Docker环境下,如何搭建ELK堆栈?详细教程和使用分析】在此配置文件中,我们使用TCP输入插件来接收来自端口5000的日志数据 。我们还指定了一个JSON编解码器,以便Logstash可以正确地解析接收到的JSON格式数据 。然后,我们使用Elasticsearch输出插件将处理后的数据发送到Elasticsearch 。我们指定了Elasticsearch的主机地址,并将日志索引的名称设置为logstash-YYYY.MM.dd 。这将允许我们按日期存储和搜索日志数据 。
4、构建和运行ELK堆栈我们已经准备好了docker-compose.yml和logstash.conf文件,现在我们可以构建和运行ELK堆栈 。在命令行中,切换到包含这两个文件的目录,然后运行以下命令:
docker-compose up
这将构建和启动ELK堆栈中的所有容器 。在第一次运行时,Docker将从Docker Hub下载所需的镜像 。这可能需要一些时间,具体取决于您的网络速度 。一旦所有容器都成功启动,您可以在Web浏览器中访问Kibana界面 。只需在浏览器中输入http://localhost:5601即可 。
5、发送日志数据到ELK堆栈现在我们已经成功搭建了ELK堆栈,接下来我们需要将日志数据发送到它 。
推荐阅读
- 微软集成开发环境Visual Studio 2022 17.5正式发布
- 断缴社保影响大,不到万不得已的情况下,尽量不要这样做!
- 甜蜜蜜歌曲原唱下载 甜蜜蜜歌曲
- 金山毒霸手机版软件下载?金山毒霸手机版哪去了?官网怎么没有了?
- 来电铃声免费下载 手机搞笑铃声下载
- 吹裙子下截 美女吹裙子小游戏
- 俞白眉|票房低就玩道德绑架?《中国乒乓》最后一块遮羞布被俞白眉扯下!
- 超级记忆力训练下载 超级记忆力训练法
- 手部模拟器中文版下载~~手部模拟器怎么切换腿?
- 苹果核战记1高清在线?苹果核战记度云资源,只要资源不要告诉我怎么下。?