PrtSc
同键,通过按下ALT+SysRq+<command key>
可以直接向 linux kernel 发送预设的系统操作指令。 这套组合键提供了一系列在系统崩溃时常用到的功能,比如同步数据、杀进程、卸载文件系统,甚至系统重启。启用 SysRq
的前提是在 linux kernel 编译时启用了 CONFIG_MAGIC_SYSRQ
选项,在目前主流的发行版 linux 中都启用了该选项,但若你是自己编译的内核,则有必要搜索一下内核的 config 文件了,确保里面有一句
CONFIG_MAGIC_SYSRQ=y
内核中还有一个与 SysRq 相关的配置项:
CONFIG_MAGIC_SYSRQ_DEFAULT_ENABLE=0x01b6
这个配置项指定了默认SysRq的值,这个值表示kernel会对哪些功能产生反应。
我们可以通过查看 /proc/sys/kernel/sysrq
的值来判断 Kernel 会对哪些功能产生反应。
cat /proc/sys/kernel/sysrq
16
这里你会看到一个数字,这个数字可以转换成一个9位比特的形式,其中每一位的比特都有一个含义如下:
因此,我这里的 16
表示允许通过 SysRq 来同步数据到磁盘中去, 而数字 130
转换成二进制就是 010000010
,根据表中的对应关系很容易看出允许重启/关机以及调整终端日志级别。
如果只是希望临时更改 SysRq
的值,那么很简单,只需要将新的值写入到 /proc/sys/kernel/sysrq
中去
echo "1" |sudo tee /proc/sys/kernel/sysrq
或者通过 sysctl
来进行设置
sysctl -w kernel.sysrq=1
如果需要每次启动时都自动修改 SysRq 的值,则需要修改配置文件
echo "kernel.sysrq = 1"|sudo tee -a /etc/sysctl.conf
使用 SysRq 有两种方式:一种是直接通过键盘 Alt+SysRq+<command key>(部分笔记本上是Alt+Fn+PrtSrc+<command key>)
来出发,还有一种是直接通过 /proc/sysrq-trigger
接口来完成.
echo “ b ” |sudo tee /proc/sysrq-trigger
其中,这里每个 command-key
都对应一种kernel的行为,而且需要说明的是,不同种类的键盘上,相同kernel行为对应的 command-key
居然是不同的!
下面表格就是各个kernel行为对应的 command-key
的说明:
下面列出几个常见的功能键组合:
这套组合键大致相当于 reboot 命令:
若仅仅是因为资源消耗过量引起系统挂起就重启系统显然是不好的,我们可以尝试通过回收一些资源的方式来回复系统挂起。
SysRq 中用来结束进程的 command-key 包括 E-I-K-F,其中:
此外,若系统挂起是由于实时任务消耗太多CPU引起的,则可以通过 N
来降低实时任务运行的优先级来缓解挂起症状。
SysRq还提供了几个用于获取系统信息的commandkey,在恢复系统挂起前推荐执行这些 commandkey,以记录下当前系统状态。
从上面的列表中我们可以看到,使用SysRq能够输出大量的信息。这些信息,默认会输出到syslog中. 同时,若设置的 console_loglevel(0-9)
大于 default_message_loglevel
则输出也会输出到本地控制台终端上去。 另外,若设置的 console_loglevel
大于 default_message_loglvel
则输出还会通过netconsole输出到远程机器上去。
总体来说,syslog 中记录的日志应该是最完整的,然而由于负责记录日志的 syslogd
本身是一个用户进程,在某些情况下可能会被杀掉,从而导致日志记录不下来。
echo " "|sudo tee /proc/sysrq-triggerdmesg |tail -n 1
[17899.255261] sysrq: SysRq : HELP : loglevel(0-9) reboot(b) crash(c)
terminate-all-tasks(e) memory-full-oom-kill(f) kill-all-tasks(i)
thaw-filesystems(j) sak(k) show-backtrace-all-active-cpus(l)
show-memory-usage(m) nice-all-RT-tasks(n) poweroff(o) show-registers(p)
show-all-timers(q) unraw(r) sync(s) show-task-states(t) unmount(u)
force-fb(V) show-blocked-tasks(w) dump-ftrace-buffer(z)