出现 “dmesg: read kernel buffer failed: Operation not permitted” 错误通常是因为当前用户没有权限读取内核日志缓冲区

这可以通过修改内核参数 kernel.dmesg_restrict 来解决。

你可以尝试以下命令来允许非特权用户读取内核日志:

sudo sysctl -w kernel.dmesg_restrict=0

这个命令会临时修改系统设置,允许当前用户访问 dmesg。如果你想让这个设置在系统重启后依然有效,你可以将这个参数添加到 /etc/sysctl.conf 文件中:

echo "kernel.dmesg_restrict = 0" | sudo tee -a /etc/sysctl.conf >/dev/null

或者,如果你的系统使用的是 /etc/sysctl.d/ 目录来管理额外的 sysctl 配置,你可以创建一个新的配置文件或者编辑现有的文件:

echo "kernel.dmesg_restrict = 0" | sudo tee -a /etc/sysctl.d/99-sysctl.conf >/dev/null

请注意,修改这个设置可能会有安全方面的影响,因为它允许非特权用户查看可能包含敏感信息的内核日志。在某些系统上,这个设置可能已经存在于 /etc/sysctl.d/10-kernel-hardening.conf 文件中,你可以编辑这个文件来更改设置。

如果你需要清除内核日志缓冲区,可以使用以下命令:

sudo dmesg -c

这个命令需要 root 权限,因为它会清除所有用户可见的日志信息。如果你只是想查看日志而不是清除它,你可以简单地运行:

dmesg

如果你的系统上 dmesg 命令仍然不可用,你可能需要检查你的用户是否在允许使用 dmesg 的用户组中,或者查看是否有其他系统策略限制了这个命令的使用。

最后谢谢阅读,笔者记录工作中的问题,如有错误之处还请指正。

Logo

有“AI”的1024 = 2048,欢迎大家加入2048 AI社区

更多推荐