Tigervncserver аварийно завершает работу, если не запущен с помощью sudo

Я установил следующие пакеты:

ii  tigervnc-common                          1.10.1+dfsg-1                        amd64        Virtual network computing; Common software needed >
ii  tigervnc-standalone-server               1.10.1+dfsg-1                        amd64        Standalone virtual network computing server
ii  tigervnc-viewer                          1.10.1+dfsg-1                        amd64        Virtual network computing client for X
ii  tigervnc-xorg-extension                  1.10.1+dfsg-1                        amd64        Virtual network computing X server extension

Я запустил vncserver, настроил пароль и не добавил никаких дополнительных настроек.

(Это при уже работающем сеансе VNC) Команда без sudo:

root@kali:~# vncserver -localhost

New 'kali.'"'':2 (root)' desktop at :2 on machine kali.'"''

Starting applications specified in /etc/X11/Xvnc-session
Log file is /root/.vnc/kali.'"'':2.log

Use xtigervncviewer -SecurityTypes VncAuth -passwd /root/.vnc/passwd :2 to connect to the VNC server.


vncserver: Failed command '/etc/X11/Xvnc-session': 256!

=================== tail -15 /root/.vnc/kali.'"'':2.log ===================

Xvnc TigerVNC 1.10.0 - built Dec 30 2019 14:38:21
Copyright (C) 1999-2019 TigerVNC Team and many others (see README.rst)
See https://www.tigervnc.org for information on TigerVNC.
Underlying X server release 12006000, The X.Org Foundation


Sun Jan 12 18:52:25 2020
 vncext:      VNC extension running!
 vncext:      Listening for VNC connections on local interface(s), port 5902
 vncext:      created VNC server for screen 0
X connection to :2 broken (explicit kill or server shutdown).
 ComparingUpdateTracker: 0 pixels in / 0 pixels out
 ComparingUpdateTracker: (1:-nan ratio)
Killing Xtigervnc process ID 4108... which seems to be deadlocked. Using SIGKILL!

===========================================================================

Starting applications specified in /etc/X11/Xvnc-session has failed.
Maybe try something simple first, e.g.,
        tigervncserver -xstartup /usr/bin/xterm

При работе с sudo и это работает:

root@kali:~# sudo vncserver -localhost

New 'kali.'"'':2 (root)' desktop at :2 on machine kali.'"''

Starting applications specified in /etc/X11/Xvnc-session
Log file is /root/.vnc/kali.'"'':2.log

Use xtigervncviewer -SecurityTypes VncAuth -passwd /root/.vnc/passwd :2 to connect to the VNC server.

Я являюсь корнем для обоих, поэтому я хочу понять, почему sudo имеет значение


person Michael Z    schedule 13.01.2020    source источник


Ответы (1)


создайте исполняемый файл ~/.vnc/xstartup со следующим содержимым:

#!/bin/bash

PATH=/usr/bin:/usr/sbin
unset SESSION_MANAGER
unset DBUS_SESSION_BUS_ADDRESS
exec startxfce4 &

для значения exec проверьте сеанс рабочего стола с помощью:

ls /usr/share/xsessions/

там вы найдете файлы .desktop, такие как:

cinnamon2d.desktop  cinnamon.desktop  gnome.desktop  gnome-xorg.desktop  
kodi.desktop

Откройте файл с интересующей вас средой рабочего стола для вашего сеанса vnc и проверьте там переменную Exec, для меня это было cinnamon-session-cinnamon. Итак, мой ~/.vnc/xstartup выглядел так:

#!/bin/bash

PATH=/usr/bin:/usr/sbin
unset SESSION_MANAGER
unset DBUS_SESSION_BUS_ADDRESS
exec cinnamon-session-cinnamon &

после этого vncserver должен запускаться без каких-либо требований sudo, по крайней мере, так было в моем случае. Я предполагаю, что отсутствие исполняемого файла препятствует запуску vncserver, но с привилегиями sudo ему удается запуститься с настройками по умолчанию, извлеченными из некоторых файлов, доступных только для sudoers.

person Victor Di    schedule 21.12.2020