日志服务部署

在 Linux 环境中,将多台服务器的日志汇总到一台日志服务器,核心是通过 rsyslog 或 syslog-ng 实现日志的集中采集与存储,这种架构适合运维人员统一监控多台服务器的网络、系统、应用日志。

一、架构说明

  • 日志服务器:一台固定 IP 的服务器,负责接收并存储所有客户端服务器的日志。
  • 客户端服务器 :多台需要上传日志的服务器,配置 rsyslog 将日志转发到日志服务器。
  • 传输协议 :默认使用 UDP 514 (轻量、高效),若需确保日志不丢失,可使用 TCP 514(可靠传输)。

二、配置日志服务器(接收端)

1.编辑 rsyslog 主配置文件

bash 复制代码
vi /etc/rsyslog.conf

2.启用 UDP/TCP 监听模块

取消以下配置的注释(根据需求选择协议):

bash 复制代码
# 启用 UDP 监听(推荐,轻量)
module(load="imudp")
input(type="imudp" port="514")

# (可选)启用 TCP 监听(可靠,适合重要日志)
module(load="imtcp")
input(type="imtcp" port="514")

3.配置日志分类存储规则

为了区分不同客户端的日志,按客户端 IP日志类型 划分存储路径,添加以下配置:

bash 复制代码
# 规则1:按客户端 IP 分类存储(所有日志)
$template RemoteLog,"/var/log/remote/%FROMHOST-IP%/%PROGRAMNAME%.log"
*.* ?RemoteLog

# 规则2:单独存储 SSH 日志(来自所有客户端)
auth.* /var/log/remote/ssh-all.log

%FROMHOST-IP%:客户端服务器的 IP 地址。

%PROGRAMNAME%:产生日志的程序名(如 sshd、nginx)。

$template:定义日志存储的模板路径。

4.创建日志存储目录并设置权限

bash 复制代码
mkdir -p /var/log/remote
chown root:root /var/log/remote
chmod 700 /var/log/remote # 限制权限,防止敏感日志泄露

5.重启 rsyslog 服务生效

bash 复制代码
systemctl restart rsyslog
systemctl enable rsyslog

# 检查监听端口是否生效
ss -unlp | grep 514 # 查看 UDP 514
ss -tnlp | grep 514 # 查看 TCP 514

三、配置客户端服务器(发送端)

1.编辑客户端 rsyslog 配置文件

bash 复制代码
vi /etc/rsyslog.conf

2.添加日志转发规则

在文件末尾添加以下内容,替换 <日志服务器IP> 为实际 IP

bash 复制代码
# 方案1:转发所有日志到日志服务器(UDP)
*.* @<日志服务器IP>:514

# 方案2:转发所有日志到日志服务器(TCP,可靠传输)
# *.* @@<日志服务器IP>:514

# 方案3:只转发指定类型日志(如 SSH+防火墙日志)
# auth.*;kern.* @<日志服务器IP>:514

3.重启客户端 rsyslog 服务

bash 复制代码
systemctl restart rsyslog

四、验证配置是否生效

1.在客户端触发日志生成

bash 复制代码
# 执行 SSH 登录操作,生成 auth 日志
ssh root@localhost

# 或手动生成测试日志
logger -p auth.info "Test remote log from $(hostname -I)"

2.在日志服务器查看接收的日志

bash 复制代码
# 查看按 IP 分类的日志
ls /var/log/remote/

# 实时查看客户端日志
tail -f /var/log/remote/<客户端IP>/sshd.log

# 查看所有客户端的 SSH 汇总日志
tail -f /var/log/remote/ssh-all.log
相关推荐
乌托邦的逃亡者12 分钟前
CentOS/Openeuler主机中,为一个网卡设置多个IP地址
linux·运维·网络·tcp/ip·centos
拾贰_C1 小时前
【OpenClaw | openai | QQ】 配置QQ qot机器人
运维·人工智能·ubuntu·面试·prompt
桌面运维家1 小时前
服务器进程异常监控:快速定位与排障实战指南
运维·服务器
@CLoudbays_Martin111 小时前
UniApp是否能够接入SDK游戏盾呢?
服务器·网络·网络协议·tcp/ip·安全
风曦Kisaki1 小时前
# Linux Shell 编程入门 Day02:条件测试、if 判断、循环与随机数
linux·运维·chrome
木雷坞2 小时前
视觉算法环境 Docker 镜像拉取失败排查
运维·人工智能·docker·容器
郝亚军2 小时前
ubuntu 22.04如何安装libmodbus
运维·服务器·ubuntu
李日灐2 小时前
< 6 > Linux 自动化构建工具:makefile 详解 + 进度条实战小项目
linux·运维·服务器·后端·自动化·进度条·makefile
JZC_xiaozhong2 小时前
跨系统审批自动化怎么做?从采购到销售合同的完整方案
大数据·运维·自动化·流程自动化·数据集成与应用集成·业务流程管理·异构数据集成
计算机安禾2 小时前
【Linux从入门到精通】第34篇:搭建FTP与Samba——跨平台文件共享解决方案
linux·运维·服务器