0

0

Linux如何配置Rsyslog服务器_Linux日志集中收集与存储【运维】

尼克

尼克

发布时间:2026-01-11 06:51:33

|

507人浏览过

|

来源于php中文网

原创

在Linux中搭建Rsyslog服务器需五步:一、安装并启用服务;二、配置UDP/TCP监听端口;三、定义远程日志接收规则与模板;四、防火墙放行514端口;五、验证接收能力。

linux如何配置rsyslog服务器_linux日志集中收集与存储【运维】

如果您需要在Linux系统中搭建Rsyslog服务器以实现日志的集中收集与存储,则需对Rsyslog服务进行针对性配置,使其能够接收来自远程客户端的日志消息并写入指定文件或数据库。以下是具体配置步骤:

一、安装并启用Rsyslog服务

Rsyslog通常预装于多数主流Linux发行版中,但需确认其已安装并处于运行状态,同时设置开机自启以保障服务持续可用。

1、执行命令检查Rsyslog是否已安装:rpm -q rsyslog(CentOS/RHEL)或dpkg -l | grep rsyslog(Debian/Ubuntu)。

2、若未安装,使用包管理器安装:yum install rsyslog(CentOS 7及更早)或dnf install rsyslog(CentOS 8+/RHEL 8+),Debian系使用apt install rsyslog

3、启动服务并设为开机自启:systemctl start rsyslogsystemctl enable rsyslog

二、配置Rsyslog监听UDP/TCP端口

Rsyslog默认不监听网络连接,需修改主配置文件启用UDP和/或TCP输入模块,使服务器可接收远程日志。UDP轻量但不可靠,TCP提供传输保障,建议生产环境启用TCP。

1、编辑主配置文件:vi /etc/rsyslog.conf 或使用现代模块化配置路径中的文件(如/etc/rsyslog.d/50-default.conf)。

2、取消以下两行的注释(删除开头的#号)以启用UDP监听:$ModLoad imudp$UDPServerRun 514

3、如需启用TCP支持,取消以下两行注释:$ModLoad imtcp$InputTCPServerRun 514

4、保存文件后重启服务:systemctl restart rsyslog

三、定义远程日志接收规则

为区分不同客户端的日志,需在配置中添加模板与接收规则,将日志按主机名或IP地址归类存储到独立文件中,避免混杂。

1、在/etc/rsyslog.d/目录下新建配置文件,例如:vi /etc/rsyslog.d/30-remote.conf

FreeTTS
FreeTTS

FreeTTS是一个免费开源的在线文本到语音生成解决方案,可以将文本转换成MP3,

下载

2、插入模板定义,用于生成带主机名的路径:$template RemoteLogs,"/var/log/remote/%HOSTNAME%/%$YEAR%-%$MONTH%-%$DAY%.log"

3、添加规则,将所有来自UDP/TCP的*.*日志应用该模板:*.* ?RemoteLogs

4、确保目录存在且rsyslog有写入权限:mkdir -p /var/log/remotechown -R syslog:syslog /var/log/remote(Debian/Ubuntu)或 chown -R root:root /var/log/remote(RHEL/CentOS)。

四、配置防火墙放行日志端口

若系统启用firewalld或iptables,必须显式允许UDP 514和/或TCP 514端口通信,否则远程日志无法到达Rsyslog进程。

1、对于firewalld(RHEL/CentOS 7+、Fedora):firewall-cmd --permanent --add-port=514/udpfirewall-cmd --permanent --add-port=514/tcp

2、重载防火墙规则:firewall-cmd --reload

3、对于iptables(传统方式),追加规则:iptables -A INPUT -p udp --dport 514 -j ACCEPTiptables -A INPUT -p tcp --dport 514 -j ACCEPT,并保存规则。

五、验证Rsyslog服务器接收能力

在完成上述配置后,需通过本地模拟或真实客户端发送测试日志,确认服务端能正确接收并落盘,排除配置语法错误或端口阻塞问题。

1、使用logger命令本地模拟远程日志(强制指定源主机):logger -d -n 127.0.0.1 -P 514 "Test log from localhost"

2、查看对应主机日志文件是否生成:tail -f /var/log/remote/localhost/$(date +%Y-%m-%d).log

3、使用netstat或ss确认端口监听状态:ss -tuln | grep :514,应显示0.0.0.0:514或[::]:514处于LISTEN状态。

相关专题

更多
default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

219

2023.12.07

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

180

2023.11.24

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

343

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2072

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

346

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

253

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

322

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

408

2023.10.16

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

80

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7万人学习

Git 教程
Git 教程

共21课时 | 2.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号