docker 安装 logstash

文章目录

Logstash基本语法组成

什么是Logstash

logstash是一个数据抽取工具,将数据从一个地方转移到另一个地方。如hadoop生态圈的sqoop等。下载地址:https://www.elastic.co/cn/downloads/logstash

logstash之所以功能强大和流行,还与其丰富的过滤器插件是分不开的,过滤器提供的并不单单是过滤的功能,还可以对进入过滤器的原始数据进行复杂的逻辑处理,甚至添加独特的事件到后续流程中。

Logstash配置文件有如下三部分组成,其中input、output部分是必须配置,filter部分是可选配置,而filter就是过滤器插件,可以在这部分实现各种日志过滤功能。

配置文件:

复制代码
input {
    #输入插件
}
filter {
    #过滤匹配插件
}
output {
    #输出插件
}

拉去镜像

因为我这里的es是7.12.1的,所以我logstash我也拉取同样版本,也自己去看版本对照表https://www.elastic.co/cn/support/matrix#matrix_compatibility

bash 复制代码
docker pull logstash:7.12.1

启动镜像

bash 复制代码
docker run \
--name logstash \
--restart=always \
-p 5044:5044 \
-p 9600:9600 \
-v logstash-config:/usr/share/logstash/config \
-v logstash-data:/usr/share/logstash/data \
-v logstash-pipeline:/usr/share/logstash/pipeline \
-d logstash:7.12.1

Logstash输入插件(input)

https://www.elastic.co/guide/en/logstash/current/input-plugins.html

1、标准输入(Stdin)

复制代码
input{
    stdin{
       
    }
}
output {
    stdout{
        codec=>rubydebug    
    }
}

2、读取文件(File)

logstash使用一个名为filewatch的ruby gem库来监听文件变化,并通过一个叫.sincedb的数据库文件来记录被监听的日志文件的读取进度(时间戳),这个sincedb数据文件的默认路径在 <path.data>/plugins/inputs/file下面,文件名类似于.sincedb_123456,而<path.data>表示logstash插件存储目录,默认是LOGSTASH_HOME/data。

复制代码
input {
    file {
        path => ["/var/*/*"]
        start_position => "beginning"
    }
}
output {
    stdout{
        codec=>rubydebug    
    }
}

默认情况下,logstash会从文件的结束位置开始读取数据,也就是说logstash进程会以类似tail -f命令的形式逐行获取数据。

相关推荐
java_logo2 小时前
n8n Docker 部署手册
运维·docker·容器
安安csdn5 小时前
k8s存储juicefs简介
docker·容器·kubernetes
筑梦之路6 小时前
etcd节点噶了导致的k8s集群瘫痪处理参考——筑梦之路
docker·kubernetes·etcd
风清再凯9 小时前
03-docker存储与网络
网络·docker·容器
正怒月神11 小时前
docker-compose 启动 elk
elk·docker·容器
hello_2501 天前
动手模拟docker网络-bridge模式
网络·docker·桥接模式
小醉你真好1 天前
15、Docker Compose 安装ELK + Filebeat单机版
elk·docker·jenkins
Gss7771 天前
Docker 公有仓库使用、Docker 私有仓库(Registry)使用总结
docker·容器
暴富奥利奥1 天前
完成docker方式的ros环境配置
linux·学习·docker·容器
海海思思1 天前
解决Docker "exec format error":架构不匹配问题分析
docker·容器