WikiDer > Менеджер X сессий
в X Window System, Менеджер X сессий это управление сеансом программа, программа, которая может сохранять и восстанавливать текущие государственный набора запущенных приложений.
Обзор
С точки зрения менеджера X-сессий, сессия - это «состояние рабочего стола» в данный момент времени: набор окон с их текущим содержимым. Точнее, сеанс - это набор клиентов, управляющих этими окнами или связанных с ними, и информация, которая позволяет этим приложениям при необходимости восстанавливать состояние этих окон.
Самый узнаваемый эффект от использования диспетчера сеансов - это возможность выхода из интерактивного сеанса, а затем обнаружение точно таких же окон в том же состоянии при повторном входе в систему. Чтобы это работало, программа диспетчера сеансов сохраняет имена приложений, запущенных при выходе из системы, и запускает их снова при входе в систему. Более того, чтобы состояние приложений также было восстановлено (что необходимо для восстановления содержимого окон), приложения должны иметь возможность сохранять свое состояние выполнения по запросу от диспетчера сеансов и загружать его обратно при повторном запуске.
Как правило, сеанс можно сохранить или загрузить в любое время, даже если пользователь не входит в систему или не выходит из нее. Также возможно сохранить несколько разных сессий и загрузить одну из них по выбору пользователя. Сеансы также можно указать, предоставив список приложений, составляющих сеанс. В результате пользователь имеет возможность сохранять набор различных сеансов, либо сохраняя состояние выполнения запущенных в данный момент приложений, либо явно перечисляя приложения, составляющие сеанс. Таким образом, пользователь может позже решить загрузить данный сеанс.
Протокол XSMP
Для того, чтобы сеанс включал состояние приложения, приложение должно иметь возможность сохранять и загружать свое текущее состояние, когда это необходимо. Протокол с именем X протокол управления сеансом (XSMP) определяет, как взаимодействуют приложения и менеджеры сеансов. Формат сообщения XSMP такой же, как Установление интерактивного подключения (ICE) формат сообщения.[1] Особое значение имеет то, что оконный менеджер может взаимодействовать с диспетчером сеансов, поскольку диспетчер окон отвечает за размещение окон и наличие значков. Приложения, которые не могут сохранять свое состояние, могут быть включены в сеанс, но они не сохраняют свое состояние между сеансами.
Система X Window включает в себя менеджер сеансов по умолчанию, называемый хсм
. Для конкретных настольных систем были разработаны и другие менеджеры сеансов: например, ksmserver
является менеджером сеансов по умолчанию для KDE.
Протокол
XSMP - это подпротокол Протокол межклиентского обмена. Клиент запускает протокол, подключившись к диспетчеру сеансов. Расположение диспетчера сеансов в сети зависит от системы: в POSIX система, среда содержит переменную SESSION_MANAGER
. Следовательно, когда клиент запускается, его среда должна содержать эту переменную с соответствующим значением.
Идентификаторы
В протоколе учтены два факта:
- для правильного перезапуска сеанса необходимо перезапустить не только запущенные в нем приложения, но и перезапустить их таким образом, чтобы они восстановили свое предыдущее состояние;
- одно и то же приложение может запускаться более одного раза в одном или другом сеансе.
Различные экземпляры одного и того же приложения могут быть активны в одно и то же время в одном или в разных сеансах, и эти экземпляры, скорее всего, имеют разные состояния выполнения. Например, пользователь мог запустить текстовый редактор для файла / etc / passwd
, затем в файле letter.txt
в том же сеансе, а затем в файле todo.txt
в другом сеансе.
Для правильного восстановления сеансов диспетчер сеансов должен распознавать разные экземпляры одного и того же приложения как разные. По этой причине диспетчер сеанса выбирает уникальный идентификатор для каждого экземпляра каждого приложения. Таким образом, менеджер сеанса может различать текстовый редактор, работающий на / etc / passwd
и текстовый редактор, работающий на todo.txt
, даже если это два экземпляра одной и той же программы.
Идентификаторы должны быть уникальными. В частности, они должны быть уникальными для всех сеансов, управляемых менеджером сеансов: идентификатор текстового редактора, работающего на / etc / passwd
отличается не только от того же текстового редактора, работающего на letter.txt
но также отличается от текстового редактора, работающего на todo.txt
в другом сеансе. Идентификатор клиента остается неизменным даже после завершения и перезапуска сеанса.
Основные части протокола
Основными частями протокола управления сессией являются:
- менеджер сеанса выбирает уникальный идентификатор для каждого клиента
- менеджер сеанса просит клиентов сохранить свое состояние
- клиент указывает, как он должен быть запущен снова, чтобы состояние было восстановлено (например, командная строка будет использоваться для запуска процесса)
Последний пункт возможен, потому что менеджер сеанса поддерживает набор свойств для каждого клиента (в терминологии X Window System свойство - это просто контейнер для данных). Эти данные могут быть изменены клиентом в любое время. Одно из этих свойств называется RestartCommand
, и содержит информацию о том, как снова запустить клиент.
Когда диспетчер сеанса запрашивает у клиента сохранение своего состояния, приложение действует следующим образом:
- он сохраняет свое состояние таким образом, чтобы можно было различать состояния двух разных экземпляров; это можно получить, например, сохранив состояние в файле, имя которого содержит его идентификатор
- он хранит спецификацию того, как он должен быть снова запущен в
RestartCommand
свойство; это свойство должно содержать идентификатор клиента, потому что:- приложение должно сохранять свой идентификатор при повторном запуске
- идентификатор нужен для восстановления состояния (например, нужно найти файл, в котором хранится его состояние)
Менеджер сеанса поддерживает другие свойства, кроме RestartCommand
. Например, свойство определяет, как запустить приложение, если сеанс разрушен.
Локальное и глобальное состояние
При запросе клиента на сохранение своего состояния оконный менеджер может указать, должно ли быть сохранено локальное или глобальное состояние (или оба). Разница в том, должен ли результат сохранения быть видимым для других приложений или нет.
В случае текстового редактора сохранение глобального состояния означает обычное сохранение файла, чтобы другие приложения могли использовать новую версию файла. Сохранение локального состояния означает, что необходимо сохранить локальную копию файла, чтобы другие приложения могли видеть файл в его исходной версии.
Пример
Ниже приведены основные этапы взаимодействия диспетчера сеансов с гипотетическим текстовым редактором. xyz
когда это приложение запускается впервые за сеанс, пользователь выходит из системы, а затем снова входит:
- приложение подключается к диспетчеру сеансов по протоколу межклиентского обмена
- приложение сообщает диспетчеру сеанса, что это первый запуск, и, следовательно, у него нет предыдущего идентификатора (и, следовательно, нет предыдущего состояния)
- диспетчер сеанса отвечает, отправляя клиенту его уникальный идентификатор, скажем
4324
; - менеджер сеанса немедленно просит клиента сохранить свое локальное состояние (только потому, что клиент был запущен впервые)
- клиент сохраняет командную строку
xyz -sid 4324
как собственностьRestartCommand
в диспетчере сеансов (это также зависит от системы: в POSIX системе, это свойство фактически содержит argv множество) - клиент хранит свое состояние локально; например, он может хранить имя редактируемого файла и всю другую информацию (например, текущую строку) в локальном файле.
.temp-4324
- когда пользователь выходит из системы, менеджер сеанса отправляет сообщение всем клиентам, уведомляющее, что они должны сохранить свое состояние
- клиент
4324
снова подчиняется - когда все клиенты сообщили менеджеру сеанса, что их состояние сохранено, менеджер сеанса завершает сеанс
Когда клиенту говорят сохранить свое состояние, у него может быть возможность иметь ограниченное взаимодействие с пользователем или нет (например, спрашивать пользователя, следует ли сохранить отредактированный файл). В любом случае состояние сохраняется, он сообщает об этом диспетчеру сеанса, отправляя соответствующее сообщение).
При повторном запуске сеанса происходит следующее:
- диспетчер сеансов перезапускает клиента
4324
выполняя то, что хранится в собственностиRestartCommand
связанный с клиентом4324
- поэтому приложение запускается как
xyz -sid 4324
; таким образом приложение знает свой идентификатор - приложение извлекает информацию о состоянии из файла
.temp-4324
- приложение подключается к диспетчеру сеансов с указанием идентификатора
4324
, чтобы менеджер сеанса знал, что это не новый клиент, а перезапускающий старый
Сеансы управления клиентами
Согласно протоколу XSMP диспетчер сеанса - это произвольная программа, которая запускает и контролирует состояние других приложений. В результате клиент сам может быть менеджером сеанса других клиентов. Например, почтовый клиент может начать Текстовый редактор для написания электронного письма и вести себя как менеджер сеанса по отношению к редактору. Таким образом, если почтовый клиент будет закрыт, а затем перезапущен, он сможет восстановить состояние текстового редактора.
История
Эта секция нуждается в расширении. Вы можете помочь добавляя к этому. (Январь 2009 г.) |
Для GNOME диспетчер сеансов GNOME заменил XSMP на D-автобус интерфейс в версии 2.24.[2] Однако это далеко не полная функция, и она не используется приложениями, отличными от GNOME.
Смотрите также
Рекомендации
- ^ «Протокол управления сеансом X». www.x.org. Получено 2020-12-02.
- ^ "Проекты / SessionManagement / GnomeSession - GNOME Wiki!". wiki.gnome.org.
внешняя ссылка
- Протокол управления сеансом X
- xsm страница руководства
- ksmserver, то KDE менеджер сеанса
- ROX-сессия, то ROX Desktop менеджер сеанса