SysRq

Эта статья находится на начальном уровне проработки, в одной из её версий выборочно используется текст из источника, распространяемого под свободной лицензией
Материал из энциклопедии Руниверсалис
Расположение клавиши SysRq на клавиатуре. Совмещена с клавишей Print screen

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 и ввести букву команды.

Alt + SysRq + H Help — выводит все доступные возможности SysRq, выделяя большой буквой клавишу действия;
Alt + SysRq + 0-9 loglevel0-9 — позволяет менять уровень подробности вывода от 0 (только критические сообщения) до 8 (самый подробный режим);
Alt + SysRq + B reBoot — выполняет немедленную перезагрузку системы аналогично кнопке RESET (без синхронизации и размонтирования файловых систем);
Alt + SysRq + C Crashdump — выполняет директиву kexec для перезагрузки, чтобы получить сведения об ошибках;
Alt + SysRq + D holDs — показывает все блокировки, которые держат устройства или файлы;
Alt + SysRq + O powerOff — корректно выключает систему (если настроено и поддерживается, обычно это прямая команда отключения);
Alt + SysRq + S Sync — пытается синхронизировать все примонтированные файловые системы, при этом пишет в консоли «Emergency Sync». При успешном завершении выводится «Emergency Sync Complete»;
Alt + SysRq + U Unmount — пытается перемонтировать все примонтированные файловые системы в режим «только чтение»;
Alt + SysRq + T showTasks — выдаст список текущих задач и информацию о них в текущую консоль;
Alt + SysRq + N Nice — используется для того, чтобы сбросить приоритет задачи реального времени или просто с измененным приоритетом;
Alt + SysRq + W shoW-blocked-tasks — выдаст список всех непрерываемых (заблокированных, ждущих окончание ввода-вывода) задач;
Alt + SysRq + M showMem — выдаст информацию о доступной и занятой оперативной памяти, а также степени использования свопа;
Alt + SysRq + F Full — позволяет вызвать обработчик oom_kill (out-of-memory kill) для прерывания приложений, забравших слишком много памяти (может занять продолжительное время). Используйте его, если свободная память совсем истощилась, так что система не реагирует ни на какой иной ввод (курсор мыши не движется, индикаторы NumLock/CapsLock не включаются, но индикатор работы накопителя всё время включен);
Alt + SysRq + K secure access Key — убивает все процессы на текущей консоли. Её следует применять для снятия зависшего X-сервера. При этом графический сервер будет остановлен и невозможно будет увидеть ввод-вывод либо пока X-сервер не перезапустится, либо пока видеорежим не будет исправлен вручную;
Alt + SysRq + R unRaw — перехватывает управление мышью и клавиатурой у Х-сервера, что полезно, если Х-сервер завис: так можно перейти в консоль, убить Х-сервер или проверить логи;
Alt + SysRq + E tErm — послать сигнал завершения работы SIGTERM всем процессам, кроме init;
Alt + SysRq + I KILL — послать сигнал немедленного завершения работы SIGKILL всем процессам, кроме init.

То есть, например, для аварийной синхронизации данных следует выполнить последовательность 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[10]. Вместо tty7 (7 — обычный номер для запуска X-сервера) можно использовать tty$(fgconsole) для программного определения номера tty.

Примечания

  1. What is the SysRq key for?. comp.os.msdos.programmer FAQ. Дата обращения: 8 января 2008. Архивировано 10 ноября 2018 года.
  2. Dan Gookin. PCs For Dummies Quick Reference. — С. 192. "Dead keys... SysRq"
  3. Киви Берд. Давим на клавиши, "Домашний Компьютер" №12 (14 декабря 2003). Архивировано 21 января 2014 года. Дата обращения 17 января 2014.
  4. Ralf Brown's Interrupt List. Дата обращения: 8 января 2008. Архивировано 19 июня 2016 года.
  5. PC Mag 25 Jun 1991 Архивная копия от 21 января 2014 на Wayback Machine page 418 "Summary of BIOS Services"
  6. Original IBM PC Product fact sheet. IBM Information Systems Division (August 12, 1981). Дата обращения: 13 января 2010. Архивировано 20 августа 2010 года.
  7. Returning Control to CodeView. Microsoft Knowledge Base. Дата обращения: 8 января 2008. Архивировано 8 ноября 2008 года.
  8. 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 года.
  9. MicroVGA datasheet. Дата обращения: 17 января 2014. Архивировано 15 октября 2012 года.
  10. Recovering from Sys Rq + r

Литература

Ссылки