您当前的位置:首页 > 电脑百科 > 程序开发 > 容器

Docker环境下,如何搭建ELK堆栈?详细教程和使用分析

时间:2023-02-23 13:08:14  来源:51CTO  作者:Java编程世界
我们将使用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.2
    contAIner_name: elasticsearch
    environment:
      - node.name=elasticsearch
      - discovery.type=single-node
    ports:
      - 9200:9200
   .NETworks:
      - elk

  logstash:
    image: docker.elastic.co/logstash/logstash:7.10.2
    container_name: logstash
    volumes:
      - ./logstash/config:/usr/share/logstash/pipeline/
    command: logstash -f /usr/share/logstash/pipeline/logstash.conf
    environment:
      - pipeline.batch.size=500
      - pipeline.workers=4
    ports:
      - 5000:5000
    networks:
      - elk

  kibana:
    image: docker.elastic.co/kibana/kibana:7.10.2
    container_name: kibana
    ports:
      - 5601:5601
    networks:
      - elk

networks:
  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 => 5000
    codec => json
  }
}

output {
  elasticsearch {
    hosts => ["elasticsearch:9200"]
    index => "logstash-%{+YYYY.MM.dd}"
  }
}

在此配置文件中,我们使用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堆栈,接下来我们需要将日志数据发送到它。

在Logstash服务中,我们已经设置了一个TCP输入插件,它将监听来自5000端口的数据。因此,我们可以将日志数据发送到该端口,Log

stash将自动将其解析和发送到Elasticsearch中。

以下是一些将日志数据发送到ELK堆栈的示例方法:

使用nc命令发送日志数据

linux系统上,您可以使用nc(也称为netcat)命令将日志数据发送到Logstash服务。

首先,运行以下命令在主机上安装nc命令:

sudo apt-get install netcat

然后,使用以下命令发送一些日志数据:

echo '{"message": "Hello, World!"}' | nc localhost 5000

这将向Logstash服务发送一条JSON格式的日志消息。

使用Python/ target=_blank class=infotextkey>Python发送日志数据

您还可以使用Python编写一个简单的脚本来将日志数据发送到Logstash服务。以下是一个示例脚本:

 
import socket
import json

logstash_host = "localhost"
logstash_port = 5000

log_data = {"message": "Hello, World!"}

log_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
log_socket.connect((logstash_host, logstash_port))
log_socket.send(json.dumps(log_data).encode('utf-8'))
log_socket.close()

这个脚本使用Python的socket模块连接到Logstash服务,并将JSON格式的日志数据发送到5000端口。

6、在Kibana中查看日志数据

现在我们已经成功发送了一些日志数据到ELK堆栈,接下来我们需要在Kibana中查看它们。

首先,打开Web浏览器并访问http://localhost:5601。这将打开Kibana界面。

在Kibana界面中,选择“Discover”选项卡。这将显示所有索引的日志数据。

在默认情况下,Kibana将显示最近15分钟的日志数据。您可以使用时间范围选择器来选择不同的时间范围。

在“Discover”选项卡中,您还可以使用各种过滤器和查询来过滤和搜索日志数据。

7、总结

通过使用Docker和ELK堆栈,我们可以快速、轻松地搭建一个功能强大的日志分析平台。

在本文中,我们学习了如何创建一个Docker Compose文件来定义ELK堆栈中的各种服务,并了解了如何使用Logstash配置文件将日志数据发送到Elasticsearch中。

我们还学习了如何使用Kibana界面来可视化和分析日志数据,并了解了如何使用各种过滤器和查询来过滤和搜索日志数据。

希望这篇文章能够帮助您快速入门ELK堆栈和日志分析领域。

8、参考资料

以下是本文中使用的一些参考资料:

  • Docker官方文档:https://docs.docker.com/
  • ELK堆栈官方文档:https://www.elastic.co/guide/index.html
  • Docker Compose官方文档:https://docs.docker.com/compose/
  • Logstash配置指南:https://www.elastic.co/guide/en/logstash/current/configuration.html
  • Kibana官方文档:https://www.elastic.co/guide/en/kibana/current/index.html

9、结论

通过本文的学习,我们了解了如何使用Docker和ELK堆栈来构建一个强大的日志分析平台。

ELK堆栈由三个核心组件组成:Elasticsearch、Logstash和Kibana。Elasticsearch用于存储和索引日志数据,Logstash用于解析和发送日志数据,Kibana用于可视化和分析日志数据。

我们使用Docker Compose文件来定义ELK堆栈中的各种服务,并使用Logstash配置文件将日志数据发送到Elasticsearch中。

最后,我们使用Kibana界面来可视化和分析日志数据,并学习了如何使用各种过滤器和查询来过滤和搜索日志数据。

希望这篇文章能够帮助您入门ELK堆栈和日志分析领域。



Tags:Docker   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
Docker 和传统虚拟机有什么区别?
我有一个程序员朋友,他每年情人节都要送女朋友一台服务器。他说:“谁不想在过节当天收到一台 4核8g 的服务器呢?”“万一对方不要,我还能留着自己用。” 给他一次过节的机会,他能...【详细内容】
2024-03-26  Search: Docker  点击:(12)  评论:(0)  加入收藏
掌握Docker网络驱动程序:优化容器通信
Docker为在容器内包装、交付和运行应用程序提供了一个强大的平台,从而彻底改变了容器化。网络是容器化的重要组成部分,Docker提供了各种网络驱动程序来支持容器之间的通信以...【详细内容】
2024-03-22  Search: Docker  点击:(11)  评论:(0)  加入收藏
如何基于Docker镜像逆向生成Dockerfile
引言你是否曾经遇到过一个想要使用的 Docker 镜像,但却无法修改以适应你的特定需求?或者你可能发现了一个喜欢的 Docker 镜像,但想要了解它是如何构建的?在这两种情况下,将 Docke...【详细内容】
2024-03-07  Search: Docker  点击:(23)  评论:(0)  加入收藏
Docker与Docker Compose入门:释放你应用部署的威力
今天给大家介绍一项强大而有趣的技能,那就是使用 Docker 和 Docker Compose 来释放你的应用部署的威力!无论你是一名开发人员还是系统管理员,掌握这个技能都将为你的工作带来巨...【详细内容】
2024-01-17  Search: Docker  点击:(66)  评论:(0)  加入收藏
Docker镜像与容器的交互及在容器内部执行代码的原理与实践
Docker作为一种流行的容器技术,已经成为现代应用程序开发和部署的重要工具。在Docker中,镜像是构建和运行容器的基础,而容器则是基于镜像创建的可执行实例。Docker镜像与容器的...【详细内容】
2024-01-10  Search: Docker  点击:(78)  评论:(0)  加入收藏
如何在 Ubuntu 上安装 Docker
使用 Docker 意味着开启一个新的计算领域,但如果你刚刚开始使用 Docker,安装可能看起来是一项艰巨的任务。在 Ubuntu 上安装 Docker 有两种推荐的方法: 从 Ubuntu 的仓库安装 D...【详细内容】
2024-01-04  Search: Docker  点击:(124)  评论:(0)  加入收藏
七个杀手级Docker命令
Docker是一个容器化平台,通过操作系统级别的虚拟化技术,实现软件的打包和容器化运行。借助Docker,开发人员能够将应用程序以容器的形式进行部署,但在此之前需要构建Docker镜像。...【详细内容】
2023-12-22  Search: Docker  点击:(141)  评论:(0)  加入收藏
Docker容器如何打包应用程序的代码和依赖项?
Docker容器通过将应用程序的代码和所有依赖项打包到一个独立的软件包中,实现了应用程序的快速部署和移植。下面是Docker容器实现这一目标的步骤:打包应用程序:使用Docker工具将...【详细内容】
2023-12-20  Search: Docker  点击:(130)  评论:(0)  加入收藏
DBA视角:把数据库放入Docker是一个馊主意
对于无状态的应用服务而言,容器是一个相当完美的开发运维解决方案。然而对于带持久状态的服务 —— 数据库来说,事情就没有那么简单了。生产环境的数据库是否应当放...【详细内容】
2023-12-18  Search: Docker  点击:(200)  评论:(0)  加入收藏
Docker容器编排技术解析
一、容器编排介绍容器编排是现代云原生应用管理的核心,它涉及在大规模的环境中自动化部署、管理、扩展和网络配置容器。随着微服务架构的兴起和应用的复杂性增加,容器编排成为...【详细内容】
2023-12-15  Search: Docker  点击:(249)  评论:(0)  加入收藏
▌简易百科推荐
Docker 和传统虚拟机有什么区别?
我有一个程序员朋友,他每年情人节都要送女朋友一台服务器。他说:“谁不想在过节当天收到一台 4核8g 的服务器呢?”“万一对方不要,我还能留着自己用。” 给他一次过节的机会,他能...【详细内容】
2024-03-26  小白debug  微信公众号  Tags:Docker   点击:(12)  评论:(0)  加入收藏
掌握Docker网络驱动程序:优化容器通信
Docker为在容器内包装、交付和运行应用程序提供了一个强大的平台,从而彻底改变了容器化。网络是容器化的重要组成部分,Docker提供了各种网络驱动程序来支持容器之间的通信以...【详细内容】
2024-03-22    51CTO  Tags:Docker   点击:(11)  评论:(0)  加入收藏
Containerd容器管理
Nginx 指定容器名称 使用 ctr container create 命令创建容器后,容器并没有处于运行状态,其只是一个静态的容器。容器基本操作容器基本操作主要是 ctr image 命令,查看命令帮...【详细内容】
2024-03-20  云原生运维圈  微信公众号  Tags:容器   点击:(13)  评论:(0)  加入收藏
如何基于Docker镜像逆向生成Dockerfile
引言你是否曾经遇到过一个想要使用的 Docker 镜像,但却无法修改以适应你的特定需求?或者你可能发现了一个喜欢的 Docker 镜像,但想要了解它是如何构建的?在这两种情况下,将 Docke...【详细内容】
2024-03-07  云原生运维圈  微信公众号  Tags:Docker   点击:(23)  评论:(0)  加入收藏
Kubernetes是什么?主要特点是什么?
Kubernetes是什么?Kubernetes,也称为K8s,是一个开源的容器编排系统,由Google首次开发和维护。它允许容器化的应用程序在集群中自动部署、扩展和管理。Kubernetes提供了一种容器...【详细内容】
2024-02-01    简易百科  Tags:Kubernetes   点击:(160)  评论:(0)  加入收藏
我们一起聊聊容器资源自愈
在企业实际在使用容器这类资源的时候,除了技术本身,要考虑的其他问题也会很多。企业管理的容器有千千万万,出于效率考虑,对于有特殊需求的容器如何进行批量创建和管理呢,这就需要...【详细内容】
2024-01-30  匠心独运维妙维效  微信公众号  Tags:容器   点击:(47)  评论:(0)  加入收藏
Docker与Docker Compose入门:释放你应用部署的威力
今天给大家介绍一项强大而有趣的技能,那就是使用 Docker 和 Docker Compose 来释放你的应用部署的威力!无论你是一名开发人员还是系统管理员,掌握这个技能都将为你的工作带来巨...【详细内容】
2024-01-17  waynblog  微信公众号  Tags:Docker   点击:(66)  评论:(0)  加入收藏
Docker镜像与容器的交互及在容器内部执行代码的原理与实践
Docker作为一种流行的容器技术,已经成为现代应用程序开发和部署的重要工具。在Docker中,镜像是构建和运行容器的基础,而容器则是基于镜像创建的可执行实例。Docker镜像与容器的...【详细内容】
2024-01-10  编程技术汇  今日头条  Tags:Docker   点击:(78)  评论:(0)  加入收藏
如何在 Ubuntu 上安装 Docker
使用 Docker 意味着开启一个新的计算领域,但如果你刚刚开始使用 Docker,安装可能看起来是一项艰巨的任务。在 Ubuntu 上安装 Docker 有两种推荐的方法: 从 Ubuntu 的仓库安装 D...【详细内容】
2024-01-04    Linux中国  Tags:Docker   点击:(124)  评论:(0)  加入收藏
从Kubernetes的探针到DevOps
今天在群里又看有人问如何设置 Kubernetes 的探针,感觉要补充的话太多了,结合我们在一些 DevOps 项目中痛苦的体验,今天一劳永逸的全部说完,此外,也为大家展现一下为什么 DevOps...【详细内容】
2023-12-27  云云众生s  微信公众号  Tags:Kubernetes   点击:(116)  评论:(0)  加入收藏
站内最新
站内热门
站内头条