2
0
mirror of https://github.com/pikvm/pikvm synced 2024-11-10 13:10:37 +00:00
pikvm/docs/vnc.md
Maxim Devaev 6944626b8d update
2023-03-14 02:14:43 +02:00

3.5 KiB

VNC

As an alternative to the web interface, you can use VNC with various desktop clients. The main advantage of VNC over the browser is the ability to expand the image to the full screen, as well as complete interception of all keyboard keys. In some cases, VNC will be more responsive than the browser, especially on weak computers.

!!! warning Don't use VNC without X.509 or TLS encryption on untrusted networks! Otherwise your password will be transmitted over the network in plain text. Unfortunately, this is the reality of the VNC protocol.

!!! note VNC and its varients/TeamViewer/RDP to a system uses the target systems framebuffer IE local display, VNC usage for PiKVM accesses the stream, there will still be a 100-200ms latency and cannot be compared with the other software solutions.

  * NORMAL USAGE: *VNC/TM/RDP -> Target system*
  * PiKVM USAGE: *VNC -> PiKVM (hardware capture, processing) -> Target system*

Enabling VNC on the PiKVM side

  1. Switch PiKVM filesystem to read-write mode using command rw.

  2. Optional: Change client's keyboard layout if you're using an non-US keyboard. To do this edit file /etc/kvmd/override.yaml:

    vnc:
        keymap: /usr/share/kvmd/keymaps/ru
    

    All available keymaps are located in /usr/share/kvmd/keymaps:

  3. Optional: This step is not nessessory if using TigerVNC as it uses the webgui user:pass. Some VNC clients (for example TightVNC) can't use user/password authentication. In this case you can enable passphrases mode in /etc/kvmd/override.yaml:

    vnc:
        auth:
            vncauth:
                enabled: true
    

    To set passphrases edit file /etc/kvmd/vncpasswd.

  4. Enable kvmd-vnc daemon. VNC will be available on the port 5900: systemctl enable --now kvmd-vnc.

  5. Switch filesystem back to read-only: ro.

!!! note With enabled 2FA, you will need to add the one-time code to the password without spaces. That is, if the password is foobar and the code is 123456, then you need to use foobar123456 as the password. Also note that vncauth (step 3) will not work with 2FA.

Configuring the client

We recommend TigerVNC for a better experience on desktop.

If you are using PiKVM V3+ or DIY based on CSI bridge, you can try the latest version (>= 1.13.0) of TigerVNC with H.264 support. It will improve performance and save traffic.

H.264 is available in binary builds for Windows, for other OS it needs to be compiled manually (before that, you need to install ffmpeg libraries).

Here are our recommended settings for TigerVNC:

Compression tab Security tab
If your client does not support H.264, choose Tight

For iOS and Android the recommended application is bVNC:

Unsupported clients

  • RealVNC - Does not support most widely used open VNC protocol extensions.
  • Remmina - Slightly imperfect algorithms for matching settings with the server, we are working on it.
  • Guacamole - Incorrectly implements vencrypt, no JPEG compression.
  • Vinagre - Incorrectly implements vencrypt, dead.