0

0

大量 sudo session 日志刷屏的 pam_limits 与 rsyslog 限流方案

舞夢輝影

舞夢輝影

发布时间:2026-01-22 09:17:09

|

909人浏览过

|

来源于php中文网

原创

应关闭 pam_limits.so 的 debug 日志并为 rsyslog 添加速率限制;具体操作是删除 /etc/pam.d/sudo 等文件中的 debug 参数,并在 /etc/rsyslog.d/ 中配置 omrate limit 规则。

大量 sudo session 日志刷屏的 pam_limits 与 rsyslog 限流方案

大量 sudo session 日志刷屏,通常是 pam_limits.so 模块在每次 sudo 执行时反复写入 syslog(如 rsyslog)导致的,尤其在脚本高频调用 sudo 或容器环境里特别明显。根本原因不是日志级别设太高,而是 PAM 模块默认开启 debug 日志且缺乏限流机制。解决方向有两个:一是关闭 pam_limits 的冗余日志,二是对 rsyslog 中相关日志做速率限制。

关闭 pam_limits 的 debug 日志输出

pam_limits.so 默认启用 debug 选项时,会为每次会话打印类似 pam_limits(limit): 'nofile' set to 1024 soft, 65536 hard 的日志。只要它出现在 /etc/pam.d/sudo/etc/pam.d/common-session 中并带 debug,就会持续刷屏。

  • 检查 PAM 配置文件中是否含 debug:运行 grep -r "pam_limits.*debug" /etc/pam.d/
  • 若存在,编辑对应文件(如 /etc/pam.d/sudo),将 required pam_limits.so debug 改为 required pam_limits.so(删掉 debug
  • 无需重启服务,PAM 配置热生效;sudo 下次执行即不再输出该类日志

在 rsyslog 中对 pam_limits 日志限流

即使关掉 debug,某些系统版本或定制模块仍可能输出 info 级别的 limits 日志。这时可在 rsyslog 层做速率控制,避免打满磁盘或干扰其他日志。

飞笔AI
飞笔AI

飞笔AI致力于创作高质量的海报等图像,满足用户个性化设计需求。用户可通过平台便捷地创建各种风格和主题的海报、新媒体素材图等。

下载
  • 新建限流规则文件:/etc/rsyslog.d/50-pam-limits-limit.conf
  • 写入以下内容(以每分钟最多 5 条为例):
    if $programname == 'sudo' and $msg contains 'pam_limits' then {
      :msg, contains, "pam_limits" stop
    }
    if $programname == 'sudo' and $msg contains 'pam_limits' then {
      action(type="omrate limit" 
             rule="pam_limits_limit" 
             burst="5" 
             interval="60")
      action(type="omfile" file="/var/log/sudo-pam-limits.log")
    }
  • 重启 rsyslog:systemctl restart rsyslog
  • 注意:omrate limit 是 rsyslog v8.1901+ 原生支持的模块,旧版本需启用 imuxsock 并配置 $SystemLogRateLimitInterval 全局限流,但粒度较粗

补充建议:检查是否误启了 multiple pam_limits 行

同一 PAM 配置中多次加载 pam_limits.so(例如在 common-sessionsudo 中都存在),会导致日志翻倍。建议统一收敛到一处,并确保无重复或冲突参数。

  • 运行 grep -r "pam_limits.so" /etc/pam.d/ 查看所有加载点
  • 确认 /etc/security/limits.conf/etc/security/limits.d/*.conf 是否有异常配置(如通配符或空行引发重复解析)
  • 临时测试可注释非必要位置的 pam_limits.so 行,观察日志是否减少

不复杂但容易忽略。核心就是两步:去掉 PAM 里的 debug,再给 rsyslog 加个节流阀。多数场景下,第一项就足够解决问题。

相关专题

更多
session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

314

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

741

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

88

2025.08.19

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

37

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

18

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

233

2026.01.21

妖精漫画入口地址合集
妖精漫画入口地址合集

本专题整合了妖精漫画入口地址合集,阅读专题下面的文章了解更多详细内容。

61

2026.01.21

java版本选择建议
java版本选择建议

本专题整合了java版本相关合集,阅读专题下面的文章了解更多详细内容。

3

2026.01.21

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

14

2026.01.21

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Laravel 5.8 中文文档手册
Laravel 5.8 中文文档手册

共74课时 | 86.3万人学习

SESSION实现登录与验证
SESSION实现登录与验证

共10课时 | 9.7万人学习

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

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