sysRq键的使用方法

sysrq键简介sysrq键是一个魔术案件,只要在内核没有完全卡死的情况下,内核都会相应sysrq 键的输入,使用这些组合键都可以搜集包括系统内存使用、cpu任务处理、进程运行状态等系统运行信息。
配置内核配置选项中要使能config_magic_sysrq选项,这样系统启动之后,会生成/proc/sysrq-trigger节点用于调试。
修改/etc/sysctl.conf启动sysrq。
kernel.sysrq=1执行下列命令,使修改生效。
sysctl -p也可以通过写echo number >/proc/sys/kernel/sysrq节点临时使能sysrq功能。
写入不同的值使能不同的功能:
值描述/说明
0 完全禁用 sysrq
1 启用 sysrq 的所有功能
2 允许控制终端日志级别
4 允许控制终端日志级别
8 允许调试进程dump
16 允许执行sync命令
32 允许重新挂载文件系统为之读
64 允许发送信号给进程(term,kill,oom-kill)
128 允许重启/关机
256 允许调整实时任务的优先级
如何使用sysrqecho > /proc/sysrq-trigger命令键 是区分大小写的。
具体含义如下。
命令键功能
b 将立即重启系统,不会同步或者卸载磁盘。
c 将执行系统 crash,如果配置了系统 crashdump,将执行 crashdump。
d 显示所有持有的锁。
e 发送 sigterm 信号给所有进程,除了 init 进程。
f 将调用 oom killer 杀掉一个过度占用内存的进程,如果什么任务都没杀, 也不会 panic。
g kgdb 使用(内核调试器)。
h 将会显示帮助。(实际上除了这里列举的键,其他的都将显示帮助, 但是h容易记住):-)
i 发送 sigkill 给所有进程,除了 init 进程。
j 强制性的 “解冻它” - 用于被 fifreeze ioctl 操作冻住的文件系统。
k 安全访问秘钥(sak)杀掉在当前虚拟控制台的所有程序,注意:参考 下面 sak 节重要论述。
l 显示所有活动 cpu 的栈回溯。
m 将导出当前内存信息到你的控制台。
n 用于使所有实时任务变成普通任务。
o 将关闭系统(如果配置和支持的话)。
p 将导出当前寄存器和标志位到控制台。
q 将导出每个 cpu 上所有已装备的高精度定时器(不是完整的 time_list 文件显示的 timers)和所有时钟事件设备的详细信息。
r 关闭键盘的原始模式,设置为转换模式。
s 将尝试同步所有的已挂载文件系统。
t 将导出当前所有任务列表和它们的信息到控制台。
u 将尝试重新挂载已挂载文件系统为只读。
v 强制恢复帧缓存控制台。
v 触发 etm 缓存导出 [arm 架构特有]
w 导出处于不可中断状态(阻塞)的任务。
x 在 ppc/powerpc 架构上用于 xmon 接口。在 sparc64 架构上用于显示全局的 pmu(性能监控单元)寄存器。在 mips 架构上导出所有的 tlb 条目。
y 显示全局 cpu 寄存器 [sparc-64 架构特有]
z 导出 ftrace 缓存信息
0-9 设置控制台日志级别,该级别控制什么样的内核信息将被打印到你的 控制台。(比如0,将使得只有紧急信息,像 panics or oopses 才能到你的控制台。)
打印内存使用信息root@firefly:~# echo m > /proc/sysrq-trigger[ 3100.196187] sysrq: sysrq : show memory[ 3100.196675] mem-info:[ 3100.196931] active_anon:48062 inactive_anon:2987 isolated_anon:0[ 3100.196931] active_file:40449 inactive_file:53540 isolated_file:0[ 3100.196931] unevictable:0 dirty:22 writeback:0 unstable:0[ 3100.196931] slab_reclaimable:10518 slab_unreclaimable:6599[ 3100.196931] mapped:44843 shmem:3710 pagetables:1568 bounce:0[ 3100.196931] free:810482 free_pcp:497 free_cma:0[ 3100.199998] dma free:3241928kb min:7920kb low:9900kb high:11880kb active_anon:192248kb inactive_anon:11948kb active_file:161796kb inactive_file:214160kb unevictable:0kb isolated(anon):0kb isolated(file):0kb present:4030464kb managed:3933592kb mlocked:0kb dirty:88kb writeback:0kb mapped:179372kb shmem:14840kb slab_reclaimable:42072kb slab_unreclaimable:26396kb kernel_stack:5792kb pagetables:6272kb unstable:0kb bounce:0kb free_pcp:1988kb local_pcp:224kb free_cma:0kb writeback_tmp:0kb pages_scanned:0 all_unreclaimable? no[ 3100.204031] lowmem_reserve[]: 0 0 0[ 3100.204414] dma: 272*4kb (u) 95*8kb (um) 177*16kb (ume) 88*32kb (ume) 50*64kb (um) 32*128kb (um) 6*256kb (um) 4*512kb (um) 2*1024kb (m) 3*2048kb (ume) 785*4096kb (m) = 3241928kb[ 3100.206208] node 0 hugepages_total=0 hugepages_free=0 hugepages_surp=0 hugepages_size=2048kb[ 3100.206990] 97710 total pagecache pages[ 3100.207345] 0 pages in swap cache[ 3100.207679] swap cache stats: add 0, delete 0, find 0/0[ 3100.208156] free swap = 0kb[ 3100.208425] total swap = 0kb[ 3100.208721] 1007616 pages ram[ 3100.209003] 0 pages highmem/movableonly[ 3100.209352] 24218 pages reservedroot@firefly:~#打印进程列表root@firefly:~# echo t > /proc/sysrq-trigger[ 3357.426399] sysrq: sysrq : show state[ 3357.426902] call trace:[ 3357.427155] [] __switch_to+0x94/0xbc[ 3357.427759] [] __schedule+0x334/0x65c[ 3357.428249] [] schedule+0x70/0x84[ 3357.428762] [] schedule_hrtimeout_range_clock+0x54/0xd8[ 3357.429390] [] schedule_hrtimeout_range+0x38/0x48[ 3357.430004] [] sys_epoll_wait+0x2c0/0x334[ 3357.430515] [] sys_epoll_pwait+0xb4/0x104[ 3357.431057] [] el0_svc_naked+0x24/0x28[ 3357.431576] call trace:[ 3359.224688] runnable tasks:[ 3359.224688] task pid tree-key switches prio wait-time sum-exec sum-sleep[ 3359.224688] ----------------------------------------------------------------------------------------------------------[ 3359.226942] watchdog/5 31 -8.990375 842 0 0.010418 33.639974 0.011083 /[ 3359.227935] migration/5 32 0.000000 11 0 0.006417 0.703626 0.011083 /...............................[ 3359.280491] rsyslogd 620 12549.402602 31 120 3.959710 13.067249 3000146.370846 /[ 3359.281483] gmain 649 2780.837080 4 120 1.497875 0.234791 42.333083 /[ 3359.282473] gdbus 653 6084.558463 235 120 11.845505 88.143377 5894.875470 /[ 3359.283464] probing-thread 657 2798.851658 1 120 0.171209 0.046375 0.000000 /[ 3359.284458] gmain 666 13129.747017 842 120 1.635792 160.937875 ............................... [ 3359.347891] kbase_event 1087 5737.991190 2 100 0.000000 0.015416 0.022167 /[ 3359.348888] kworker/5:0 1415 12729.712418 6352 120 94.661328 379.266952 300531.917073 /[ 3359.349880] kworker/5:1 1421 13139.623478 4592 120 40.804756 269.058278 218093.165092 /[ 3359.350919]打印 cpu 信息root@firefly:~# echo w > /proc/sysrq-trigger[ 3461.098259] sysrq: sysrq : show blocked state[ 3461.099495] sched debug version: v0.11, 4.4.194+ #15[ 3461.099987] ktime : 3460974.551474[ 3461.100559] sched_clk : 3461099.486338[ 3461.101163] cpu_clk : 3461099.486629[ 3461.101733] jiffies : 4298128273[ 3461.102303] [ 3461.102457] sysctl_sched...............................[ 3461.106084] [ 3461.476753] task pid tree-key switches prio wait-time sum-exec sum-sleep[ 3461.476753] ----------------------------------------------------------------------------------------------------------[ 3461.479007] watchdog/5 31 -8.990375 868 0 0.010418 34.639809 0.011083 /[ 3461.479999] migration/5 32 0.000000 11 0 0.006417 0.703626 0.011083 /[ 3461.480990] ksoftirqd/5 33 12976.655002 282 120 31.262910 9.577926 3226896.156313 /....................[ 3461.598951] gdbus 981 5621.043245 63 120 10.429415 7.925751 240.024166 /[ 3461.599945] kbase_event 1087 5737.991190 2 100 0.000000 0.015416 0.022167 /[ 3461.600943] kworker/5:1 1421 13242.484431 6324 120 56.331917 371.919231 300578.331580 /[ 3461.601934] kworker/5:0 1424 13267.128801 416 120 3.932261 25.079662 19671.560460 /[ 3461.602964]显示所有活动 cpu 的栈回溯root@firefly:~# echo l > /proc/sysrq-trigger[ 3602.003162] sysrq: sysrq : show backtrace of all active cpus[ 3602.003919] call trace:[ 3602.004175] [] dump_backtrace+0x0/0x220root@firefly:~# [ 3602.004675] [] show_stack+0x24/0x30[ 3602.005233] [] showacpu+0x68/0x84[ 3602.005688] [] flush_smp_call_function_queue+0x84/0x134[ 3602.006303] [] generic_smp_call_function_single_interrupt+0x18/0x20[ 3602.007007] [] handle_ipi+0x19c/0x260[ 3602.007490] [] gic_handle_irq+0x12c/0x184[ 3602.007995] exception stack(0xffffffc0f2f1fd90 to 0xffffffc0f2f1fec0)[ 3602.008580] fd80: 0000000000000000 0000000000000003[ 3602.009284] fda0: 00000040ee976000 0000000000000020 00ffffffffffffff 0000001425865f85[ 3602.009988] fdc0: 000000000004b382 0000000000000003 00000032b5593519 ffffff8008081800[ 3602.010691] fde0: 0000000000001000 0000000000000000 0000000034d5d91d 00000040ee976000[ 3602.011394] fe00: ffffffc0f2f0a880 0000000000000000 0000000000000000 0000000000000000[ 3602.012098] fe20: 0000000030d00800 00000346a09ab464 0000000000000002 ffffffc00a4bac00[ 3602.012801] fe40: ffffff80097ace18 0000000000000001 0000034697fd8ddd ffffff800974e488[ 3602.013504] fe60: 0000000001ab4000 00000000010f8244 0000000000000000 ffffffc0f2f1fec0[ 3602.014209] fe80: ffffff8008b9eb10 ffffffc0f2f1fec0 ffffff8008b9eb14 0000000060000145[ 3602.014912] fea0: ffffffc0f2f1fec0 ffffff8008b9eb10 ffffffffffffffff 0000000000000002[ 3602.015615] [] el1_irq+0xb4/0x140[ 3602.016070] [] cpuidle_enter_state+0x1cc/0x25c[ 3602.016624] [] cpuidle_enter+0x34/0x44[ 3602.017112] [] call_cpuidle+0x6c/0x74[ 3602.017598] [] cpu_startup_entry+0x2ac/0x2bc[ 3602.018128] [] secondary_start_kernel+0x190/0x1bc[ 3602.018700] [] 0x10f8188触发 crashdumproot@firefly:~# echo c > /proc/sysrq-trigger[ 3635.905960] sysrq: sysrq : trigger a crash[ 3635.906476] unable to handle kernel null pointer dereference at virtual address 00000000[ 3635.907201] pgd = ffffffc0d4a3e000[ 3635.907640] [00000000] *pgd=0000000000000000, *pud=0000000000000000[ 3635.908305] internal error: oops: 96000045 [#1] smp..............................................................[ 3648.331820] exception stack(0xffffffc0cd8cbb30 to 0xffffffc0cd8cbc60)[ 3648.332405] bb20: ffffff800967ff68 0000008000000000[ 3648.333108] bb40: ffffffc0cd8cbd00 ffffff80085bb538 000000000000000f 0000000000000000[ 3648.333811] bb60: ffffff80097f72f8 0000000000000002 ffffffc0cd8cbb90 000000030003c018[ 3648.334514] bb80: 00000000000000c3 0000000100000000 ffffffc0cd8cbc30 ffffff800810d674[ 3648.335218] bba0: ffffffc0cd8cbc90 ffffff80092b55d1 ffffff80095fa000 0000000000000006[ 3648.335921] bbc0: 0000000000000063 0000000000000000 0000000000000001 0000000000000000[ 3648.336623] bbe0: ffffffc0f7ee8320 0000000000000000 0000000000000000 0000000000000000[ 3648.337327] bc00: 0000000000000010 ffffff800965ead8 ffffff8008478398 7f7f7f7f7f7f7f7f[ 3648.338029] bc20: 71277660716d73ff 7f7f7f7f7f7f7f7f 0101010101010101 0000000000000000[ 3648.338733] bc40: 0ffffffffffffffe 0000000000000000 ffffff80081e5cb8 0000007f8147b8c8[ 3648.339434] [] el1_da+0x24/0x8c[ 3648.339873] [] __handle_sysrq+0xa0/0x14c[ 3648.340379] [] write_sysrq_trigger+0x5c/0x74[ 3648.340911] [] proc_reg_write+0xa8/0xcc[ 3648.341406] [] __vfs_write+0x48/0xe8[ 3648.341877] [] vfs_write+0xa8/0x15c[ 3648.342338] [] sys_write+0x5c/0xb0[ 3648.342798] [] el0_svc_naked+0x24/0x28总结sysrq 在处理系统挂起时安全重启方面已经比较完善了。
https://blog.csdn.net/qtm_gitee/article/details/122929292
https://blog.csdn.net/weixin_42506599/article/details/108411139
https://www.codenong.com/cs106961584/
https://www.kernel.org/doc/html/latest/translations/zh_cn/admin-guide/sysrq.html?highlight=sysrq
https://blog.csdn.net/zhangzhi123456789/article/details/47088253
end

该如何看待工业机器人视觉市场
加州将立法要求自动驾驶车在2025年前实现零排放
嵌入式应用对微处理器的需求
18b20程序及应用
SIA:11月份全球半导体产品销售额仍在增长 达到394亿美元
sysRq键的使用方法
乐鑫打造智能语音设备开发平台 飞荣达荣登新兴产业“领航企业50强”
三星146英寸MicroLED电视9月开始量产,设备寿命将达到10万小时
ADI与现代汽车公司合作推出业界首个全数字路噪降噪系统
几个在工业领域数据驱动价值创造的案例
曝LG或发布至少6款手机于CES2017展会
波峰焊不良分析原因分析
完整的RFID系统是怎样的结构
小米6和荣耀9谁更好?凭心而论,我还是喜欢小米官网的客服妹子
特斯拉为Autopilot推出新功能“Navigate”
基于CNN的汽车视觉识别系统应用介绍
DP83TC811S-Q1的优点及在T-BOX的应用中的优势
河套IT TALK 67: (原创) 基于深度学习的超分技术(万字长文)
英特尔Mobileye始终如一 引领自动驾驶行业进行变革
基于AT89C51单片机的算术运算计算器系统设计