博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ELK Stack (2) —— ELK + Redis收集Nginx日志
阅读量:5324 次
发布时间:2019-06-14

本文共 2422 字,大约阅读时间需要 8 分钟。

ELK Stack (2) —— ELK + Redis收集Nginx日志

摘要

使用Elasticsearch、Logstash、Kibana与Redis(作为缓冲区)对Nginx日志进行收集


版本

elasticsearch版本: elasticsearch-2.2.0

logstash版本: logstash-2.2.2

kibana版本: kibana-4.3.1-darwin-x64

jdk版本: jdk1.8.0_65

内容

目标架构

613455-20160223153859115-615487136.png

准备工作

参考以下文章安装好ELK与Redis

以CAS系列中的使用的Nginx负载均衡器为例

ELK配置

  • Nginx

    修改nginx.conf

    log_format logstash '$http_host $server_addr $remote_addr [$time_local] "$request" '              '$request_body $status $body_bytes_sent "$http_referer" "$http_user_agent" '              '$request_time $upstream_response_time';

    613455-20160223153923083-337734227.png

  • Elasticsearch

    修改elasticsearch.yml

    cluster.name: logstash_elasticsearch  http.cors.allow-origin: "/.*/"  http.cors.enabled: true

    613455-20160223153942990-2045006412.png

  • Logstash

    • /logstash/conf/logstash_agent.conf

      input {          file {                  type => "nginx_access"                  path => ["/usr/share/nginx/logs/test.access.log"]          }  }  output {          redis {                  host => "localhost"                  data_type => "list"                  key => "logstash:redis"          }  }
    • /logstash/conf/logstash_indexer.conf

      input {          redis {                  host => "localhost"                  data_type => "list"                  key => "logstash:redis"                  type => "redis-input"          }  }  filter {      grok {          match => [              "message", "%{WORD:http_host} %{URIHOST:api_domain} %{IP:inner_ip} %{IP:lvs_ip} \[%{HTTPDATE:timestamp}\] \"%{WORD:http_verb} %{URIPATH:baseurl}(?:\?%{NOTSPACE:request}|) HTTP/%{NUMBER:http_version}\" (?:-|%{NOTSPACE:request}) %{NUMBER:http_status_code} (?:%{NUMBER:bytes_read}|-) %{QS:referrer} %{QS:agent} %{NUMBER:time_duration:float} (?:%{NUMBER:time_backend_response:float}|-)"          ]      }      kv {          prefix => "request."          field_split => "&"          source => "request"      }      urldecode {          all_fields => true      }      #date {      #    type => "log-date"      #    match => ["timestamp" , "dd/MMM/YYYY:HH:mm:ss Z"]      #}      date {          match => ["logdate" , "dd/MMM/YYYY:HH:mm:ss Z"]      }  }  output {          elasticsearch {                  #embedded => false                  #protocol => "http"                  hosts => "localhost:9200"                  index => "access-%{+YYYY.MM.dd}"          }  }

    注意有些网络示例为旧版本配置,新版本下output的embedded、protocol以及filter的date都有所更新。

  • Kibana

    创建Index Pattern: access-*

测试

访问本地Kibana

613455-20160223154016568-201002000.png

613455-20160223154031318-309664934.png

参考

参考来源:

结束

转载于:https://www.cnblogs.com/richaaaard/p/5210118.html

你可能感兴趣的文章
Integer值判断是否相等问题
查看>>
实验中心服务器配置记录
查看>>
js数组去重
查看>>
UIView 设置背景图片
查看>>
$2018/8/15 = Day \ \ 1$杂题整理
查看>>
SpringBoot整合ActiveMQ
查看>>
[PCB设计] 2、畸形PCB板子的制作核心——AD14导入dwg格式文件的方法
查看>>
[每日电路图] 5、心率检测电路设计详解——送给想了解心率计的小白(博主推荐)...
查看>>
C#对 Dictionary进行排序 转
查看>>
51nod 1563 坐标轴上的最大团(今日gg模拟第一题) | 线段覆盖 贪心 思维题
查看>>
C#捕捉异常try catch finally throw(一)
查看>>
POJ-3683-Priest John's Busiest Day(2-sat)
查看>>
asp.net生成高质量缩略图通用函数(c#代码),支持多种生成方式
查看>>
使用R语言-操作data.frame
查看>>
文件系统管理
查看>>
[导入]古装武侠剧《神农碧血刀》全20集
查看>>
PHP之流程的控制
查看>>
如何查找Linux的函数定义的位置?
查看>>
大数据量 处理方法总结(转)
查看>>
关于win10和sqlserver的兼容性
查看>>