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:
luis@ubuntu18server:~$ 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
- All Categories
- 177 LFX Mentorship
- 177 LFX Mentorship: Linux Kernel
- 754 Linux Foundation IT Professional Programs
- 374 Cloud Engineer IT Professional Program
- 170 Advanced Cloud Engineer IT Professional Program
- 74 DevOps IT Professional Program - Discontinued
- 5 DevOps & GitOps IT Professional Program
- 100 Cloud Native Developer IT Professional Program
- 7.6K Training Courses & Learning Paths
- 2 AI & ML Training
- 1 Blockchain & Decentralized Identity Training
- 5 Cloud & Containers Training
- 1 Cybersecurity Training
- 2 DevOps & Site-Reliability Training
- 1 Linux Kernel Development Training
- 1 Networking Training
- 2 Open Source Best Practice Training
- 2 System Administration Training
- 1 System Engineering Training
- 1 Web & Application Development Training
- 794 Hardware
- 202 Drivers
- 68 I/O Devices
- 37 Monitors
- 95 Multimedia
- 173 Networking
- 91 Printers & Scanners
- 89 Storage
- 769 Linux Distributions
- 81 Debian
- 68 Fedora
- 22 Linux Mint
- 13 Mageia
- 24 openSUSE
- 150 Red Hat Enterprise
- 31 Slackware
- 13 SUSE Enterprise
- 356 Ubuntu
- 465 Linux System Administration
- 31 Cloud Computing
- 73 Command Line/Scripting
- Github systems admin projects
- 98 Linux Security
- 78 Network Management
- 101 System Management
- 46 Web Management
- 111 Mobile Computing
- 19 Android
- 77 Development
- 1.2K New to Linux
- 1K Getting Started with Linux
- 393 Off Topic
- 121 Introductions
- 182 Small Talk
- 29 Study Material
- 976 Programming and Development
- 310 Kernel Development
- 648 Software Development
- 990 Software
- 382 Applications
- 182 Command Line
- 5 Compiling/Installing
- 68 Games
- 317 Installation
- Archived
- 2 LFD140 Class Forum
- 1.4K LFS258 Class 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)
