一:logstash介绍
Logstash在elk系统中为数据存储,报表查询和日志解析创建了一个功能强大的管道链。Logstash提供了多种多样的 input,filters,codecs和output组件,logstash由以下三部分组成
 
input数据输入端,可以接收来自任何地方的源数据
1:file:从文件中读取
2:syslog:监听在514端口的系统日志信息,并解析成RFC3164格式
3:redis:从redis-server list 中获取
4:beat:接收来自Filebeat的事件
 
filter数据中转层,主要进行格式处理,数据类型转换、数据过滤、字段添加,修改等,主要用做过滤
1:grok: 通过正则解析和结构化任何文本。Grok 目前是logstash最好的方式对非结构化日志数据解析成结构化和可查询化。logstash内置了120个匹配模式,满足大部分需求。
2:mutate: 在事件字段执行一般的转换。可以重命名、删除、替换和修改事件字段。
3:drop: 完全丢弃事件,如debug事件。
4:clone: 复制事件,可能添加或者删除字段。
5:geoip: 添加有关IP地址地理位置信息。
 
output是logstash工作的最后一个阶段,负责将数据输出到指定位置,兼容大多数应用
1:elasticsearch: 发送事件数据到 Elasticsearch,便于查询,分析,绘图。
2:file: 将事件数据写入到磁盘文件上。
3:mongodb:将事件数据发送至高性能NoSQL mongodb,便于永久存储,查询,分析,大数据分片。
4:redis:将数据发送至redis-server,常用于中间层暂时缓存。
5:graphite: 发送事件数据到graphite
6:statsd: 发送事件数据到 statsd。
 
二:logstash启动方式
logstash分别由-e和-f两种启动方式
-e:用来快速测试不用修改配置文件,一般用来调试!
-f :指定配置文件启动,需要把基本配置写入文件中启动,这里比较内容比较复杂,涉及到如何采集、过滤以及输出
 
1:下面进行-e启动方式演示
[root@localhost ~]# logstash -e  "input {stdin {} } output {stdout {}  }"
hell ghs     //输入字符信息
 
Sending Logstash's logs to /usr/local/elk/logstash/logs which is now configured via log4j2.properties
The stdin plugin is now waiting for input:
[2017-11-24T19:15:06,655][INFO ][logstash.agent           ] Pipelines running {:count=>1, :pipelines=>["main"]}
2017-11-24T11:15:06.704Z localhost.localdomain hell ghs     //这里显示的上面输入的字符串
 
##stdin {} :表示标准输入,stdout {} :表示标准输出
 
2:-f 配置文件启动方式
编辑一个配置文件,指定输入输出
[root@localhost ~]# vim ceshi.conf
input {
   stdin {}
 }
output{
    stdout {
        codec => rubydebug {}
}
}
 
## codec
 
执行配置文件
[root@localhost ~]# logstash -f test.conf
hell ghs          //输入字符串
{
      "@version" => "1",
          "host" => "localhost.localdomain",
    "@timestamp" => 2017-11-24T12:16:43.086Z,
       "message" => "hell ghs"
}
 
 
1:编写一个过滤系统日志的配置文件
[root@localhost ~]# vim messages.conf
input {
     file{
        path => "/var/log/messages"
        type => "syslog"
      }
 }
output {
    stdout { codec => rubydebug }
}
##path指定的是过滤日志的文件路径,type指定类型,自定义,主要做区分!
 
2:执行文件,显示过滤的日志结果
[root@localhost ~]# logstash -f messages.conf
{
      "@version" => "1",
          "host" => "localhost.localdomain",
          "path" => "/var/log/messages",
    "@timestamp" => 2017-11-24T11:01:02.189Z,
       "message" => "Nov 24 19:01:01 localhost systemd: Starting Session 11 of user root.",
          "type" => "syslog"
}
 
三:输出到elasticsearch,在kibana形成WEB图形方式
1:编写一个配置文件,让日志输出到elasticsearch通过kibana生成WEB图形!
[root@localhost ~]# vim  test.conf    ##配置文件名字自定义
input {
 file {
       path => "/var/log/messages"     //定义日志文件路径
       type => "test"                             //定义日志类型
       stat_interval => 1
       start_position => "beginning"
}
}
 
output{
     elasticsearch {
        hosts => ["192.168.1.200:9200"]       //定义需要输出到elasticsearch的ip和端口
        index => "test-%{+YYYY.MM.dd}"    //定义索引的名字,名字为test
}
}
 
2:执行配置文件
[root@localhost ~]# logstash -f test.conf -d
执行之后,在kibana的WEB页面Index pattern添加索引的名称,就可以Discover会形成以下日志输出的信息

ELK-logstash基本用法的更多相关文章

  1. ELK——Logstash 2.2 date 插件【翻译+实践】

    官网地址 本文内容 语法 测试数据 可配置选项 参考资料 date 插件是日期插件,这个插件,常用而重要. 如果不用 date 插件,那么 Logstash 将处理时间作为时间戳.时间戳字段是 Log ...

  2. ELK logstash 处理MySQL慢查询日志(初步)

    写在前面:在做ELK logstash 处理MySQL慢查询日志的时候出现的问题: 1.测试数据库没有慢日志,所以没有日志信息,导致 IP:9200/_plugin/head/界面异常(忽然出现日志数 ...

  3. ELK logstash 启动慢的解决方法

    最近开始测试部署ELK, 在部署logstash的时候出现一个故障: logstash在第一次安装完成以后启动正常, 但是之后启动时间越来越长, 5分钟以上甚至10多分钟.以至于怀疑程序错误, 在重装 ...

  4. 【ELK】【docker】【elasticsearch】2.使用elasticSearch+kibana+logstash+ik分词器+pinyin分词器+繁简体转化分词器 6.5.4 启动 ELK+logstash概念描述

    官网地址:https://www.elastic.co/guide/en/elasticsearch/reference/current/docker.html#docker-cli-run-prod ...

  5. ELK logstash邮件报警

    这个方法有一个问题就是我这边不能给我们公司的邮箱发邮件.还有就是我们有两个邮箱一个是腾讯企业邮箱,还有一个就是我们的集团邮箱 使用下面的这个方法是不能给我们的集团邮箱发邮件的.第二个问题就是这个方法给 ...

  6. ELK(Logstash+Elasticsearch+Kibana)的原理和详细搭建

    一. Elastic Stack Elastic Stack是ELK的官方称呼,网址:https://www.elastic.co/cn/products ,其作用是“构建在开源基础之上, Elast ...

  7. [elk]logstash的最佳实战-项目实战

    重点参考: http://blog.csdn.net/qq1032355091/article/details/52953837 不得不说这是一个伟大的项目实战,是正式踏入logstash门槛的捷径 ...

  8. [elk]logstash grok原理

    logstash语法 http://www.ttlsa.com/elk/elk-logstash-configuration-syntax/ https://www.elastic.co/guide/ ...

  9. [elk]logstash&filebeat常用语句

    filebeat安装dashboard 参考: https://www.elastic.co/guide/en/beats/filebeat/current/filebeat-getting-star ...

  10. ELK——Logstash 2.2 mutate 插件【翻译+实践】

    官网地址 本文内容 语法 测试数据 可选配置项 mutate 插件可以在字段上执行变换,包括重命名.删除.替换和修改.这个插件相当常用. 比如: 你已经根据 Grok 表达式将 Tomcat 日志的内 ...

随机推荐

  1. nyoj 366 D的小L (全排列)

    D的小L 时间限制:4000 ms  |  内存限制:65535 KB 难度:2   描述       一天TC的匡匡找ACM的小L玩三国杀,但是这会小L忙着哩,不想和匡匡玩但又怕匡匡生气,这时小L给 ...

  2. python:collections模块

    Counter类 介绍:A counter tool is provided to support convenient and rapid tallies 构造:class collections. ...

  3. mysql基础之约束

    约束的目的: 1.约束保证数据的完整性和一致性. 2.约束分为表级约束 和 列级 约束.(针对约束字段的数目的多少来确定的) 3.约束类型包括 not null (非空约束) primary key( ...

  4. 记录工作遇到的死锁问题(Lock wait timeout exceeded; try restarting transaction)

    1.问题背景 刚来新公司不久,对业务还不太熟悉,所以领导先安排我维护原有系统.大概介绍下项目背景,项目分为核心业务部分在项目A中,与第三方交互的业务在项目B中,前端发起请求调用A项目接口,并在A项目中 ...

  5. 0MQ宗旨

    先来看<Implementing distributed applications with 0MQ and some other bad guys...>.用0MQ去实现分布应用,或者用 ...

  6. opencv 4 图像处理(漫水填充,图像金字塔与图片尺寸缩放,阈(yu)值化)

    漫水填充 实现漫水填充算法:floodFill函数 简单调用范例 #include <opencv2/opencv.hpp> #include <opencv2/imgproc/im ...

  7. Maven 无法下载依赖包的解决方法---三步dao!!!

    版权声明:本文为博主原创文章,转载请附上原文出处链接和本声明. 本文链接:https://www.cnblogs.com/WLCYSYS/p/11932157.html maven 自动下载依赖包出现 ...

  8. ubuntu 16.04 和 windows 10系统安装mysql 允许远程访问 | mysql user guide on ubuntu 16.04 and windows 10

    本文首发于个人博客https://kezunlin.me/post/36e618e7/,欢迎阅读! mysql user guide on ubuntu 16.04 and windows 10 Pa ...

  9. 扛把子组20191121-10 Scrum立会报告+燃尽图 06

    此作业的要求参见http://edu.cnblogs.com/campus/nenu/2019fall/homework/10070 一.小组情况: 队名:扛把子 组长:孙晓宇 组员:刘信鹏 韩昊 宋 ...

  10. 初探three.js光源

    上一节我们简单的说了一下THREE中必要的元素.今天我们深入探讨一下各种THREE的光源. 一 基础光源 基础光源有4种1.THREE.AmbientLight(环境光源)2.THREE.PointL ...