Подготовка базового ВРМОбязательные настройкиДля подготовки необходимо: |
Базовое ВРМ в домен вводить не нужно: процесс ввода контролируется параметрами гостевых ОС (см. подраздел Управление параметрами гостевых ОС в Termidesk), которые указываются при создании фонда ВРМ (см. подраздел Добавление фонда ВРМ). |
Настройка гостевой ОС Windows сводится к выполнению следующих действий:
Установку приложений |
qemu-guest-agent for Windows (доступ: https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/archive-qemu-ga/qemu-ga-win-106.0.1-1.el9/) и spice-guest-tools (доступ: https://www.spice-space.org/download/windows/spice-guest-tools/);spice-webdavd для Windows (доступ: https://www.spice-space.org/download/windows/spice-webdavd/) для включения возможности перенаправления каталога из пользовательской рабочей станции в ВРМ. Перенаправление каталогов из пользовательской рабочей станции в ВРМ с установкой пакета spice-webdavd работает только для протокола SPICE;Настройка гостевой ОС Astra Linux сводится к выполнению следующих действий:
qemu-guest-agent, spice-vdagent, xserver-xorg-video-qxl::~$ sudo apt install -y qemu-guest-agent spice-vdagent xserver-xorg-video-qxl |
где:
-y - ключ для пропуска подтверждения установки;
xrdp для корректной работы подключения по протоколу RDP к ВРМ::~$ sudo apt install -y xrdp |
libcanberra-pulse для корректной работы аудио::~$ sudo apt install -y libcanberra-pulse |
spice-webdavd, davfs2, autofs для включения возможности автоматического перенаправления каталога из пользовательской рабочей станции в ВРМ по протоколу SPICE::~$ sudo apt install -y spice-webdavd davfs2 autofs |
Для предоставления пользователям возможности перенаправления каталога в ВРМ необходимо также выполнить настройки, указанные в подразделе Настройка перенаправления каталога из пользовательской рабочей станции в ВРМ. |
/etc/acpi/events/powerbtn-acpi-support к виду:event=button/power action=/sbin/poweroff |
astra-ad-sssd-client для возможности ввода ВРМ с ОС Astra Linux в домен MS AD::~$ sudo apt install -y astra-ad-sssd-client |
astra-freeipa-client для возможности ввода ВРМ с ОС Astra Linux в домен FreeIPA::~$ sudo apt install -y astra-freeipa-client |
При необходимости работы с vGPU по протоколу доставки Loudplay в гостевой ОС дополнительно должны быть установлены серверные драйверы NVIDIA и сервер Loudplay. |
Для гостевой ОС Astra Linux необходимо также изменить способ назначения сетевых настроек:
systemctl --now mask) и удалить (apt remove) встроенную программу для управления сетевыми соединениями NetworkManager::~$ sudo systemctl --now mask NetworkManager && sudo apt remove network-manager |
/etc/network/interfaces.d/<имя интерфейса>.conf. Необходимо создать конфигурационные файлы и описать их, воспользовавшись справочным центром Astra Linux:
https://wiki.astralinux.ru/pages/viewpage.action?pageId=3277370;/etc/network/interfaces, добавив в нее следующую строку, если ее нет:source /etc/network/interfaces.d/* |
:~$ sudo systemctl restart networking |
Для гостевой ОС Linux, отличной от Astra Linux, при необходимости ввода ВРМ в домен FreeIPA нужно внести изменения в файл
/usr/lib/python3.6/site-packages/ipalib/constants.py:
:~$ sudo sed -i "s/^NAME_REGEX.*$/NAME_REGEX = r'[a-z][_a-z0-9\\\-]*[a-z0-9]$|[a-z]$'/g" $(sudo find / -name constants.py -type f | grep -FzZ 'ipalib/constants.py') |
Команда осуществляет поиск файла constants.py в корневой директории и учитывает, что найденный путь к файлу должен содержать каталог «ipalib». В найденный файл вносится изменение переменной NAME_REGEX.
Путь к файлу зависит от используемой ОС Linux и версии Python и может отличаться от указанного. Для определения пути к файлу можно воспользоваться утилитой
|
При стандартной настройке сетевой инфраструктуры предполагается, что IP-адрес DNS-сервера определяется DHCP-сервером. Однако если это не так, необходимо скорректировать файл /etc/resolv.conf в гостевой ОС Astra Linux:
:~$ echo -e 'domain <имя_домена>\nsearch <имя_домена>\nnameserver <IP-адрес_DNS-сервера>' | sudo tee /etc/resolv.conf |
/etc/resolv.conf от перезаписи нужно создать файл /etc/dhcp/dhclient-enter-hooks.d/nodnsupdate::~$ sudo touch /etc/dhcp/dhclient-enter-hooks.d/nodnsupdate |
#!/bin/bash
make_resolv_conf() {
:
} |
Вернуть возможность перезаписи файла /etc/resolv.conf можно, удалив ранее созданный /etc/dhcp/dhclient-enter-hooks.d/nodnsupdate и выполнив перезапуск сетевой службы:
:~$ sudo systemctl restart networking |
|
Для гостевой ОС Astra Linux Special Edition:
:~$ sudo mkdir /media/davfs |
/etc/auto.master.d/spice-webdav.autofs следующего содержания:/- /etc/auto.master.d/auto.localwebdav.mount |
где:
/- - опция, указывающая утилите autofs выполнять монтирование по существующему пути вместо автоматического создания подкаталогов в корневой точке монтирования;
/etc/auto.master.d/auto.localwebdav.mount следующего содержания:/media/davfs -fstype=davfs,rw,dir_mode=0777,file_mode=666 :http\://localhost\:9843 |
где:
/media/davfs - каталог, в который будет происходить монтирование;
-fstype=davfs,rw - тип смонтированной файловой системы с правами на чтение и запись в нее (rw);
dir_mode=0777,file_mode=666 - права, с которыми будут доступны файлы и каталоги. Рекомендуется не менять указанные значения для исключения случаев монтирования файловой системы от пользователя root и недоступности файлов при подключении через программу доставки ВРМ (termidesk-viewer);
/etc/davfs2/secrets, добавив строку:"http://localhost:9843/" "" "" |
где:
http://localhost:9843/ - место размещения файловой системы, по которому определяется устройство хранения для монтирования;
"" "" - логин и пароль пользователя, по умолчанию пусты для утилиты spice-webdav;
:~$ sudo systemctl restart autofs |
Для гостевой ОС Windows должен быть установлен пакет spice-webdavd (доступ: https://www.spice-space.org/download/windows/spice-webdavd/).
В ОС Windows сетевой диск не будет автоматически смонтирован в ВРМ. Для включения функционала нужно:
.bat), который будет выполнять автоматическое монтирование, и поместить его в каталог C:\Windows\System32\GroupPolicy\User\Scripts\Logon;gpedit.msc переопределить локальную политику «Конфигурация пользователя - Конфигурация Windows - Сценарии (вход/выход из системы)»: отредактировать параметр «Вход в систему», добавив новый сценарий и назначив ему имя ранее созданного исполняемого файла, например: C:\Windows\System32\GroupPolicy\User\Scripts\Logon\<исполняемый файл.bat>;gpedit.msc переопределить локальную политику «Конфигурация компьютера - Административные шаблоны - Система - Групповая политика - Настроить задержку сценария входа)»: задать ей значение «Включено» и «мин.:0» ;C:\Windows\system32\gpupdate /force |
Автоматическое масштабирование экрана в ОС Astra LinuxВ некоторых случаях при переходе в полноэкранный режим в пользовательской рабочей станции гостевая ОС Astra Linux не производит автоматическое масштабирование экрана. |
Условием масштабирования является запущенный процесс |
Для настройки автоматического масштабирования экрана необходимо:
/etc/udev/rules.d/50-spice-vdagent.rules, создав правило для udev:ACTION=="change", KERNEL=="card0", SUBSYSTEM=="drm", RUN=="/usr/local/bin/x-resize" |
udev командой::~$ sudo systemctl restart udev |
/usr/local/bin/x-resize:#!/bin/sh
PATH=/usr/bin
desktopuser=$(/bin/ps -o user:80= -C spice-vdagent | grep -v fly-dm) || exit 0
export DISPLAY=:0
export XAUTHORITY=$(eval echo "~$desktopuser")/.Xauthority
xrandr --output $(xrandr | awk '/ connected/{print $1; exit; }') --auto |
#!/bin/sh
PATH=/usr/bin
# Имя пользователя получается через вывод списка пользователей (заголовки отключены), от имени которых запущен spice-vdagent | из списка вырезается имя fly-dm (сессия отображения ввода логина-пароля)
desktopuserlist=$(/bin/ps -o user:80= -C spice-vdagent | grep -v fly-dm) || exit 0
# Проверенное решение, но работает только для имён пользователей без дефисов, пробелов и т.д.
#desktopuserlist=$(/bin/ps -ef | /bin/grep -oP '^\w+ (?=.*vdagent( |$))') || exit 0
for desktopuser in $desktopuserlist; do
export DISPLAY=:0
export XAUTHORITY=$(eval echo "~$desktopuser")/.Xauthority
#Get active monitors
ACTMONS=$(xrandr --listactivemonitors | awk '/[[:alnum:]]+ +/ {print $4}' | sort)
#Get primary monitor
PRIMARYMON=$(xrandr --listactivemonitors | awk '/*/ {print $4}')
#Get current and preferred display resolutions
for MON in $ACTMONS
do
#Get preferred display resolution
PREFRES=$(xrandr | awk -v monpref="$MON connected" '/connected/ {p = 0} $0 ~ monpref {p = 1} p' | awk '/+/ {print $1;}' | sed -n '2~2p')
#Get current display resolution
CURNRES=$(xrandr | awk -v moncurn="$MON connected" '/connected/ {p = 0} $0 ~ moncurn {p = 1} p' | awk '/*/ {print $1;}')
if [[ $CURNRES != $PREFRES ]];
then
if [[ $MON == $PRIMARYMON ]];
then
xrandr --output $MON --auto
logger -p local0.notice -t ${0##*/}[$$] "$MON primary display change resolution to preferred $PREFRES"
else
xrandr --output $MON --left-of $PRIMARYMON --auto
logger -p local0.notice -t ${0##*/}[$$] "$MON display change resolution to preferred $PREFRES and left of $PRIMARYMON"
fi
else
logger -p local0.notice -t ${0##*/}[$$] "$MON display is already using preferred resolution $PREFRES"
fi
done
done |
:~$ sudo chmod +x /usr/local/bin/x-resize |
Для масштабирования экрана приветствия необходимо выполнить:
kscreen, переименовав расширение или удалив данные файлы из указанных директорий: /usr/share/fly-dm/autostart/greeter/kscreend_autostart.desktop, /usr/share/fly-dm/preload/greeter/kscreend_preload.desktop;spice-vdagent для экрана приветствия::~$ sudo ln -s /etc/xdg/autostart/spice-vdagent.desktop /usr/share/fly-dm/autostart/greeter/spice-vdagent.desktop |
fly-dm командой::~$ sudo systemctl restart fly-dm |
Если файл |