修改info-center的channel把日志发送到日志服务器_一款可与ELK相提并论的集中式日志管理系统-Graylog...

Graylog与ELK可以相提并论的一款集中式日志管理方案,支持数据收集、检索、可视化Dashboard。

简介

Graylog最小化架构设计:

d0cc4a5e56396655b9fe113c78470521.png

GrayLog:提供 GrayLog对外接口,具有报警选项的可插入日志和事件分析服务器。

Elasticsearch:一个基于Lucene的文档存储,主要用于日志索引、存储和分析。

MongoDB:存储一些 GrayLog 的配置信息。


Graylog群集架构图:

0f07bfc7c011536e70804f2e847325be.png
  1. 一体化方案,安装方便,不像ELK有3个独立系统间的集成问题。
  2. 采集原始日志,并可以事后再添加字段,比如http_status_code,response_time等等。
  3. 自己开发采集日志的脚本,并用curl/nc发送到Graylog Server,发送格式是自定义的GELF,Flunted和Logstash都有相应的输出GELF消息的插件。自己开发带来很大的自由度。实际上只需要用inotifywait监控日志的modify事件,并把日志的新增行用curl/netcat发送到Graylog Server就可。
  4. 搜索结果高亮显示,就像google一样。
  5. 搜索语法简单,比如: source:mongo AND reponse_time_ms:>5000,避免直接输入elasticsearch搜索json语法
  6. 搜索条件可以导出为elasticsearch的搜索json文本,方便直接开发调用elasticsearch rest api的搜索脚本。

环境部署

Java安装

$ yum install java-1.8.0-openjdk-headless.x86_64
7b17d4cd5abdbf6f7c1935f5447c2a41.png

MongoDB安装

准备yum源

$ vim /etc/yum.repos.d/mongodb-org-3.2.repo
af8f39bbf43eaed954b36da4f3c7a5c5.png
$ yum install mongodb-org

启动服务

$ sudo chkconfig --add mongod$ sudo systemctl daemon-reload$ sudo systemctl enable mongod.service$ sudo systemctl start mongod.service

Elasticsearch安装

$ rpm --import https://artifacts.elastic.co/GPG-KEY-elasticsearch$ vim /etc/yum.repos.d/elasticsearch.repo$ yum install elasticsearch
532782ab645696f976fba4f2aaf1c706.png

更改elasticsearch配置文件

$ vim /etc/elasticsearch/elasticsearch.ymlcluster.name: graylog
4ca5cc71d2962f13eda4c81cac0908d9.png

启动服务

$ chkconfig --add elasticsearch $ systemctl daemon-reload $ systemctl enable elasticsearch.service $ systemctl restart elasticsearch.service

安装Graylog

$ rpm -Uvh https://packages.graylog2.org/repo/packages/graylog-2.3-repository_latest.rpm$ yum install graylog-server

编辑配置文件 /etc/graylog/server/server.conf 添加 password_secret 、root_password_sha2,执行如下命令,将结果添加到分别添加到配置文件对应的部分。

$ yum install epel-release$ yum install pwgen$ pwgen -N 1 -s 96

将结果添加到 配置文件的password_secret 部分。

$ echo -n  | sha256sum

将结果添加到配置文件的 root_password_sha2 部分。

f1a8f32c75df31684aafd2a3a4af749e.png

启动服务

$ sudo chkconfig --add graylog-server $ sudo systemctl daemon-reload $ sudo systemctl enable graylog-server.service $ sudo systemctl start graylog-server.service

然后修改rest_listem_uri和web_listem_uri的IP地址修改为本机的IP。

rest_listen_uri = http://192.168.190.168:9000/api/web_listen_uri = http://192.168.190.168:9000/root_timezone = Asia/Shanghai

至此,graylog web已经安装完成,访问http://localhost:9000即可看到web界面。

官方文档:http://docs.graylog.org/en/3.0/pages/getting_started/configure.html

9c3d0b54c99e6e9fe5f0f18c4eb00f79.png
2adad06afb79910872dcf30b3be9ee19.png

添加日志收集器

a6b5f584b229c2354a660b3771b0c631.png
bc836702a59ea0adb1d2ba15661d1f33.png
0fa367dd9df22a04fc5a90d95c1cf433.png
c45a1b599bf39d5e994708a90fd7af74.png

测试

执行命令:

# echo 'date' | nc 127.0.0.1 5555
a559a6cab4a28e4991b1d6ba3c030cb5.png

安装成功

GELF (Graylog Extended Log Format) 可以接收结构化的事件, 支持压缩(GZIP’d or ZLIB’d)和分块。

GELF message:

  • version string
  • host string
  • short_message string
  • full_message string
  • timestamp number
  • level number
  • facility string
  • line number
  • file string
  • _[additional field] string or number, 通过 _ 前缀添加自定义的字段
fbce0dce98714e6cdd40411bd2952605.png
ae9c6e42c5f09f4a8dc4273b7e4b5426.png
ea82f199d337fdf220837300c75ff642.png

测试命令:

# curl -XPOST http://127.0.0.1:12201/gelf -p0 -d '{"short_message":"Hello jncsy!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值