logstash的使用注意事项

说明:本文为作者原创,欢迎大家转载,不过记得声明出处哦~

前言

Logstash的相关文章收录在博客的ELK分类中,相关的内容欢迎大家前往《ELK》进行查阅和交流学习。

 

正文

在使用logstash的过程中,错误的配置将导致无法收集和输出日志。
现在网络上并不容易找到关于logstash的中文文档,这里我提供一个可以参考的在线文档:
https://doc.yonyoucloud.com/doc/logstash-best-practice-cn/index.html

logstash的配置文件默认存放于config目录(也可以自定义,因为在启动logstash时是通过命令参数的方式来主动加载配置文件的,如:“logstash -f ../config/logstash.conf”)。
以logstash.conf为例,下面给出一个基本配置的内容:

# This is a comment. You should use comments to describe
# parts of your configuration.

input {
    stdin {
        codec => plain{
            charset => "GBK"
        }
    }
    file {
#       path =>"C:\Users\Administrator\Desktop\EKL\logs\*.log"
#上一行被注释的配置是错误的,path使用反斜杠“\”将无法被识别,无论是windows还是linux系统都应使用斜杠“/”来划分路径,如下一行的配置
        path =>"C:/Users/Administrator/Desktop/EKL/logs/*.log"
    }
}

#filter {
#
#}

output {
    stdout {
        codec => json_lines
    }
    elasticsearch {
        hosts => ["localhost:9200"]
#       index => "logstash-%{+YYYY.MM.dd}"
        index => "test"
    }
}

在上面的配置代码中,我们需要谨记,配置文件中必须含有一个input和一个output配置,里面的内容可以不写,但是代码结构需要有。
在input配置中,stdin是标准输入的插件,只有设置了stdin,才能在logstash启动后的终端窗口继续输入字符,否则,logstash启动完毕后,终端窗口将无法输入字符。输入字符后点击回车键,将会将当前所输入内容作为一次输入结果发送给输出终端(当然需要设置好相对应的输出终端作为接收或存储数据端)。
file结构体作为输入端读取文件的插件,其中的path的配置尤其需要注意。在windows系统中,文件目录是以反斜杠“\”来分段的,但在logstash配置文件中,“\”将无法被识别,因此需要把URL中的“\”更改为“/”才能生效。

在output配置中,elasticsearch作为与Elasticsearch服务连接的插件,通过hosts配置Elasticsearch的连接地址,index则指定索引(不设置index的情况下,将自动生成一个“logstash-%{+YYYY.MM.dd}”格式的索引进行数据输出存储)。
同时,output中也可以配置file结构体来将数据输出到文件,可以使用sprintf-format格式来自定义带日期命名的URL,如:“path => "/path/to/%{+yyyy/MM/dd/HH}/%{host}.log"”
 

 

-------------------------------------
作者:TGY——一个IT男的画意诗情
来源:优快云 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值