介绍一套传统的日志监控服务器部署方案

服务器
本文介绍一套传统的日志监控服务器部署方案,可以将多个 linux主机的日志收集在 一个日志服务器上保存在/data/log/并按IP分目录保存。

一、方案介绍

(1) 方式 1:

Rsyslog->Rsyslog-server+mysql+Loganalyzer  

(2) 重点:(配置文件)

  • 转发日志的主机——配置rsyslog.conf日志转发规则、存储规则、系统日志与非系统日志的区别定义。
  • 接收日志服务器——配置rsyslog.conf日志接受模块、存储规则、mysql存储模块、系统日志与非系统日志的区别定义。
  • 日志文件命名规则与日志内容自定义模板的区别和使用方法。

(3) 功能 :

  • 将多个 linux主机的日志收集在 一个日志服务器上保存在/data/log/并按IP分目录保存;
  • 同步存储在MySQL数据库中;
  • 展示在web上;

二、基础架构C/S

三、安装脚本.sh

1.适用环境:(经过测试,过程没有异常),其他环境下有异常请更改脚本再运行。

Linux version 3.10.0-693.el7.x86_64
CentOS Linux release 7.4.1708 (Core)

2.脚本说明:

脚本会安装数据库,如果你的系统已经装有数据库并有数据,请先修改脚本中数据库的安装语句再执行,避免数据丢失。

使用说明:

(1) 客户端:

执行客户端rsyslog-agent安装脚本请在后面跟上你的rsyslog-server的ip,如:

sh rsyslog_install_agent.sh 192.168.32.128

(2) 服务端-单机部署

如果你想要把rsyslog-server和web服务装在同一个主机上请按顺序执行脚本:

sh rsyslog_mysql_install_server.sh
sh loganalyzer_web_install_server.sh

(3) 服务的-双机部署

如果你想要把rsyslog-server和web服务分开装在不同的主机上,请在rsyslog-server上执行脚本:

sh rsyslog_mysql_install_server.sh

在web服务器上执行脚本:

sh loganalyzer_web_install_server.sh

rsyslog_mysql_install_server.sh:

#!/bin/bash
clear
echo '
>>>>>>>>安装Rsyslog+mariadb-server=Rsyslog-server
------------------------------------------------
!!!如果系统已经安装过mysql数据库,请将脚本中的安装数据库的部分注释再继续
环境:
适用版本:测试正常.
Linux version 3.10.0-693.el7.x86_64
CentOS Linux release 7.4.1708 (Core)
---------------------------------------------------
其他系统环境下没有测试,如果报错,请更改脚本再继续安装
'
sleep 10
echo '第一步:基本环境配置'
yum install wget -y
wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo && yum makecache fast && yum install centos-release-scl -y
sed -i '1c\#!/usr/bin/python2 -Es' /usr/sbin/firewalld && sed -i '1c\#!/usr/bin/python2 -Es' /usr/bin/firewall-cmd
systemctl restart firewalld && systemctl enable firewalld
sed -i 's/enforcing/disabled/g' /etc/selinux/config
setenforce 0
clear
echo '第二步:安装rsyslog并配置转发到mysql,作为日志服务器rsyslog-server'
yum remove rsyslog -y && rm -rf /etc/rsyslog*
yum install rsyslog rsyslog-mysql mariadb-server -y
rpm -ql rsyslog-mysql
sed -i 's/Syslog/rsyslog/g' /usr/share/doc/rsyslog-8.24.0/mysql-createDB.sql
systemctl start rsyslog && systemctl enable rsyslog
systemctl start mariadb && systemctl enable mariadb
pwd_sql=$(rpm -ql rsyslog-mysql | grep create)
mysql <$pwd_sql
mysql -e "grant all privileges on rsyslog.* to rsyslog@'%' identified by 'rsyslog';grant all privileges on rsyslog.* to rsyslog@'localhost' identified by 'rsyslog';flush privileges;"
#sed -i '$ a\$ModLoad imtcp\n$InputTCPServerRun 514' /etc/rsyslog.conf
sed -i '$ a\$ModLoad imudp\n$UDPServerRun 514\n$ModLoad imtcp\n$InputTCPServerRun 514\n$ModLoad ommysql #:ommysql:数据库IP,数据库名,用户名,密码\n*.info;mail.none;authpriv.none;cron.none :ommysql:127.0.0.1,rsyslog,rsyslog,rsyslog' /etc/rsyslog.conf
sed -i '$ a\*.info;mail.none;authpriv.none;cron.none @127.0.0.1' /etc/rsyslog.conf
systemctl restart rsyslog
firewall-cmd --add-port=514/tcp --zone=public --permanent
firewall-cmd --reload && systemctl restart firewalld
clear
netstat -nltp |grep -E '514|3306'
echo '安装结束!
请检查3306和514端口是否在侦听。
注意:
执行此脚本以后firewalld默认enable,如果需要设置开机不自启,请自己disable
接收日志的端口为514
mysql信息:port:3306,数据库、用户名密码均为rsyslog

loganalyzer_web_install_server.sh:


#!/bin/bash
clear
echo '
>>>>>>>>安装loganalyzer
------------------------------------------------
@如果系统安装过httpd,请不要使用这个脚本,或者更改以后再使用
适用版本:测试正常.
Linux version 3.10.0-693.el7.x86_64
CentOS Linux release 7.4.1708 (Core)
---------------------------------------------------
其他系统环境下没有测试,如果报错,请更改脚本再继续安装
'
echo '第一步:基本环境配置'
yum install wget -y
wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo && yum makecache fast && yum install centos-release-scl -y
sed -i '1c\#!/usr/bin/python2 -Es' /usr/sbin/firewalld && sed -i '1c\#!/usr/bin/python2 -Es' /usr/bin/firewall-cmd
systemctl stop firewalld  
sed -i 's/enforcing/disabled/g' /etc/selinux/config
setenforce 0
echo '第二步:开始安装组件'
yum install php php-mysql httpd -y
systemctl start httpd &&  systemctl enable httpd
echo '第三步:开始下载配置loganalyzer'
wget https://download.adiscon.com/loganalyzer/loganalyzer-4.1.12.tar.gz --no-check-certificate
mkdir -p /var/www/html/loganalyzer && tar -zxvf loganalyzer-4.1.12.tar.gz && cp -rf loganalyzer-4.1.12/* /var/www/html/loganalyzer
chmod a+x /var/www/html/loganalyzer/contrib/*
sh /var/www/html/loganalyzer/contrib/secure.sh
sh /var/www/html/loganalyzer/contrib/configure.sh
cp config.php /var/www/html/loganalyzer/src
chmod 666 /var/www/html/loganalyzer/src/config.php
sed -i 's/80/8051/g' /etc/httpd/conf/httpd.conf
systemctl restart httpd firewalld
firewall-cmd --add-port=8051/tcp --zone=public --permanent
firewall-cmd --reload && systemctl restart firewalld
systemctl enable firewalld
echo '
第四步:请在浏览器上访问如下url,
如果可以打开则说明正常http://系统ip:8051/loganalyzer/src/install.php能访问就行,不需要开始在web上操作,
rsyslog+mysql服务服务装好以后再在web上操作数据源
注意:
执行此脚本以后firewalld默认enable,如果需要设置开机不自启,请自己disable

rsyslog_install_agent.sh:

#!/bin/bash
clear
echo '
>>>>>>>>安装Rsyslog将日志转发到rsyslog-server
------------------------------------------------
@使用脚本请请先修改18行的ip地址为rsyslog-server的ip
适用版本:测试正常.
Linux version 3.10.0-693.el7.x86_64
CentOS Linux release 7.4.1708 (Core)
---------------------------------------------------
其他系统环境下没有测试,如果报错,请更改脚本再继续安装
'
sleep 10
yum remove rsyslog -y && rm -rf /etc/rsyslog*
wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo && yum makecache fast && yum install centos-release-scl -y
sed -i '1c\#!/usr/bin/python2 -Es' /usr/sbin/firewalld && sed -i '1c\#!/usr/bin/python2 -Es' /usr/bin/firewall-cmd
sytemctl restart firewalld && sytemctl enable firewalld
yum install rsyslog -y
sed -i '$ a\*.info;mail.none;authpriv.none;cron.none @'$1'' /etc/rsyslog.conf
systemctl restart rsyslog
firewall-cmd --add-port=514/tcp --zone=public --permanent
firewall-cmd --reload
echo 'rsyslog配置完成!!
请去Rsyslog-server的数据库中查看是否有这台主机的日志。
注意:
执行此脚本以后firewalld默认enable,如果需要设置开机不自启,请自己disable
'

四、访问web进行简单配置

1.http://服务器ip:8051/loganalyzer/src/install.php

2.进行数据源的配置,使用mysql_nactive。

注意按着这个脚本安装的数据库、账号、密码均为rsyslog,连接127.0.0.1:3306

3.鼠标点点点的操作大家都会,这里不再继续描述。

到这里这个平台已经算基本完成,后期就是优化的操作,优化的是客户端和服务端的配置文件/etc/rsyslog.conf,更改配置以后一定要重启rsyslog配置才会生效。

五、整体效果

日志服务器本地存储:

web展示:

我这里提供一套配置文件模板,参考。

服务端配置文件:


#配置运行目录
$ModLoad imuxsock # provides support for local system logging (e.g. via logger command)
$ModLoad imjournal # provides access to the systemd journal
$WorkDirectory /var/lib/rsyslog
#接收本机的日志
#配置接收其他主机的日志UDP+TCP
$ModLoad imudp
$UDPServerRun 514
$ModLoad imtcp
$InputTCPServerRun 514
$AllowedSender tcp, 192.168.32.0/24
#定义本地存储路径
$template format1,"/data/log/%fromhost-ip%/warning(up)-%$YEAR%-%$MONTH%-%$DAY%.log"
$template format2,"/data/log/%fromhost-ip%/web-access-%$YEAR%-%$MONTH%-%$DAY%.log"
$template format3,"/data/log/%fromhost-ip%/web-error-%$YEAR%-%$MONTH%-%$DAY%.log"
#非系统日志--应用日志
module(load="imfile" PollingInterval="10")
input(
type="imfile"
File="/var/log/httpd/access_log"
Tag="http_accessr"
Severity="info"
Facility="local1")

input(type="imfile"
File="/var/log/httpd/error_log"
Tag="http_error"
Severity="error"
Facility="local2")

#发送服务器本身的日志warning以上级别的日志
*.warning @@192.168.32.128:514
local2.* @@192.168.32.128:514
local1.* @@192.168.32.128:514

#设置本地存储
:fromhost-ip, !isequal, "127.0.0.1" ?format1
*.warning ?format1
local1.* ?format2
local2.* ?format3
#将日志存储在mysql中
$ModLoad ommysql #:ommysql:数据库IP,数据库名,用户名,密码
*.warning;local1.*;local2.* :ommysql:127.0.0.1,rsyslog,rsyslog,rsyslog

客户端配置文件:


#配置运行目录
$ModLoad imuxsock # provides support for local system logging (e.g. via logger command)
$ModLoad imjournal # provides access to the systemd journal
$WorkDirectory /var/lib/rsyslog
#非系统日志--应用日志
module(load="imfile" PollingInterval="10")
#输入nginx_access_log
input(
type="imfile"
File="/var/log/httpd/access_log"
Tag="nginx_accessr"
Severity="info"
Facility="local1")
#输入nginx_error_log
input(type="imfile"
File="/var/log/httpd/error_log"
Tag="nginx_error"
Severity="error"
Facility="local2")

#发送规则:发送warning以上等级的系统信息及nginx的所有日志
*.warning @@192.168.32.128:514
*.warning @192.168.32.128:514
local1.* @@192.168.32.128:514
local2.* @@192.168.32.128:514

#定义本地存储路径
*.info;mail.none;authpriv.none;cron.none      /var/log/messages
authpriv.*                                   /var/log/secure
mail.*                                    -/var/log/maillog
cron.*                                   /var/log/cron
*.emerg                                  :omusrmsg:*
uucp,news.crit                           /var/log/spooler
local7.*                                 /var/log/boot.log
责任编辑:赵宁宁 来源: IT仔的笔记本
相关推荐

2019-02-20 10:22:20

监控HDFSHadoop

2023-03-03 17:00:00

部署Linux内核

2015-11-02 09:38:51

云计算客户端服务器

2018-11-07 11:26:14

超融合服务器部署

2022-04-29 09:04:35

日志平台开发

2009-03-03 13:00:00

虚拟化技术vmwarexen

2010-03-16 15:54:52

2014-04-03 16:36:46

Ubuntu ServCacti服务器监控

2010-05-21 11:50:54

IIS服务器

2012-02-16 09:22:11

2018-07-06 11:01:03

2017-10-27 16:09:26

UbuntuGraylog日志服务器

2014-12-02 10:02:21

Android异步任务

2009-09-17 13:23:22

NIS服务器

2009-06-23 18:01:45

Ajax框架源代码

2018-08-31 08:42:48

LinuxUnix实用程序

2022-08-11 08:27:24

Sentry日志监控系统

2009-07-21 16:23:26

2009-02-17 09:51:00

2021-01-08 08:19:36

数据库TiDB集群
点赞
收藏

51CTO技术栈公众号