如何通过Rsyslog在Linux系统中设置日志颜色优先级,以支持实时巡检辅助?

2026-05-07 19:251阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计961个文字,预计阅读时间需要4分钟。

如何通过Rsyslog在Linux系统中设置日志颜色优先级,以支持实时巡检辅助?

Rsyslog 本身不支持日志颜色显示,它是一个系统级的日志守护进程,负责接收、过滤、路由和记录日志。它不负责终端的渲染。

要实现人工在线实时巡检时按优先级看到不同颜色的功能,关键不在 rsyslog 的配置,而在于日志消耗端的着色方案。

以下是一个基于日志消耗端着色方案的示例:

cczegrc 实时着色标准日志流

这是最轻量、最贴近你需求的做法:保持 rsyslog 原样工作(例如把日志写入 /var/log/messages),再用着色工具包装 tail -f 输出。

  • 安装 ccze:sudo apt install ccze(Debian/Ubuntu)或 sudo yum install ccze(RHEL/CentOS)
  • 实时查看并着色:sudo tail -f /var/log/messages | ccze -A
  • ccze 默认识别 emergalertcriterrwarningnotice 等 syslog 优先级,并映射为红、橙、黄、粉等高对比颜色
  • -A 参数启用 ANSI 转义序列,确保颜色生效;可配合 -x(禁用插件)或自定义配置文件增强匹配精度

systemd-journald + journalctl --no-pager(推荐替代方案)

如果你的系统已启用 systemd(现代 Linux 发行版默认),journald 原生支持结构化日志和优先级着色,无需额外工具:

  • journalctl -f -p err 实时跟踪错误及以上级别(自动红色高亮)
  • journalctl -f 默认就对 emerg(红底白字)、alert(红)、crit(亮红)、err(红)、warning(黄)等做 ANSI 着色
  • 颜色行为由 SYSTEMD_COLORS=1 环境变量控制,通常已启用;若失效可显式运行:SYSTEMD_COLORS=1 journalctl -f
  • 相比传统 rsyslog + 文件,journald 更易过滤(-t sshd-u nginx.service)、支持 JSON 输出、且默认启用日志压缩与轮转

在 rsyslog 中添加标记便于下游着色(进阶适配)

若必须保留 rsyslog 并对接自定义着色脚本(如 awk + echo -e),可在日志行开头注入可识别的前缀:

  • 编辑 /etc/rsyslog.conf/etc/rsyslog.d/50-custom.conf
  • 添加模板,把 priority 名称嵌入日志内容:template(name="ColoredPrefix" type="string" string="%timestamp% %hostname% %syslogtag%%msg%\n")
  • 更实用的是用 property 替换器提取 priority 名称:template(name="PriorityTagged" type="string" string="%timestamp% [%pri-text%] %hostname% %syslogtag%%msg%\n")
  • 然后在输出规则中使用该模板:*.* /var/log/colored.log;PriorityTagged
  • 后续可用 tail -f /var/log/colored.log | awk '/\[emerg\]/ {print "\033[41;37m" $0 "\033[0m"; next} ...' 实现简单着色(但不如 ccze 稳定)

避免常见误区

不要尝试让 rsyslog 直接输出 ANSI 转义码到文件——这会污染日志内容,破坏后续 grep、logrotate、ELK 等工具解析;也不要修改 /etc/issue 或 shell 提示符来“模拟”日志颜色。颜色必须发生在“人眼看到之前最后一环”,即终端渲染阶段。

标签:Linux

本文共计961个文字,预计阅读时间需要4分钟。

如何通过Rsyslog在Linux系统中设置日志颜色优先级,以支持实时巡检辅助?

Rsyslog 本身不支持日志颜色显示,它是一个系统级的日志守护进程,负责接收、过滤、路由和记录日志。它不负责终端的渲染。

要实现人工在线实时巡检时按优先级看到不同颜色的功能,关键不在 rsyslog 的配置,而在于日志消耗端的着色方案。

以下是一个基于日志消耗端着色方案的示例:

cczegrc 实时着色标准日志流

这是最轻量、最贴近你需求的做法:保持 rsyslog 原样工作(例如把日志写入 /var/log/messages),再用着色工具包装 tail -f 输出。

  • 安装 ccze:sudo apt install ccze(Debian/Ubuntu)或 sudo yum install ccze(RHEL/CentOS)
  • 实时查看并着色:sudo tail -f /var/log/messages | ccze -A
  • ccze 默认识别 emergalertcriterrwarningnotice 等 syslog 优先级,并映射为红、橙、黄、粉等高对比颜色
  • -A 参数启用 ANSI 转义序列,确保颜色生效;可配合 -x(禁用插件)或自定义配置文件增强匹配精度

systemd-journald + journalctl --no-pager(推荐替代方案)

如果你的系统已启用 systemd(现代 Linux 发行版默认),journald 原生支持结构化日志和优先级着色,无需额外工具:

  • journalctl -f -p err 实时跟踪错误及以上级别(自动红色高亮)
  • journalctl -f 默认就对 emerg(红底白字)、alert(红)、crit(亮红)、err(红)、warning(黄)等做 ANSI 着色
  • 颜色行为由 SYSTEMD_COLORS=1 环境变量控制,通常已启用;若失效可显式运行:SYSTEMD_COLORS=1 journalctl -f
  • 相比传统 rsyslog + 文件,journald 更易过滤(-t sshd-u nginx.service)、支持 JSON 输出、且默认启用日志压缩与轮转

在 rsyslog 中添加标记便于下游着色(进阶适配)

若必须保留 rsyslog 并对接自定义着色脚本(如 awk + echo -e),可在日志行开头注入可识别的前缀:

  • 编辑 /etc/rsyslog.conf/etc/rsyslog.d/50-custom.conf
  • 添加模板,把 priority 名称嵌入日志内容:template(name="ColoredPrefix" type="string" string="%timestamp% %hostname% %syslogtag%%msg%\n")
  • 更实用的是用 property 替换器提取 priority 名称:template(name="PriorityTagged" type="string" string="%timestamp% [%pri-text%] %hostname% %syslogtag%%msg%\n")
  • 然后在输出规则中使用该模板:*.* /var/log/colored.log;PriorityTagged
  • 后续可用 tail -f /var/log/colored.log | awk '/\[emerg\]/ {print "\033[41;37m" $0 "\033[0m"; next} ...' 实现简单着色(但不如 ccze 稳定)

避免常见误区

不要尝试让 rsyslog 直接输出 ANSI 转义码到文件——这会污染日志内容,破坏后续 grep、logrotate、ELK 等工具解析;也不要修改 /etc/issue 或 shell 提示符来“模拟”日志颜色。颜色必须发生在“人眼看到之前最后一环”,即终端渲染阶段。

标签:Linux