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
- 51 LFX Mentorship
- 104 LFX Mentorship: Linux Kernel
- 576 Linux Foundation IT Professional Programs
- 304 Cloud Engineer IT Professional Program
- 125 Advanced Cloud Engineer IT Professional Program
- 53 DevOps Engineer IT Professional Program
- 61 Cloud Native Developer IT Professional Program
- 5 Express Training Courses
- 5 Express Courses - Discussion Forum
- 2.1K Training Courses
- 19 LFC110 Class Forum
- 7 LFC131 Class Forum
- 27 LFD102 Class Forum
- 158 LFD103 Class Forum
- 20 LFD121 Class Forum
- 1 LFD137 Class Forum
- 61 LFD201 Class Forum
- 1 LFD210 Class Forum
- LFD210-CN Class Forum
- 1 LFD213 Class Forum - Discontinued
- 128 LFD232 Class Forum
- LFD237 Class Forum
- 23 LFD254 Class Forum
- 611 LFD259 Class Forum
- 105 LFD272 Class Forum
- 1 LFD272-JP クラス フォーラム
- 1 LFD273 Class Forum
- 2 LFS145 Class Forum
- 25 LFS200 Class Forum
- 739 LFS201 Class Forum
- 1 LFS201-JP クラス フォーラム
- 11 LFS203 Class Forum
- 75 LFS207 Class Forum
- 300 LFS211 Class Forum
- 54 LFS216 Class Forum
- 47 LFS241 Class Forum
- 41 LFS242 Class Forum
- 37 LFS243 Class Forum
- 11 LFS244 Class Forum
- 37 LFS250 Class Forum
- 1 LFS250-JP クラス フォーラム
- LFS251 Class Forum
- 141 LFS253 Class Forum
- LFS254 Class Forum
- 1.1K LFS258 Class Forum
- 10 LFS258-JP クラス フォーラム
- 93 LFS260 Class Forum
- 132 LFS261 Class Forum
- 33 LFS262 Class Forum
- 80 LFS263 Class Forum
- 15 LFS264 Class Forum
- 11 LFS266 Class Forum
- 18 LFS267 Class Forum
- 18 LFS268 Class Forum
- 23 LFS269 Class Forum
- 203 LFS272 Class Forum
- 1 LFS272-JP クラス フォーラム
- LFS274 Class Forum
- LFS281 Class Forum
- 236 LFW211 Class Forum
- 172 LFW212 Class Forum
- 7 SKF100 Class Forum
- SKF200 Class Forum
- 903 Hardware
- 219 Drivers
- 74 I/O Devices
- 44 Monitors
- 116 Multimedia
- 209 Networking
- 101 Printers & Scanners
- 85 Storage
- 763 Linux Distributions
- 88 Debian
- 66 Fedora
- 15 Linux Mint
- 13 Mageia
- 24 openSUSE
- 142 Red Hat Enterprise
- 33 Slackware
- 13 SUSE Enterprise
- 357 Ubuntu
- 479 Linux System Administration
- 41 Cloud Computing
- 70 Command Line/Scripting
- Github systems admin projects
- 95 Linux Security
- 78 Network Management
- 108 System Management
- 49 Web Management
- 68 Mobile Computing
- 23 Android
- 30 Development
- 1.2K New to Linux
- 1.1K Getting Started with Linux
- 538 Off Topic
- 131 Introductions
- 217 Small Talk
- 22 Study Material
- 826 Programming and Development
- 278 Kernel Development
- 514 Software Development
- 928 Software
- 260 Applications
- 184 Command Line
- 3 Compiling/Installing
- 76 Games
- 316 Installation
- 61 All In Program
- 61 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)