05. Remote Access - VNC on Ubuntu and derivatives

I couldn't get the tigervncserver to work on a Ubuntu 18.04 desktop VM - it failed with the message: XIO: fatal IO error 11 (Resource temporarily unavailable) on X server ":1" after 175 requests (175 known processed) with 0 events remaining. This might have to do with the fact that it is running in a VM and virt-manager is using SPICE to show the screen, which uses port 5900.
So I installed tigervnc on the Linux Mint 20 host (Ubuntu 20.04). This time the vncserver started - hurray!
But connecting to the server using vncviewer resulted in a grey screen and a message window saying: Could not acquire name on session bus
Eventually I put things together and here is how it works:
- Install the tigervnc-standalone-server etc. packages. Then run the vncserver. It will ask for a password, which then stored under ~/.vnc/passwd.
- The default configuration file is /etc/vnc.conf. The settings in there can be overwritten by a local (per user) config file ~/.vnc/vnc.conf. The latter has to be manually created (but wasn't needed in my case).
- The important file is the xstartup script file, which is not created by default. The man page specifies it as $HOME/.vnc/Xvnc-session:
$HOME/.vnc/Xvnc-session
A shell script specifying X applications to be run when a
TigerVNC desktop is started. If it doesn't exist and no system
default is provided in /etc/vnc.conf, tigervncserver will create
a new one which runs a couple of basic applications. To be com‐
patible with older versions of this wrapper script, we will also
use the file $HOME/.vnc/xstartup if it is present.
- To make it work, create the ~/.vnc/Xvnc-session script as follows:
#!/bin/bash unset SESSION_MANAGER unset DBUS_SESSION_BUS_ADDRESS mate-session &
You need to change the last line depending on the desktop you run, for example gnome-session.
Make the file executable with chmod +x
- The vncserver needs to read that file, so we kill the vncserver and restart it:
vncserver -kill vncserver
- When the vncserver starts, it will tell you how to connect to it. In my case it was:
xtigervncviewer -SecurityTypes VncAuth -passwd /home/heiko/.vnc/passwd :1
vncviewer :1
will also work.
- For remote access make sure the firewall has ports 5900-5904 open (actually it can be any port starting with 5900 for display :0, 5901 for display :1 etc.).
I'm not sure if starting a new X server is the best way to do it. It doesn't connect to the active screen I'm using, but rather opens a new desktop. Any ideas on how to do that?
Comments
-
Hi Heiko! Thank you for the detailed explanation.
A couple of points that might help:
Re-tested on Ubuntu 18.04. The initial pass failed as described, however, the HINTS in step 3 say to create a /home/student/.vnc/xstartup file. The text of the file is in the HINT and in the SOLUTIONS directory. This will clear the initial error.
I do not have "mate-session" installed but doesn't that start a new desktop? The supplied xstartup file contains only a couple simple apps xterm and xeyes. The HINTS also mention you may have to install the applications.
We will improve the sequence of the steps to improve the lab exercise.
Thank you for your observations,
Lee1 -
Hi @heiko_s , I'm glad you made it work!
I got it working on Ubuntu 18.04; in my test case, the startup config file is created for the user as soon as I start the server. So I edited and I used xfce4 instead, as mate was not working by default, and also choose it because it's lighter. My config file looks like this:
[email protected]:~$ cat .vnc/xstartup #!/bin/sh #xrdb $HOME/.Xresources #xsetroot -solid grey #x-terminal-emulator -geometry 80x24+10+10 -ls -title "$VNCDESKTOP Desktop" & #x-window-manager & # Fix to make GNOME work #export XKL_XMODMAP_DISABLE=1 #/etc/X11/Xsession unset SESSION_MANAGER unset DBUS_SESSION_BUS_ADDRESS exec startxfce4
So I commented everything and I added the last three lines, which is very similar to yours, but the desktop environment.
Hint: try it from a remote host using a ssh tunnel with the "via" parameter for vncviewer.
Many regards,
Luis.0 -
Thanks Lee,
Of course you are right and I also saw the xstartup file under SOLUTIONS. The twm didn't work for me, it's usually not installed. In most cases Ubuntu users will have gnome-session, I prefer mate-session.
In either case, I cannot "share" my existing screen. I guess I must have missed something (perhaps I need to DuckDuck ubuntu screen sharing vnc).
And here is one search result: https://websiteforstudents.com/access-ubuntu-18-04-lts-beta-desktop-via-vnc-from-windows-machines/
0 -
The ViNC session is a separate X session, not shared.
0 -
I am mistaken, sharing an existing screen can be done with tiger VNC. Our current lab does not demo that functionality, perhaps in the future.
0 -
It's been ages since I used VNC (must have been in 2005), but I vaguely remember having shared an existing desktop. Thanks for confirming.
0
Categories
- 8.8K All Categories
- 12 LFX Mentorship
- 65 LFX Mentorship: Linux Kernel
- 356 Linux Foundation Boot Camps
- 226 Cloud Engineer Boot Camp
- 69 Advanced Cloud Engineer Boot Camp
- 23 DevOps Engineer Boot Camp
- 5 Cloud Native Developer Boot Camp
- 724 Training Courses
- 14 LFC110 Class Forum
- 16 LFD102 Class Forum
- 96 LFD103 Class Forum
- 2 LFD121 Class Forum
- 55 LFD201 Class Forum
- 1 LFD213 Class Forum - Discontinued
- 128 LFD232 Class Forum
- 14 LFD254 Class Forum
- 420 LFD259 Class Forum
- 78 LFD272 Class Forum
- 1 LFD272-JP クラス フォーラム
- 15 LFS200 Class Forum
- 683 LFS201 Class Forum
- LFS201-JP クラス フォーラム
- 271 LFS211 Class Forum
- 50 LFS216 Class Forum
- 23 LFS241 Class Forum
- 26 LFS242 Class Forum
- 18 LFS243 Class Forum
- 4 LFS244 Class Forum
- 7 LFS250 Class Forum
- LFS250-JP クラス フォーラム
- 103 LFS253 Class Forum
- 753 LFS258 Class Forum
- 7 LFS258-JP クラス フォーラム
- 48 LFS260 Class Forum
- 74 LFS261 Class Forum
- 6 LFS262 Class Forum
- 76 LFS263 Class Forum
- 14 LFS264 Class Forum
- 10 LFS266 Class Forum
- 8 LFS267 Class Forum
- 8 LFS268 Class Forum
- 4 LFS269 Class Forum
- 173 LFS272 Class Forum
- 1 LFS272-JP クラス フォーラム
- 184 LFW211 Class Forum
- 99 LFW212 Class Forum
- 875 Hardware
- 204 Drivers
- 74 I/O Devices
- 43 Monitors
- 115 Multimedia
- 204 Networking
- 98 Printers & Scanners
- 82 Storage
- 716 Linux Distributions
- 78 Debian
- 64 Fedora
- 12 Linux Mint
- 13 Mageia
- 22 openSUSE
- 125 Red Hat Enterprise
- 33 Slackware
- 13 SUSE Enterprise
- 344 Ubuntu
- 445 Linux System Administration
- 33 Cloud Computing
- 63 Command Line/Scripting
- Github systems admin projects
- 88 Linux Security
- 73 Network Management
- 105 System Management
- 45 Web Management
- 50 Mobile Computing
- 18 Android
- 19 Development
- 1.2K New to Linux
- 1.1K Getting Started with Linux
- 499 Off Topic
- 119 Introductions
- 193 Small Talk
- 19 Study Material
- 742 Programming and Development
- 237 Kernel Development
- 471 Software Development
- 898 Software
- 244 Applications
- 178 Command Line
- 2 Compiling/Installing
- 72 Games
- 313 Installation
- 19 All In Program
- 19 All In Forum
Upcoming Training
-
August 20, 2018
Kubernetes Administration (LFS458)
-
August 20, 2018
Linux System Administration (LFS301)
-
August 27, 2018
Open Source Virtualization (LFS462)
-
August 27, 2018
Linux Kernel Debugging and Security (LFD440)