基本部署文档

1、升级本机所有包

yum update -y

2、查看rsyslog官网,加入新的源https://www.rsyslog.com/rhelcentos-rpms/

cd /etc/yum.repos.d/
wget http://rpms.adiscon.com/v8-stable/rsyslog.repo # for CentOS 7,8,9
wget http://rpms.adiscon.com/v8-stable-daily/rsyslog-daily.repo # for CentOS 7,8,9

也可以通过rpm直接安装,在这里搜索包。由于用的centos7可能版本较低,需要较多依赖,未成功。最好采用其他在维护发行版。
http://rpmfind.net/linux/rpm2html/search.php?query=rsyslog

4、安装Rsyslog及Rsyslog连接MySQL的模块

yum install rsyslog rsyslog-mysql -y

5、导入rsyslog-mysql数据库文件
由于安装了BT面板,就直接在面板中建立数据库,注意这里的配置参数要和后面conf文件对应。

如果未通过BT面板安装,传统导入方法如下:

cd /usr/share/doc/rsyslog-8.24.0/
mysql -uroot -padmin@123 < mysql-createDB.sql

创建用户

grant all on Syslog.* to rsyslog@'localhost' identified by '123456';
flush privileges;

注意导入时建立的库为Syslog首字母为大写。BT面板建立的为小写syslog。

rsyslog原始SQL
mysql-createDB.zip
BT面板建立SQL
syslog最终表结构.zip

6、配置文件开启端口和模块
正常开启mysql例子如下

$ModLoad ommysql
*.* :ommysql:localhost,Syslog,rsyslog,123456

最终配置文件如下,主要开启了udp和tcp514端口获取,开启mysql输出,注意mysql连接配置。

# rsyslog configuration file

# For more information see /usr/share/doc/rsyslog-*/rsyslog_conf.html
# If you experience problems, see http://www.rsyslog.com/doc/troubleshoot.html

#### MODULES ####
$MaxMessageSize 64k
# The imjournal module bellow is now used as a message source instead of imuxsock.
$ModLoad imuxsock # provides support for local system logging (e.g. via logger command)
$ModLoad imjournal # provides access to the systemd journal
#$ModLoad imklog # reads kernel messages (the same are read from journald)
$ModLoad immark  # provides --MARK-- message capability

# Provides UDP syslog reception
$ModLoad imudp
$UDPServerRun 514

# Provides TCP syslog reception
$ModLoad imtcp
$InputTCPServerRun 514

$ModLoad ommysql
*.* :ommysql:127.0.0.1,syslog,syslog,123456


#### GLOBAL DIRECTIVES ####

# Where to place auxiliary files
$WorkDirectory /var/lib/rsyslog

# Use default timestamp format
$ActionFileDefaultTemplate RSYSLOG_TraditionalFileFormat

# File syncing capability is disabled by default. This feature is usually not required,
# not useful and an extreme performance hit
#$ActionFileEnableSync on

# Include all config files in /etc/rsyslog.d/
$IncludeConfig /etc/rsyslog.d/*.conf

# Turn off message reception via local log socket;
# local messages are retrieved through imjournal now.
$OmitLocalLogging on

# File to store the position in the journal
$IMJournalStateFile imjournal.state


#### RULES ####

# Log all kernel messages to the console.
# Logging much else clutters up the screen.
#kern.*                                                 /dev/console

# Log anything (except mail) of level info or higher.
# Don't log private authentication messages!
#*.info;mail.none;authpriv.none;cron.none                /var/log/rsyslog/messages

# The authpriv file has restricted access.
#authpriv.*                                              /var/log/rsyslog/secure

# Log all the mail messages in one place.
#mail.*                                                  -/var/log/rsyslog/maillog


# Log cron stuff
#cron.*                                                  /var/log/rsyslog/cron

# Everybody gets emergency messages
#*.emerg                                                 :omusrmsg:*

# Save news errors of level crit and higher in a special file.
#uucp,news.crit                                          /var/log/rsyslog/spooler

# Save boot messages also to boot.log
#local7.*                                                /var/log/rsyslog/boot.log

# 定义一个模板,使用设备 IP 动态生成文件路径
template(name="DynamicLogFile" type="string" string="/var/log/rsyslog/%fromhost-ip%/%$year%-%$month%-%$day%/%$HOUR%-%$MINUTE%.log")

# 根据 IP 地址将日志写入动态生成的文件
if $fromhost-ip != '' then ?DynamicLogFile
& stop

# ### begin forwarding rule ###
# The statement between the begin ... end define a SINGLE forwarding
# rule. They belong together, do NOT split them. If you create multiple
# forwarding rules, duplicate the whole block!
# Remote Logging (we use TCP for reliable delivery)
#
# An on-disk queue is created for this action. If the remote host is
# down, messages are spooled to disk and sent when it is up again.
#$ActionQueueFileName fwdRule1 # unique name prefix for spool files
#$ActionQueueMaxDiskSpace 1g   # 1gb space limit (use as much as possible)
#$ActionQueueSaveOnShutdown on # save messages to disk on shutdown
#$ActionQueueType LinkedList   # run asynchronously
#$ActionResumeRetryCount -1    # infinite retries if host is down
# remote host is: name/ip:port, e.g. 192.168.0.1:514, port optional
#*.* @@remote-host:514
# ### end of the forwarding rule ###

输出文件日志会按照来源IP进行分文件夹,每日一个文件保存。

结束后可以看一下安装版本,执行重启服务配置才会生效。

rsyslogd -version
systemctl restart rsyslog

7、配置防火墙
作为日志服务器,需要开启访问514端口。

# firewall-cmd --zone=public --add-port=514/tcp
# firewall-cmd --zone=public --add-port=514/udp

也可用BT面板直接开启514tcp/udp。

8、开启mysql后,遇到无法写入mysql的问题。经过查看上述文件夹/var/log/rsyslog/127.0.0.1中的日志可看到报错原因。

could not load module 'ommysql', errors: trying to load module /usr/lib64/rsyslog/ommysql.so: /usr/lib64/libmysqlclient.so.18: version `libmysqlclient_18' not found (required by /usr/lib64/rsyslog/ommysql.so) [v8.2404.0 try https://www.rsyslog.com/e/2066 ]

报错原因查了一圈,首先确定不是ommysql.so问题。可运行’rpm -ql rsyslog-mysql’,查看rsyslog-mysql安装生成了那些文件,/usr/lib64/rsyslog/ommysql.so目录与上面一致。
后又查看libmysqlclient.so.18,发现被软连接到BT面板自带的/www/server/mysql/lib/libmysqlclient.so.20。报错应该是提示version不对。

通过yum install mariadb-libs-5.5.68-1.el7.x86_64安装,rpm -ql mariadb-libs-5.5.68-1.el7.x86_64可以查询到/user/lib64/mysql/libmysqlclient.so.18
做一个软连接即可/user/lib64/libmysqlclient.so.18->/user/lib64/mysql/libmysqlclient.so.18

如果找不到libmysqlclient.so.18也可以试一下下面命令:

yum install mysql-devel
yum install mysql-community-libs
wget https://mirrors.aliyun.com/mysql/MySQL-5.7/mysql-community-libs-compat-5.7.36-1.el7.x86_64.rpm

如何配置客户端?

Linux服务器

① 安装Rsyslog,如果需要换源,可参照上面。

yum install rsyslog -y

② 配置日志发送

vi /etc/rsyslog.conf

编辑rsyslog服务配置文件,文件末尾加入一行

#*.* info @172.16.5.166:514
*.* @@172.16.5.166:514

保存退出。认证和计划任务日志等在本地保存的同时,还会保存到远程日志服务器。

配置术语说明:facility:中文翻译过来是设施的意思,从功能或程序上对日志分类,在Linux中常见的facility有:auth(认证相关的日志),authpriv(授权相关的日志),cron(计划任务相关日志),daemon(系统服务相关日志),ftp(ftp服务相关的日志),kern(内核相关日志),lpr(打印相关的日志),mail(邮件相关日志),news(新闻相关的日志),security(安全相关的日志),user(用户相关的日志),uucp(文件copy相关的日志),local0-local7(自定义相关的日志)

priority:优先级别,从低到高排序:debug(调试),info(消息),notice(注意),warn(warning警告),err(error错误),crit(critical严重警告),alert(需要立即修改的信息)emerg(panic内核崩溃,内核恐慌等严重的信息)

一个@代表通过UDP协议发送日志,两个@@代表以tcp方式传送日志。与UDP相比,TCP传输的方式更加稳定一些。

③ 将客户端执行的所有命令写入系统日志中
编辑/etc/bashrc

vi /etc/bashrc

文件底部添加一行,加入以下内容

export PROMPT_COMMAND='{ msg=$(history 1 | { read x y; echo $y; });logger "[euid=$(whoami)]":$(who am i):[`pwd`]"$msg"; }'

设置使其生效

source !$

④重启服务,使配置更改生效

systemctl restart rsyslog

Windows服务器

下载Rsyslog Windows版本
访问 https://www.rsyslog.com/windows-agent/windows-agent-download/ 并下载最新的Rsyslog MSI安装程序。

方法一:
打开RSyslog Windows Agent Configuration,依次展示RuleSets—->Default RuleSet—->ForwardSyslog—->Actions—->Rsyslog,进行Rsyslog转发配置,并启用服务。

方法二:
打开Rsyslog配置文件 rsyslog.conf,通常位于 D:\Program Files\rsyslog\ 目录下。
例如,如果您想将日志发送到远程的Rsyslog服务器,您可以在配置文件中添加如下行:

*.* @@172.16.5.166:514

其中172.16.5.166是Rsyslog服务器的IP地址,514 是默认的Rsyslog端口。

重启Rsyslog服务
可以通过服务管理器(services.msc)来重启Rsyslog服务,或者使用命令行:

net stop rsyslog && net start rsyslog

交换机和防火墙等设备

Huawei

<Huawei> system-view
[Huawei] info-center loghost source Vlanif144
[Huawei] info-center loghost 172.16.5.166 facility local5

H3C

<H3C> system-view
[H3C] info-center enable
[H3C] info-center loghost source Vlan-interface144
[H3C] info-center loghost 172.16.5.166 facility local6

Cisco

Cisco>
Cisco> enable
Cisco# config terminal
Cisco(config)# logging on
Cisco(config)# logging 172.16.5.166
Cisco(config)# logging facility local4
Cisco(config)# logging source-interface e0

Ruijie

Ruijie>
Ruijie> enable
Ruijie# config terminal
Ruijie(config)# logging buffered warnings
Ruijie(config)# logging source interface VLAN 144
Ruijie(config)# logging facility local6
Ruijie(config)# logging server 172.16.5.166

附录:

官方文档中mysql模版

RSYSLOG_StdDBFmt - Generates a insert command with the message properties, into table SystemEvents for a MariaDB/MySQL database.

template(name="StdSQLformat" type="list" option.sql="on") {
        constant(value="insert into SystemEvents (Message, Facility, FromHost, Priority, DeviceReportedTime, ReceivedAt, InfoUnitID, SysLogTag)")
        constant(value=" values ('")
        property(name="msg")
        constant(value="', ")
        property(name="syslogfacility")
        constant(value=", '")
        property(name="hostname")
        constant(value="', ")
        property(name="syslogpriority")
        constant(value=", '")
        property(name="timereported" dateFormat="mysql")
        constant(value="', '")
        property(name="timegenerated" dateFormat="mysql")
        constant(value="', ")
        property(name="iut")
        constant(value=", '")
        property(name="syslogtag")
        constant(value="')")
        }

其他模版

template(name="stdSQLformat" type="string" option.sql="on"
         string="insert into SystemEvents (Message, Facility, FromHost, Priority, DeviceReportedTime, ReceivedAt, InfoUnitID, SysLogTag) values ('%msg%', %syslogfacility%, '%HOSTNAME%', %syslogpriority%, '%timereported:::date-mysql%', '%timegenerated:::date-mysql%', %iut%, '%syslogtag%')"
        )
$template tpl,"insert into SystemEvents (Message, Facility, FromHost,
Priority, DeviceReportedTime, ReceivedAt, InfoUnitID, SysLogTag) values
('%msg%', %syslogfacility%, '%HOSTNAME%', %syslogpriority%,
'%timereported:::date-mysql%', '%timegenerated:::date-mysql%', %iut%,
'%syslogtag%')",SQL
module(load="ommysql")
action(type="ommysql" server="mysqlserver.example.com" serverport="1234"
       db="syslog_db" uid="user" pwd="pwd")

如果要编译安装rsyslog,注意添加mysql模块

./configure --enable-mysql

安装LogAnalyzer支持web查询

已经支持PHP8,在BT中建立网站,选择Nginx 1.26.2+PHP 8.0.26。建立完毕后注意去除PHP的openlog函数禁用。经测试PHP8.3也可正常使用。

1、下载程序

wget https://download.adiscon.com/loganalyzer/loganalyzer-4.1.13.tar.gz

解压到网站目录即可

2、提示没有配置文件,点击here下一步;

3、验证文件权限(BT面板中没遇到权限问题,以下仅供参考)
rsyslog-1.jpg
提示错误:缺少config.php文件,并且权限要设置为666,可以使用contrib目录下的configure.sh脚本生成。
查看configure.sh文件的内容
rsyslog-2.jpg

需要在/var/www/html/loganalyzer/下创建config.php文件,并设置666权限

[root@superman123 contrib]# touch /var/www/html/loganalyzer/config.php
[root@superman123 contrib]# chmod 666 !$

rsyslog-3.jpg

操作完上面的,执行Recheck,config.php文件可写

rsyslog-4.jpg

4、基础设置

rsyslog-5.jpg

注意该项要开启,否则无须登录也可查看log。
Require User to be logged in :Yes

5、创建表、检查SQL结果、创建用户

6、创建系统日志源

rsyslog-6.jpg

注意SystemEvents表必须为大写,和数据库中一致。

7、完成

注意如需更改配置可在loganalyzer/config.php中修改,同时如果账号和数据库连接有错,还需在数据库中同步修改。

附录:

config文件出错问题另一解决方法记录

将安装包contrib文件夹中的两个文件拷贝至syslog网站根目录中

cp -r loganalyzer-4.1.13/contrib/* /var/www/html/syslog/

将两个可执行文件增加a+x权限

cd /var/www/html/syslog/
chmod +x configure.sh secure.sh

运行configure.sh,会生成一个空白的config.php文件

./configure.sh

访问IP:端口/syslog,报错点击”here”,使用向导进行安装

loganalyzer中文乱码解决方法:

备份配置文件

cp /var/www/html/syslog/include/functions_common.php /home/cgyxt/syslog/

修改配置文件

vim /var/www/html/syslog/include/functions_common.php

找到含有return htmlentities字段的行;

return htmlentities($myStr, ENT_NOQUOTES, $content['HeaderDefaultEncoding']);// "UTF-8");

修改为(该项似乎有问题,可以不修改,PHP默认即为UTF-8,且下方有语法错误):

return htmlentities($myStr, ENT_NOQUOTES, $content['HeaderDefaultEncoding']), "UTF-8");

保存

重启apache

systemctl restart httpd

进入loganalyzer,将Admin Center>Global Options Only>Default character encoding改为”utf-8”,完成后点击send changes。

参考链接:
https://mp.weixin.qq.com/s/qhyDj-0e9i-cJkLXXb1OnQ
https://blog.csdn.net/N71FS1/article/details/128049058