filebeat日志收集架构实战(小节7)


highlight: a11y-dark

theme: juejin

日志收集实战

架构规划:

在下面的图当中从左向右看,当要访问ELK日志统计平台的时候,首先访问的是两台nginx+keepalived做的负载高可用,访问的地址是keepalived的IP,当一台nginx代理服务器挂掉之后也不影响访问,然后nginx将请求转发到kibana,kibana再去elasticsearch获取数据,elasticsearch是两台做的集群,数据会随机保存在任意一台elasticsearch服务器,redis服务器做数据的临时保存,避免web服务器日志量过大的时候造成的数据收集与保存不一致导致的日志丢失,可以临时保存到redis,redis可以是集群,然后再由logstash服务器在非高峰时期从redis持续的取出即可,另外有一台mysql数据库服务器,用于持久化保存特定的数据,web服务器的日志由filebeat收集之后发送给另外的一台logstash,再有其写入到redis即可完成日志的收集,从图中可以看出,redis服务器处于前端结合的最中间,其左右都要依赖于redis的正常运行,web服务删个日志经过filebeat收集之后通过日志转发层的logstash写入到redis不同的key当中,然后提取层logstash再从redis将数据提取并安按照不同的类型写入到elasticsearch的不同index当中,用户最终通过nginx代理的kibana查看到收集到的日志的具体内容:

logstash2(105)

安装JDK

js apt install openjdk-8-jdk -y

安装logstash

安装包:logstash

js cd /usr/local/src/ dpkg -i logstash-6.8.3.deb

编辑配置信息

```js cd /etc/logstash/conf.d/

测试文件

cat beats.conf input { beats { port => 5044 } }

output { stdout { codec => "rubydebug" } } ```

启动

js /usr/share/logstash/bin/logstash -f beats.conf ...等待

web1(106)

输出改到logstash上

```js vim /etc/filebeat/filebeat.yml

结尾添加

output.logstash: hosts: ["192.168.37.105:5044","192.168.37.105:5045"] loadbalance: true worker: 1 compression_level: 3 ```

重启logstash

js systemctl restart filebeat

在日志中追加数据

js echo 123 >> /var/log/syslog input

logstash2(105)

看能否在105收到数据

js { "log" => { "file" => { "path" => "/var/log/syslog" } }, "@timestamp" => 2023-05-28T04:48:24.727Z, "@version" => "1", "fields" => { "level" => "debug", "type" => "syslog", "review" => 1 }, "input" => { "type" => "log" }, "prospector" => { "type" => "log" }, "host" => { "architecture" => "x86_64", "name" => "web1", "os" => { "version" => "18.04.1 LTS (Bionic Beaver)", "name" => "Ubuntu", "family" => "debian", "codename" => "bionic", "platform" => "ubuntu" }, "containerized" => false, "id" => "6b1f70a8909b4b0dbb63f938c28ca940" }, "beat" => { "hostname" => "web1", "name" => "web1", "version" => "6.8.3" }, "offset" => 6609389, "tags" => [ [0] "beats_input_codec_plain_applied" ], "source" => "/var/log/syslog", "message" => "123 input" }

```js vim beats.conf

input { beats { port => 5044 codec => "json" } beats { port => 5045 codec => "json" } }

output { stdout { codec => "rubydebug" } } ```

启动

js /usr/share/logstash/bin/logstash -f beats.conf

web1(106)

收集访问日志和系统日志

可参考:filebeat.yml

```js grep -v "#" /etc/filebeat/filebeat.yml |grep -v "^$" filebeat.inputs: - type: log enabled: true paths: - /var/log/syslog fields: type: syslog-106 level: debug review: 1

添加以下8行信息

  • type: log enabled: true paths:
    • /var/log/access.log fields: app: nginx-106 level: debug review: 1 filebeat.config.modules: path: ${path.config}/modules.d/*.yml reload.enabled: false setup.template.settings: index.numberofshards: 3 setup.kibana: processors:
      • addhostmetadata: ~
      • addcloudmetadata: ~ output.logstash: hosts: ["192.168.37.105:5044","192.168.37.105:5045"] loadbalance: true ```

重启服务

js systemctl restart filebeat

logstash2(105)

此时会收到日志

```js cat beats.conf input { beats { port => 5044 codec => "json" } beats { port => 5045 codec => "json" } }

output { if [fields][type] == "syslog-106" { redis { host => "192.168.37.104" port => "6379" password => "123456" key => "syslog-37-106" data_type => list db => 3 }}

if [fields][app] == "nginx-106" { redis { host => "192.168.37.104" port => "6379" password => "123456" key => "nginx-accesslog-37-106" data_type => list db => 3 }} } ```

检查

js /usr/share/logstash/bin/logstash -f beats.conf -t

重启

js systemctl restart logstash

redis(104)

```js

redis-cli

127.0.0.1:6379> AUTH 123456 OK 127.0.0.1:6379> SELECT 3 OK 127.0.0.1:6379[3]> KEYS * 1) "nginx-accesslog-37-106" <--如果此处没有、请在web1(106),运行'/apps/nginx/sbin/nginx'后,浏览器访问:'http://192.168.37.106/' 2) "syslog-37-106" <--如果没有数据、在web1(106)上直接'echo 123 >> /var/log/syslog' ```

web2(107)

安装jdk

js apt install openjdk-8-jdk -y

安装filebeat

安装包:filebeat

js cd /usr/local/src/ dpkg -i filebeat-6.8.3-amd64.deb

web1(106)

拷贝filebeat配置文件

js scp /etc/filebeat/filebeat.yml 192.168.37.107:/etc/filebeat/

拷贝nginx配置文件

停服务

js /apps/nginx/sbin/nginx -s stop

web2(107)

创建目录

js mkdir /apps

web1(106)

打包并拷贝

```js cd /apps tar czvf nginx.tar.gz nginx/*

scp nginx.tar.gz 192.168.37.107:/apps ```

启动服务

js /apps/nginx/sbin/nginx

web2(107)

解压并启动

js cd /apps/ tar xvf nginx.tar.gz /apps/nginx/sbin/nginx

修改filebeat文件、加以区分

js vim /etc/filebeat/filebeat.yml 46 type: syslog-107 71 app: nginx-107

logstash(105)

```js cd /etc/logstash/conf.d

cat beats.conf input { beats { port => 5044 codec => "json" } beats { port => 5045 codec => "json" } }

output { if [fields][type] == "syslog-106" { redis { host => "192.168.37.104" port => "6379" password => "123456" key => "syslog-37-106" data_type => list db => 3 }}

if [fields][app] == "nginx-106" { redis { host => "192.168.37.104" port => "6379" password => "123456" key => "nginx-accesslog-37-106" data_type => list db => 3 }}

添加了2个107

if [fields][type] == "syslog-107" { redis { host => "192.168.37.104" port => "6379" password => "123456" key => "syslog-37-107" data_type => list db => 3 }}

if [fields][app] == "nginx-107" { redis { host => "192.168.37.104" port => "6379" password => "123456" key => "nginx-accesslog-37-107" data_type => list db => 3 }} } ```

重启logstash

js systemctl restart logstash

web2(107)

重启filebeat

js systemctl restart filebeat

redis(104)

浏览器访问(192.168.37.106和192.168.37.107)、产生新的日志

js 127.0.0.1:6379[3]> KEYS * 1) "nginx-accesslog-37-106" 2) "nginx-accesslog-37-107" 3) "syslog-37-107" 4) "syslog-37-106"

logstash(103)

编辑文件

```js cd /etc/logstash/conf.d/

cat redis-to-es.conf input { redis { host => "192.168.37.104" port => "6379" password => "123456" key => "syslog-37-106" data_type => list db => 3 }

redis { host => "192.168.37.104" port => "6379" password => "123456" key => "syslog-37-107" data_type => list db => 3 }

redis { host => "192.168.37.104" port => "6379" password => "123456" key => "nginx-accesslog-37-106" data_type => list db => 3 }

redis { host => "192.168.37.104" port => "6379" password => "123456" key => "nginx-accesslog-37-107" data_type => list db => 3 } }

output {

系统日志

if [fields][type] == "syslog-106" { elasticsearch { hosts => ["http://192.168.37.102:9200"] index => "filebeat-syslog-37-106-%{+YYYY.MM.dd}" }}

if [fields][type] == "syslog-107" { elasticsearch { hosts => ["http://192.168.37.102:9200"] index => "filebeat-syslog-37-107-%{+YYYY.MM.dd}" }}

nginx日志

if [fields][app] == "nginx-106" { elasticsearch { hosts => ["http://192.168.37.102:9200"] index => "logstash-nginx-accesslog-37-106-%{+YYYY.MM.dd}" }}

if [fields][app] == "nginx-107" { elasticsearch { hosts => ["http://192.168.37.102:9200"] index => "logstash-nginx-accesslog-37-107-%{+YYYY.MM.dd}" }} } ```

重启服务

js systemctl restart logstash

redis(104)

数据被取走了

js 127.0.0.1:6379[3]> KEYS * (empty list or set)

图片.png

在kibana(http://192.168.37.101:5601), 依次添加 logstash-nginx-accesslog-37-10{6,7}和filebeat-syslog-37-10{6,7}

通过haproxy代理kibana并实现登录认证

host1(101)

下载nginx

js cd /usr/local/src/ wget http://nginx.org/download/nginx-1.16.1.tar.gz

解压

js tar xvf nginx-1.16.1.tar.gz

编译安装(编译安装出错可参考)

```js cd nginx-1.16.1/ ./configure --prefix=/apps/

make make install ```

修改kibana文件

```js vim /etc/kibana/kibana.yml

server.host: "127.0.0.1" ```

重启服务

js systemctl restart kibana

js cd /apps/ mkdir nginx mv * nginx/

配置

js vim nginx/conf/nginx.conf ...#在http中添加 http { include /apps/nginx/conf.d/*.conf;

创建目录

js mkdir /apps/nginx/conf.d/

配置nginx代理kibana

```js cd /apps

vim nginx/conf.d/kibana.conf upstream kibanaserver { server 127.0.0.1:5601 weight=1 maxfails=3 fail_timeout=60; }

server { listen 80; servername www.kibana101.com; location / { proxypass http://kibanaserver; proxyhttpversion 1.1; proxysetheader Upgrade $httpupgrade; proxysetheader Connection 'upgrade'; proxysetheader Host $host; proxycachebypass $http_upgrade; } } ```

指定配置文件启动

js mkdir /apps/logs/ /apps/nginx/sbin/nginx -c /apps/nginx/conf/nginx.conf

本地域名解析

图片.png

通过域名访问

图片.png

添加认证

host1(101)

注意:首次创建需要'-c'选项、追加不需要!!!如果追加时用'-c'会把之前的替换掉!!! ```js htpasswd -bc /apps/nginx/conf/htpasswd.users zhao 123456 Adding password for user zhao

htpasswd -b /apps/nginx/conf/htpasswd.users qian 123456 Adding password for user qian ```

```js cat /apps/nginx/conf.d/kibana.conf upstream kibanaserver { server 127.0.0.1:5601 weight=1 maxfails=3 fail_timeout=60; }

server { listen 80; servername www.kibana101.com; authbasic "Restricted Access"; authbasicuserfile /apps/nginx/conf/htpasswd.users; location / { proxypass http://kibanaserver; proxyhttpversion 1.1; proxysetheader Upgrade $httpupgrade; proxysetheader Connection 'upgrade'; proxysetheader Host $host; proxycachebypass $http_upgrade; } } ```

重新加载配置文件

js /apps/nginx/sbin/nginx -c /apps/nginx/conf/nginx.conf -s reload

两个用户都可以登录

图片.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值