SysRq
SysRq или SysReq (сокращение от англ. System Request) — клавиша на клавиатуре для IBM PC-совместимого компьютера, появившаяся впервые в PC/AT и не имеющая стандартного назначения[1][2]. Изначально появилась на клавиатуре терминалов типа IBM 3270 для мейнфрейма IBM System/370, где использовалась для переключения ввода напрямую в ОС VM/370 или MVS.
В современных операционных системах может быть включена для специального использования. В 84-кнопочной версии клавиатуры IBM PC/AT SysRq была отдельной клавишей, в современных клавиатурах она совмещена с клавишей Print Screen.
История
[править | править код]84-я клавиша, SysRq,[3] была добавлена IBM в клавиатуру для IBM PC/AT для того, чтобы можно было вызывать низкоуровневые функции операционной системы без риска конфликта с любым существовавшим программным обеспечением. Было добавлено программное прерывание BIOS номер 0x15, подфункция 0x85[4][5], которое сообщало ОС о нажатии или отпускании клавиши SysRq. В отличие от большинства клавиш, нажатие SysRq не добавляло чего-либо в буфер клавиатуры[англ.].
Низкоуровневая реализация SysRq, вероятно, планировалась для переключения между операционными системами. Так, во время создания первых IBM-PC в 1980-х на них широко использовались три системы: PC DOS, CP/M-86 и UCSD p-System,[6] а в 1983—1984 появилась Xenix.
Специальная клавиша была создана, чтобы обойти различные низкоуровневые TSR-программы, работавшие с клавиатурой в обход ОС, например, для реализации горячих клавиш.
Применение
[править | править код]В ОС Windows SysRq, нажатая вместе с Alt (то есть PrtScr), копирует изображение активного окна в буфер обмена.
Компания Microsoft иногда использовала SysRq для различных отладчиков, как уровня ОС, так и уровня приложения. Некоторые версии отладчика CodeView использовали клавишу для прерывания программы во время исполнения и переключения в отладочный интерфейс.[7] Удаленный отладчик ядра Windows NT использовал последовательность нажатий Ctrl+SysRq, Ctrl+SysRq для включения отладочного режима.[8]
В ПК Hyundai/Hynix Super-16 нажатие Ctrl+SysRq приводит к холодной перезагрузке, в том числе, когда Ctrl+Alt+Del уже не работает.
Во встраиваемых системах изредка SysRq переключает сигнал RESET# в нижний уровень.[9]
SysRq в UNIX/Linux
[править | править код]Клавиша SysRq — единственная прямая связь с ядром, которая работает всегда, если работает ядро, так как соответствующие комбинации напрямую перехватываются ядром и соответствующий код является частью драйвера клавиатуры (см. Magic SysRq key[англ.]). При помощи некоторых комбинаций клавиш можно заставить систему аварийно сбросить данные на диски, перемонтировать все файловые системы в режим «только чтение», перезагрузиться или перезапустить графическую подсистему даже при зависшей системе.
Использование
[править | править код]Сначала нужно убедиться, что использование клавиши включено: в конфигурации ядра CONFIG_MAGIC_SYSRQ должно иметь значение Y (например, в ядре, используемом в Debian по умолчанию, это так). Далее необходимо нажать и удерживать последовательно Alt и SysRq и нажать одну из командных клавиш. В графических окружениях (GNOME, KDE, …) нажатие PrtScr/SysRq обычно приводит лишь к созданию скриншота, и последующая команда может не восприниматься ядром. Это можно обойти, если дополнительно удерживать Ctrl, то есть полная комбинация будет Ctrl + Alt + SysRq + клавиша. Если вместо командной клавиши нажать любую другую, то на виртуальный текстовый терминал для сообщений ядра (обычно № 10) выведется несколько строчек краткой помощи по использованию. Это удобно использовать как быстрый способ убедиться, что параметр CONFIG_MAGIC_SYSRQ в загруженном ядре включен.
Список команд SysRq в Linux
[править | править код]Одновременное нажатие клавиш Alt + SysRq + буква.
Если SysRq вызывается с использованием Fn, то следует зажать Alt + Fn + SysRq, затем отпустить Fn и ввести букву команды.
Действие | QWERTY | Dvorak | AZERTY | Colemak |
---|---|---|---|---|
Установка уровня журнала консоли, который управляет типами сообщений ядра, выводимых на консоль | 0 — 9 | 0 — 9 | 0 — 9 (без ⇧ Shift) |
0 — 9 |
Немедленная перезагрузка системы, не размонтируя и не синхронизируя файловые системы | b | x | b | b |
Выполнение сбоя системы. Будет создан аварийный дамп, если он настроен | c | j | c | c |
Отображение всех удерживаемых в данный момент блокировки (требуется опция ядра CONFIG_LOCKDEP) | d | e | d | s |
Отправка сигнала SIGTERM всем процессам, кроме init (PID 1) | e | . | e | f |
Вызов oom_kill, который убьёт процесс, чтобы облегчить состояние OOM | f | u | f | t |
При использовании Kernel Mode Setting, переключение на консоль фреймбуфера ядра.[10] Если присутствует встроенный отладчик ядра kdb, вход в отладчик |
g | i | g | d |
Вывод краткого справочного документа на консоль Любая клавиша, не связанная с командой, также должна выполнять это действие. |
h | d | h | h |
Отправка сигнала SIGKILL всем процессам, кроме init | i | c | i | u |
Принудительная «разморозка» файловых систем, замороженных с помощью FIFREEZE ioctl | j | h | j | n |
Завершение всех процессов на текущей виртуальной консоли (можно убить программы X и SVGAlib, см. ниже) Изначально это было разработано для имитации Secure attention key |
k | t | k | e |
Показ обратной трассировки стека для всех активных ЦП | l | n | l | i |
Вывод текущей информации о памяти на консоль | m | m | , | m |
Сброс уровня nice для всех высокоприоритетных задач и задач реального времени | n | b | n | k |
Отключение системы | o | r | o | y |
Вывод текущих регистров и флагов на консоль | p | l | p | ; |
Отображение всех активных таймеров высокого разрешения и источников синхронизации | q | ' | a | q |
Переключение клавиатуры из режима Raw, используемого такими программами, как X11 и SVGAlib, в режим XLATE | r | p | r | p |
Синхронизация все смонтированных файловых систем | s | o | s | r |
Вывод списка текущих задач и информации о них на консоль | t | y | t | g |
Перемонтирование всех смонтированных файловых систем в режиме только для чтения | u | g | u | l |
Принудительное восстановление консоли фреймбуфера. Для процессоров ARM вместо этого вызов дампа буфера ETM |
v | k | v | v |
Отображение списка заблокированных (состояние D) задач | w | , | z | w |
Используется интерфейсом xmon на платформах PowerPC. Показ глобальных регистров PMU на sparc64. Сброс всех записей TLB на MIPS.[11] |
x | q | x | x |
Показ глобальных регистров ЦП (специфично для SPARC-64) | y | f | y | j |
Дамп буфера трассировки ftrace | z | ; | w | z |
Alt + SysRq + 0-9 | loglevel0-9 — позволяет менять уровень подробности вывода от 0 (только критические сообщения) до 8 (самый подробный режим); |
Alt + SysRq + B | reBoot — выполняет немедленную перезагрузку системы аналогично кнопке RESET (без синхронизации и размонтирования файловых систем); |
Alt + SysRq + C | Crashdump — выполняет директиву kexec для перезагрузки, чтобы получить сведения об ошибках; |
Alt + SysRq + D | holDs — показывает все блокировки, которые держат устройства или файлы; |
Alt + SysRq + E | tErm — послать сигнал завершения работы SIGTERM всем процессам, кроме init; |
Alt + SysRq + F | Full — позволяет вызвать обработчик oom_kill (out-of-memory kill) для прерывания приложений, забравших слишком много памяти (может занять продолжительное время). Используйте его, если свободная память совсем истощилась, так что система не реагирует ни на какой иной ввод (курсор мыши не движется, индикаторы NumLock/CapsLock не включаются, но индикатор работы накопителя всё время включен); |
Alt + SysRq + H | Help — выводит все доступные возможности SysRq, выделяя большой буквой клавишу действия; |
Alt + SysRq + I | KILL — послать сигнал немедленного завершения работы SIGKILL всем процессам, кроме init. |
Alt + SysRq + K | secure access Key — убивает все процессы на текущей консоли. Её следует применять для снятия зависшего X-сервера. При этом графический сервер будет остановлен и невозможно будет увидеть ввод-вывод либо пока X-сервер не перезапустится, либо пока видеорежим не будет исправлен вручную; |
Alt + SysRq + M | showMem — выдаст информацию о доступной и занятой оперативной памяти, а также степени использования свопа; |
Alt + SysRq + N | Nice — используется для того, чтобы сбросить приоритет задачи реального времени или просто с измененным приоритетом; |
Alt + SysRq + O | powerOff — корректно выключает систему (если настроено и поддерживается, обычно это прямая команда отключения); |
Alt + SysRq + R | unRaw — перехватывает управление мышью и клавиатурой у Х-сервера, что полезно, если Х-сервер завис: так можно перейти в консоль, убить Х-сервер или проверить логи; |
Alt + SysRq + S | Sync — пытается синхронизировать все примонтированные файловые системы, при этом пишет в консоли «Emergency Sync». При успешном завершении выводится «Emergency Sync Complete»; |
Alt + SysRq + T | showTasks — выдаст список текущих задач и информацию о них в текущую консоль; |
Alt + SysRq + U | Unmount — пытается перемонтировать все примонтированные файловые системы в режим «только чтение»; |
Alt + SysRq + W | shoW-blocked-tasks — выдаст список всех непрерываемых (заблокированных, ждущих окончание ввода-вывода) задач; |
То есть, например, для аварийной синхронизации данных следует выполнить последовательность Alt + SysRq + S, далее Alt + SysRq + U. После этого можно жать на сброс или, что то же самое, Alt + SysRq + B.
Более правильно экстренную перезагрузку стоит проводить, зажав клавиши Alt + SysRq и с интервалом в 2—3 секунды нажать последовательно: R E I S U B
- unRaw (перехватить управление клавиатурой),
- tErminate (послать SIGTERM всем процессам),
- kIll (послать SIGKILL всем процессам, которые не смогли завершиться предыдущей командой),
- Sync (синхронизировать файловые системы),
- Unmount (перемонтировать файловые системы в режим «только чтение»),
- reBoot. (и напоследок, совершить перезагрузку)
Есть и другие мнемоники для запоминания этой последовательности, см Magic SysRq key[англ.].
При недоступности работы с терминалом сочетание клавиш можно послать /proc/sysrq-trigger
Например, команда echo «h» > /proc/sysrq-trigger выведет список возможных сигналов в dmesg.
Для того, чтобы восстановить управление клавиатурой X-сервером, после unRaw используйте следующую команду с правами суперпользователя:
kbd_mode -s -C /dev/tty7
[12]. Вместо tty7
(7 — обычный номер для запуска X-сервера) можно использовать tty$(fgconsole)
для программного определения номера tty.
Примечания
[править | править код]- ↑ What is the SysRq key for? comp.os.msdos.programmer FAQ. Дата обращения: 8 января 2008. Архивировано 10 ноября 2018 года.
- ↑ Dan Gookin. PCs For Dummies Quick Reference. — С. 192. «Dead keys… SysRq»
- ↑ Киви Берд (2003-12-14). "Давим на клавиши". "Домашний Компьютер" №12. Архивировано 21 января 2014. Дата обращения: 17 января 2014.
- ↑ Ralf Brown's Interrupt List . Дата обращения: 8 января 2008. Архивировано 19 июня 2016 года.
- ↑ PC Mag 25 Jun 1991 Архивная копия от 21 января 2014 на Wayback Machine page 418 «Summary of BIOS Services»
- ↑ Original IBM PC Product fact sheet . IBM Information Systems Division (12 августа 1981). Дата обращения: 13 января 2010. Архивировано 20 августа 2010 года.
- ↑ Returning Control to CodeView . Microsoft Knowledge Base. Дата обращения: 8 января 2008. Архивировано 8 ноября 2008 года.
- ↑ How to enable a remote kernel debugger connection on a computer that is running Windows Server 2003 with Service Pack 1 . Microsoft Knowledge Base. Дата обращения: 8 января 2008. Архивировано 19 марта 2008 года.
- ↑ MicroVGA datasheet . Дата обращения: 17 января 2014. Архивировано 15 октября 2012 года.
- ↑ Barnes, Jesse DRM: i915: add mode setting support . Git. Kernel (7 ноября 2008). Дата обращения: 31 августа 2013.
- ↑ Linux Magic System Request Key Hacks (13 сентября 2021). Дата обращения: 25 сентября 2022.
- ↑ Recovering from Sys Rq + r
Литература
[править | править код]- System BIOS for IBM PC/XT/AT computers and compatibles // Phoenix Technologies, Addison-Wesley Pub. Co., 1989
Ссылки
[править | править код]- SysRq: Убийца процессов Архивная копия от 1 июля 2017 на Wayback Machine // Linuxcenter.ru.
- SysRQ или как привести в чувство «зависший» Linux
- Документация ядра Linux о Sysrq (англ.)