使用Docker搭建Logstash

使用Docker搭建Logstash

Logstash是一个开源的服务器端数据处理管道,它能够接收来自多个来源的数据,转换数据,然后将数据发送到您指定的目的地。使用Docker搭建Logstash是一个简单、高效的方式。本教程将分别介绍如何通过Docker CLI和Docker Compose来搭建Logstash。

使用Docker CLI搭建Logstash

1. 拉取Logstash镜像

首先,需要从Docker Hub上拉取最新版本的Logstash官方镜像。

bash 复制代码
docker pull docker.elastic.co/logstash/logstash:7.12.1

2. 启动Logstash容器

接下来,使用以下命令启动一个Logstash容器。此命令中包含了多个参数,下面会解释每个参数的作用。

bash 复制代码
docker run -d --name logstash_instance \
  -p 9600:9600 -p 5044:5044 \
  -v /path/to/your/logstash/config/dir:/usr/share/logstash/config \
  -v /path/to/your/logstash/pipeline:/usr/share/logstash/pipeline \
  docker.elastic.co/logstash/logstash:7.12.1
  • -d: 后台运行容器。
  • --name: 指定容器的名称,这里是logstash_instance
  • -p 9600:9600: 将容器的9600端口映射到宿主机的9600端口,用于访问Logstash的监控API。
  • -p 5044:5044: 将容器的5044端口映射到宿主机的5044端口,这是Logstash常用的接收数据的端口。
  • -v /path/to/your/logstash/config/dir:/usr/share/logstash/config: 将宿主机上的Logstash配置目录挂载到容器内的配置目录。
  • -v /path/to/your/logstash/pipeline:/usr/share/logstash/pipeline: 将宿主机上的Logstash管道配置目录挂载到容器内的管道配置目录。

请替换/path/to/your/logstash/config/dir/path/to/your/logstash/pipeline为实际路径。

使用Docker Compose搭建Logstash

1. 创建docker-compose.yml文件

在一个合适的目录下,创建一个名为docker-compose.yml的文件,并填入以下内容:

yaml 复制代码
version: '3.7'
services:
  logstash:
    image: docker.elastic.co/logstash/logstash:7.12.1
    container_name: logstash_instance
    ports:
      - "9600:9600"
      - "5044:5044"
    volumes:
      - /path/to/your/logstash/config/dir:/usr/share/logstash/config
      - /path/to/your/logstash/pipeline:/usr/share/logstash/pipeline

此配置文件定义了一个服务logstash,并设置了与CLI方法相同的参数。

2. 启动服务

docker-compose.yml文件所在的目录下,运行以下命令来启动服务:

bash 复制代码
docker-compose up -d
  • up: 创建并启动容器。
  • -d: 后台运行。

参数说明

  • ports: 端口映射是用来允许外部访问容器内服务的方式。9600端口用于监控API访问,而5044是Logstash的一个常用端口,用于接收数据。
  • volumes: 卷挂载用于持久化和共享数据。这里,我们挂载了配置文件和管道定义,使得对这些文件的更改可以直接反映在容器中运行的Logstash实例上。
相关推荐
人鱼传说1 小时前
docker desktop是一个好东西
运维·docker·容器
小章UPUP2 小时前
Kubernetes (K8s) 与 Podman 的比较
容器·kubernetes·podman
忆~遂愿2 小时前
CANN metadef 核心解析:计算图原型定义、算子元数据抽象与异构系统互操作机制
docker·容器
说实话起个名字真难啊3 小时前
用docker来安装openclaw
docker·ai·容器
恬静的小魔龙3 小时前
【群晖Nas】群晖Nas中实现SVN Server功能、Docker/ContainerManager等
docker·svn·容器
Zfox_4 小时前
CANN Catlass 算子模板库深度解析:高性能 GEMM 融合计算、Cube Unit Tiling 机制与编程范式实践
docker·云原生·容器·eureka
春日见5 小时前
如何创建一个PR
运维·开发语言·windows·git·docker·容器
DARLING Zero two♡5 小时前
告别 Docker 命令行!Portainer+cpolar 让容器管理从局域网走向公网
运维·docker·容器
liu****6 小时前
2.深入浅出理解虚拟化与容器化(含Docker实操全解析)
运维·c++·docker·容器·虚拟化技术
logocode_li7 小时前
OCI/CRI 双标准下:从 dockerd 到 containerd 的 K8s 运行时迭代史
docker·云原生·容器·k8s