0

0

大量 sudo: pam_unix session opened 日志刷屏的限流方案

舞姬之光

舞姬之光

发布时间:2026-01-25 17:37:02

|

856人浏览过

|

来源于php中文网

原创

sudo 高频触发 pam_unix(session opened) 日志是正常行为,源于 PAM 模块默认记录 session 开启事件;主因是自动化工具频繁调用 sudo -n 探测权限,推荐通过 rsyslog ratelimit 按 authpriv 和消息内容限流,同时排查并修复调用源头。

大量 sudo: pam_unix session opened 日志刷屏的限流方案

为什么 sudo 会高频触发 pam_unix(session opened) 日志

这不是异常,而是 pam_unix 模块在每次成功执行 sudo 命令时的默认行为——它会调用 pam_syslog() 记录 session 开启事件。当有自动化脚本、监控工具(如 Zabbix、Prometheus node_exporter)、或定时任务频繁调用 sudo -n 做权限探测时,日志就刷屏了。

关键点在于:这些日志级别是 LOG_INFO,且由 PAM 子系统生成,rsyslogjournalctl 本身无法在接收前过滤(因为 PAM 在用户空间写入 /dev/log,早于 rsyslog 规则匹配)。

  • 不建议直接关闭 pam_unix.so 的 session 模块(影响 audit 和登录审计)
  • sudoers 中的 NOLOG 标签只抑制 sudo 自身日志,对 PAM session 日志无效
  • 修改 /etc/pam.d/sudo 注释掉 session [default=ignore] 行会导致 loginuid 丢失,影响 auditd 追踪

在 rsyslog 中按模块+消息内容限流(推荐)

rsyslog v8.33+ 支持 ratelimit 模块,可针对特定 facility+priority+msg 正则做速率控制。PAM 日志通常走 authpriv.*,消息体含 "pam_unix\(session opened"

/etc/rsyslog.d/10-pam-limit.conf 中添加:

module(load="imuxsock" ratelimit.interval="60" ratelimit.burst="5")
if $syslogfacility-text == 'authpriv' and $msg contains 'pam_unix(session opened' then {
  action(type="omfile" file="/var/log/auth.log" ratelimit.interval="60" ratelimit.burst="5")
  stop
}
  • ratelimit.interval="60" 表示每 60 秒窗口
  • ratelimit.burst="5" 表示最多放行 5 条匹配日志,超出丢弃
  • 必须加 stop,否则日志仍会落入默认 auth.log 流程
  • 注意:该规则需放在默认日志规则(如 *.* /var/log/syslog)之前才生效

用 systemd-journald 的 rate-limit 配置全局压制

如果用 journald 为主日志后端(如 Ubuntu 20.04+/RHEL 8+),可在 /etc/systemd/journald.conf 中启用内建限流:

Miniflow
Miniflow

AI工作流自动化平台

下载
RateLimitIntervalSec=30s
RateLimitBurst=10

但这会影响所有 journal 日志源,不够精准。更稳妥的做法是结合 journalctl 过滤 + 外部限流:

  • journalctl -o json --no-tail -u systemd-journald | jq -r 'select(.SYSLOG_IDENTIFIER=="sudo" and .MESSAGE | contains("session opened"))' 抽取原始事件
  • awkccze 做时间窗口计数并丢弃超量条目(适合调试,不建议生产常驻)
  • 真正要压住量,还是得回到 rsyslog 的模块级限流,它发生在日志写入磁盘前,开销最低

排查源头比压制日志更重要

日志刷屏本质是上游行为异常。先确认谁在高频调用 sudo

  • 运行 sudo journalctl -o short-iso _COMM=sudo --since "1 hour ago" | wc -l 看总量
  • 查调用者:sudo journalctl -o json _COMM=sudo --since "10 minutes ago" | jq -r '.SYSLOG_IDENTIFIER + " " + ._CMDLINE'
  • 常见元凶:check_mkcheck_sudo 插件、zabbix-agentsystem.run[sudo ...]、或自定义 health-check 脚本里没加 sleep
  • 修复建议:改用 getent group sudo | grep -q $USER 替代 sudo -n true 探测权限;或把探测周期从 10s 拉长到 5m

限流只是兜底手段。一旦 sudo 调用量突增,往往意味着某个服务配置错、脚本死循环,或权限模型被绕过——这时候盯着日志数量,比调 ratelimit.burst 更有用。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

417

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

535

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

76

2025.09.10

session失效的原因
session失效的原因

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

315

2023.10.17

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

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

747

2023.10.18

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

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

88

2025.08.19

default gateway怎么配置
default gateway怎么配置

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

220

2023.12.07

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

58

2026.01.23

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.5万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

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

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