修改Linux kernel中打印的级别

有时调试内核模块,打印信息太多了,可以通过修改/proc/sys/kernel/printk文件内容来控制。
默认设置是7 4 1 7

# cat /proc/sys/kernel/printk

7 4 1 7
该文件有四个数字值,它们根据日志记录消息的重要性,定义将其发送到何处。关于不同日志级别的更多信息,请查阅syslog(2)联机帮助。上面显示的4个数据分别对应:
控制台日志级别:优先级高于该值的消息将被打印至控制台
默认的消息日志级别:将用该优先级来打印没有优先级的消息
最低的控制台日志级别:控制台日志级别可被设置的最小值(最高优先级)
默认的控制台日志级别:控制台日志级别的缺省值

数值越小,优先级越高
其实这四个值是在kernel/printk.c 中被定义的,如下:
int console_printk[4] = {
DEFAULT_CONSOLE_LOGLEVEL, /* console_loglevel */
DEFAULT_MESSAGE_LOGLEVEL, /* default_message_loglevel */
MINIMUM_CONSOLE_LOGLEVEL, /* minimum_console_loglevel */
DEFAULT_CONSOLE_LOGLEVEL, /* default_console_loglevel */
};
内核通过printk() 输出的信息具有日志级别,日志级别是通过在printk() 输出的字符串前加一个带尖括号的整数来控制的,如printk(“<6>Hello, world!\n”);。内核中共提供了八种不同的日志级别,在 linux/kernel.h 中有相应的宏对应。

#define KERN_EMERG  "<0>"   /* systemis unusable */
#define KERN_ALERT  "<1>"   /* actionmust be taken immediately */
#define KERN_CRIT    "<2>"   /*critical conditions */
#define KERN_ERR     "<3>"   /* errorconditions */
#define KERN_WARNING "<4>"   /* warning conditions */
#define KERN_NOTICE  "<5>"   /* normalbut significant */
#define KERN_INFO    "<6>"   /*informational */
#define KERN_DEBUG   "<7>"   /*debug-level messages */

所以printk() 可以这样用:printk(KERN_INFO”Hello, world!\n”);。
未指定日志级别的printk() 采用的默认级别是DEFAULT_MESSAGE_LOGLEVEL,这个宏在kernel/printk.c 中被定义为整数4,即对应KERN_WARNING。
如果要想在内核启动过程中打印少的信息,就可以根据自己的需要在kernel/printk.c中修改以上数值,重新编译即可!
/* printk’s without a loglevel use this.. */

#define DEFAULT_MESSAGE_LOGLEVEL 4 /* KERN_WARNING */

了解了上面的这些知识后,我们就应该知道如何手动控制printk打印了。例如,我想屏蔽掉所有的内核printk打印,那么我只需要把第一个数值调到最小值1或者0。

echo 1 4 1 7 > /proc/sys/kernel/printk

或者

echo 0 4 0 7 > /proc/sys/kernel/printk

一般情况下,只需要设置第一个值为4即可,如下:

echo 4 > /proc/sys/kernel/printk

(>与4中间有个空格)

   可通过读写/proc/sys/kernel/printk文件可读取和修改控制台的日志级别。查看这个文件的方法如下:

  #cat /proc/sys/kernel/printk 6 4 1 7
上面显示的4个数据分别对应控制台日志级别、默认的消息日志级别、最低的控制台日志级别和默认的控制台日志级别。
  可用下面的命令设置当前日志级别:
  # echo 8 > /proc/sys/kernel/printk
  这样所有级别<8,(0-7)的消息都可以显示在控制台上.

### 配置和查看Debug级别的日志 #### 修改rsyslog配置以启用调试级别日志 为了使Linux系统能够记录更详细的调试信息,在`/etc/rsyslog.conf`或其子目录下的`.conf`文件中添加如下行,这会使得特定设施(facility)的日志达到最低限度的debug等级[^1]: ```bash *.debug /var/log/debug.log ``` #### 调整systemd-journald的日志级别 对于采用Systemd作为初始化进程管理系统的情况,可以通过编辑`/etc/systemd/journald.conf`来改变全局日志水平。找到`[Journal]`部分并加入或修改以下选项以便开启更多细节化的日记条目[^2]: ```ini LogLevel=debug Storage=persistent # 确保存储持久化 MaxRetentionSec=infinity # 设置最大保留时间无限期 Compress=yes # 启用压缩功能减少磁盘占用空间 SyncIntervalSec=5m # 定义同步间隔为五分钟一次 RateLimitBurst=0 # 关闭速率限制机制允许无上限写入速度 ForwardToSyslog=no # 停止转发给传统syslog守护程序防止重复记录 ``` 完成更改后需重启journald服务: ```bash sudo systemctl restart systemd-journald.service ``` #### 查看当前内核消息输出级别以及调整之 利用`cat`命令读取位于`/proc/sys/kernel/printk`处的数据了解现有设定;而通过管道操作符配合`echo`与`tee`工具则能实现即时更新这些数值从而影响控制台可见度范围内的通知严重性阈值[^4]。 ```bash # 显示现有的printk参数 cat /proc/sys/kernel/printk # 更改console_loglevel至DEBUG (通常设为8),其他保持不变 echo "8 $(cat /proc/sys/kernel/printk | cut -d' ' -f2-)" | sudo tee /proc/sys/kernel/printk ``` 另外还可以借助于`dmesg`实用程序快速切换显示模式而不必永久改动任何东西: ```bash # 将控制台日志级别设置为debug,仅限本次会话有效 dmesg -n 8 ``` #### Nginx Debug Log Configuration 针对Web服务器如Nginx而言,则是在主配置文件里指定更高的错误报告标准,即把`error_log`指令里的第二个参数改为`debug_http`, `debug_stream` 或者其他的合法值取决于所需追踪的具体模块行为[^3]. ```nginx http { ... error_log /path/to/nginx_error.log debug; } ``` 之后记得重新加载Nginx使其生效. ```bash sudo nginx -s reload ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值