AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 633708
Accepted
Gregory MOUSSAT
Gregory MOUSSAT
Asked: 2014-10-06 12:39:15 +0800 CST2014-10-06 12:39:15 +0800 CST 2014-10-06 12:39:15 +0800 CST

rsyslog 配置语法

  • 772

我需要对一些日志消息采取一些措施。例如,我想根据严重性将它们记录到不同的文件中。

如果我使用这个,一切都很好:

if $programname == 'myprog'                                       then -/var/log/myprog.log
if $programname == 'myprog' and $syslogseverity-text >= 'warning' then -/var/log/myprog-alert.log
if $programname == 'myprog' ~

这将“myprog”发出的每条消息记录到 /var/log/myprog.log
这个日志只记录“myprog”发出的警告和错误消息到 -/var/log/myprog-alert.log
然后停止处理(谢谢到'〜')

.

我喜欢更性感的东西:

if $programname == 'myprog' then {
    *.*         -/var/log/myprog.log
    *.warning   -/var/log/myprog-alert.log
    ~
}

但是这个后来的构造,虽然被 rsyslog 接受,但不过滤程序名。
例如,即使来自任何进程,每条消息都会写入 /var/log/myprog.log。

.

任何人都可以解释我的错误或误解在哪里?

.

最终方法,来自以下答案:

使用“现代” rsyslogd。版本 > 7.xy
使用以下语法:

if $programname == 'myprog' then {
    *.warning   -/var/log/myprog-alert.log
    *.*         -/var/log/myprog.log
    *.*         stop
}

或者这个:

if $programname == 'myprog' then {
    *.warning   -/var/log/myprog-alert.log
                -/var/log/myprog.log
                stop
}
configuration
  • 2 2 个回答
  • 1890 Views

2 个回答

  • Voted
  1. djmitche
    2014-10-06T14:56:56+08:002014-10-06T14:56:56+08:00

    根据过滤器和RanierScript的 rsyslog 文档,不支持多行 { .. } 语法。Rsyslog 的解析器通常不会给出错误,宁愿忽略问题或以您不希望的方式解释它们。您的“性感”示例可能正在执行{与“myprog”匹配的事件的操作(我找不到这样的操作,所以我怀疑这意味着“什么都不做”)。第二行和第三行被视为传统风格的 syslog 配置,第四行和第五行是无效的(同样,可能“什么都不做”)

    • 2
  2. Best Answer
    Bertrand SCHITS
    2014-10-09T15:47:59+08:002014-10-09T15:47:59+08:00

    您的行仅包含 '~' 是错误的。它应该是“*.* ~”。

    我知道你主要使用 Debian stable。您的 rsyslog 版本是 5.xy,不接受 RanierScript。
    您可以更新到 backports 版本(当前为 7.6.3),然后您的第二个示例应该可以工作。

    • 2

相关问题

  • 小型企业的服务器虚拟化/RAID 配置

  • httpd.conf 用于不区分大小写的文件服务

  • Windows Server 2003 DNS 添加的 CNAME 不起作用

  • 我应该使用什么策略在 linux 上安装 smtp 服务器?用于多线程服务

  • 为什么我的站点在配置为直通身份验证时使用 IUSR 帐户?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve