zoukankan      html  css  js  c++  java
  • Docker部署ELK之部署logstash7.6.0(4)

    前言:

    logstash 和filebeat都具有日志收集功能,filebeat更轻量,占用资源更少,但logstash 具有filter功能,能过滤分析日志。一般结构都是filebeat采集日志,然后发送到消息队列,redis,kafka。然后logstash去获取,利用filter功能过滤分析,然后存储到elasticsearch中

    1. 拉取logstash镜像

    sudo docker pull logstash:7.6.0
    

    2. Docker构建logstash容器

    创建一个logstash容器:
    sudo docker run -it -d -p 5044:5044 -p 5045:5045 --name logstash1 --net mynetwork logstash:7.6.0
    
    把容器的配置文件拷贝出来到宿主机中,进行修改修改
    sudo docker cp logstash1:/usr/share/logstash/config/ /home/xujk/Work/Docker/elasticsearch/logstash
    sudo docker cp logstash1:/usr/share/logstash/pipeline/ /home/xujk/Work/Docker/elasticsearch/logstash
    sudo docker cp logstash1:/usr/share/logstash/logstash-core/lib/jars/ /web/logstash/
    
    创建logstash容器,进行配置文件挂载,方便修改
    sudo docker run -d -p 5044:5044 -p 5045:5045  --privileged=true -v /home/xujk/Work/Docker/elasticsearch/logstash/config/:/usr/share/logstash/config/ -v /home/xujk/Work/Docker/elasticsearch/logstash/pipeline/:/usr/share/logstash/pipeline/ --name=logstash1 logstash:7.6.0
    
    修改配置文件:/config/logstash.yml
    http.host: "0.0.0.0"
    #xpack.monitoring.elasticsearch.hosts: [ "http://elasticsearch:9200" ]
    xpack.monitoring.enabled: true
    xpack.monitoring.elasticsearch.username: logstash_system
    xpack.monitoring.elasticsearch.password: xujingkun
    xpack.monitoring.elasticsearch.hosts: [ "http://192.168.231.132:9200" ]
    

    修改配置文件:/pipeline/logstash.conf
    input {
     beats {
       port => 5044
      }
    }
    filter {
      dissect {
        mapping => { "message" => "[%{Time}] %{LogLevel} %{message}" }
      }
    }
    output {
      elasticsearch {
                     hosts => "192.168.231.132:9200"
                     index => "xujktest_log"
                     timeout => 300
                     user=>"elastic"
                     password=>"xujingkun"
      }
      stdout {
        codec => rubydebug
      }
    }
    

    logstash配置好,上一文中的filebeat修改配置文件,输出到logstash中,详情见上一文
    Logstash使拥过滤插件dissect:
    dissect的应用有一定的局限性:主要适用于每行格式相似且分隔符明确简单的场景
    • 修改logstash.conf文件

    • 日志写入:
        sudo echo '[2020-10-23 09:38:32] Error test logstash!' >> xujk01.log
      
    • 日志分析:

    • 如果像Loglevel,Time这类咱们分解的属性在kibana界面不能做过滤filter的话,需要重新创建IndexPatterns,然后再查看日志

    FAQ&遇到问题:

    logstash同步日志数据,只有一条数据
    解决参考:https://bbs.csdn.net/topics/395110795
    因为 document_id=> “%{[@metadata][_id]}”导致的,去掉或者,设置id自增都可以解决,我们这里把这个节点去掉了

    至此,ELK日志收集实践告一段落!

  • 相关阅读:
    linux 打包 压缩
    HDU 2036 改革春风吹满地
    Windows 7 蓝屏代码大全 & 蓝屏全攻略
    Linux Shell參数扩展(Parameter Expansion)
    android不是内部或外部命令,也不是可执行的程序或批处理文件
    Object类
    抽象类中注意事项
    抽象类和接口的区别
    类接口之间的关系
    接口
  • 原文地址:https://www.cnblogs.com/kunwn/p/14540679.html
Copyright © 2011-2022 走看看