Use case toturials

Last changed: 2024-09-17

Changing network interface for a running instance

It is possible to change the network interface (i.e., from dualStack to IPv6) without rebooting or rebuilding your VM instance. This is possible between all available networks in the dashboard. Changing network interface will change the IP addresses of the instance. This toturial demonstrates how to change the network interface from dualStack to IPv6.

Tip

Set root password!

It is a good idea to set the root password prior to doing any network changes. The instance can then be accessed using the “Console” view in the dashboard.

In the Dashboard:

  1. In the drop-down menu of your running instance, select “Detach Interface” (Figure 1).

    _images/uc-if-1.png

    Figure 1: Drop-down menu of the running instance (in Compute -> Instances). The first three options are shown. We will use all three options in this toturial.

  2. Select the network to detach under “Port”. In Figure 2, a dualStack network configuration that is currently used by the running VM instance, is selected for detachment.

    _images/uc-if-2.png

    Figure 2: Selecting existing network to detach.

  3. In the drop-down menu of your running instance, select “Attach Interface” (Figure 1).

  4. Select the new (suggested) network to attach. In Figure 3, a new IPv6 network is selected.

    _images/uc-if-3.png

    Figure 3: Selecting new network to attach.

Tip

Automatic removal of security groups

Note that all security groups that used the network that you detached were removed from the instance as a result of detaching the interface. Because of this, you need to re-add the affected security group(s). In the drop-down menu of the running instance (Figure 1), select “Edit Instance”. In this toturial, a security group for SSH access is re-added as shown in Figure 4.

_images/uc-if-4.png

Figure 4: Adding security group for SSH access.

Linux VM user management

Your Linux VM will come with a root user in addition to a cloud user as described in Current GOLD images.

User management follows standard Linux procedures. Below are some useful commands:

Table 1: Linux commands for basic user management.

Command

Description

Use case

openssl rand -base64 6

Generate random 6-digit password

Interactive

sudo adduser <username>

Create a new user with a password

Interactive

sudo adduser --disabled-password <username>

Create a new user with disabled password

When creating users with key-based login only. The user cannot be authenticated using password

sudo useradd -m -s /bin/bash <username>

Create a new user without specifying its password

-“-, non-interactive

sudo passwd <username>

Set password for user

Interactive

sudo gpasswd -a <username> <groupname>

Add user <username> to the group <groupname>

Ex. adding user admin to group sudo

sudo passwd -l <username>

Disable (lock) the password for <username>

The user can no longer be authenticated using password. Login to the user with other authentication methods will still work

google-authenticator

Run 2FA setup for scanning QR code with OTP mobile app

When having set up SSH to use the Google Authenticator PAM

Example:

Creating the additional user student with disabled password. From root:

adduser --disabled-password student

This should also create the home directory /home/student.

SSH keys

The public SSH key you selected in the in the wizard when creating the VM instance, was installed for the cloud and root user. However, by default, public key-based SSH login is only enabled for the cloud user. If you like to enable this for root (not recommended), you need to edit the correspondig settings in /etc/ssh/sshd_config, followed by a restart of the ssh service.

Example:

The manual process of installing the public SSH key for student is the following (from root):

mkdir -p /home/student/.ssh
# Substitute KEY with the public SSH key received from user student
echo KEY >> /home/student/.ssh/authorized_keys

2FA/MFA

You may want to setup the VM to use a pluggable authentication module (PAM) with your public SSH key and mobile one-time-password (OTP) app. Google Authenticator provides such a setup. The installation may vary with Linux distribution. For Debian-based systems, the package to install is libpam-google-authenticator and configuration is performed in /etc/pam.d/sshd and /etc/ssh/sshd_config.

Example: Assuming that Google Authenticator PAM is setup correctly with the SSH server in the VM. From root:

su - student
google-authenticator

A good default is to say yes (‘y’) to all options. A QR code should be printed. The student needs to somehow scan this QR code using any mobile OTP app. Additionally, the file /home/student/.google_authenticator will be created together with the generated QR code. This file can be deleted if you wish to re-run the google-authenticator command to get a new QR code.

Sudo

Passwordless sudo right is granted to the cloud user. This means that you may want to use sudo to set the root password while logged in with the cloud user, as described in How do I set the root password for my Linux instance?. The config file enabling passwordless sudo for the cloud user should be located in /etc/sudoers.d/. If you want passwordless sudo right for additional users, you can edit this file accordingly.

Example: To grant sudo right to user student, add user student to the group sudo. Then, find and edit the file where the cloud user is granted sudo right. For Ubuntu, the file is /etc/sudoers.d/90-cloud-init-users. From root:

gpasswd -a student sudo
echo -e '# User rules for ubuntu\nstudent ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers.d/90-cloud-init-users

If you followed the examples in this toturial, note that student can change to any user in the VM (using sudo su - <username>).

To prevent student from accessing other users, student and any other users in the VM should not have sudo rights, as well as a disabled password.

Any user logged into the VM may change to another user with password enabled (using su - <username>). This is a reason to create users with the –disabled-password option.

Shared account:

A shared user group1 may be created with password, and the password can be shared within the group. All members of the group should then be able to login to the VM using user group1 and shared password simultaneously. Shared accounts may also be accomplished by sharing the full (private+public) SSH key and possibly OTP app. However, this use case would go against introducing these increased security measures in the first place.

Lightweight Linux remote desktop environment

This is a tutorial on how you may setup a minimal graphical desktop environment (DE) in your linux VM, and access it remotely using the Remote Desktop Protocol (RDP) over a Secure Shell (SSH) tunnel.

  • LXDE: Lightweight X Desktop Environment

  • xrdp, a VDI server using the Remote Desktop Protocol (RDP) protocol, and that starts isolated X sessions

  • Web browser (firefox)

  • File browser (pcmanfm)

  • File de-compress/compress tool (xarchiver)

  • Text processor (mousepad)

  • Terminal emulator (lxterminal)

  • Decent theme (shimmer themes).

Abbreviations:

RDP: Remote Desktop Protocol, SSH: Secure Shell, GUI: Graphical User Interface, VDI: Virtual Desktop Infrastructure, DE: Desktop Environment

Note

The specific steps required for GUI to your linux VM instance depend heavily on the software and distribution. The steps in this toturial are likely to change in the future. The last edit was 2024-09-04.

  1. Launch a new linux VM instance

  • Image: GOLD Ubuntu 24.04 LTS

  • Flavor: m1.medium (4 GB RAM, 20 GB OS disk)

  • Network: IPv6

  • Add a security group that allows SSH to the instance for IPv6

  • Add your SSH key

In this, toturial the instance is named vdi

  1. SSH login with TCP tunnel for RDP connection

    ssh ubuntu@<IPv6 address> -L 45000:localhost:3389
    

    where we choose a high numbered port that we want to use to access our DE on localhost on our local machine.

    If you are on a IPv4 only network such as eduroam, you can connect through login.uio.no or login.uib.no, e.g., for UiO users

    ssh -J <username>@login.uio.no ubuntu@<IPv6 address> -L 45000:localhost:3389
    

    where <username> is your UiO username. This requires that your SSH key is installed on the login host.

  2. Set password for the cloud user (will be asked with VDI login)

    sudo passwd ubuntu
    
  3. Install software

    sudo apt update -y && sudo apt install -y xrdp openbox-lxde-session lxappearance lxterminal xarchiver mousepad shimmer-themes firefox
    
  4. First VDI login

    Use a RDP Client to connect to localhost:45000. The client to use on Windows is the built-in Windows Remote Desktop. A good Linux client is Remmina.

    You will be asked to login as user ubuntu with the password you set previously.

  1. Necessary fixes

    • Fix lxpanel bug for Ubuntu 24.04 LTS [1] [2]

      Right click on (the visible part of the) panel -> Panel Settings -> Panel Applets, select Desktop Pager, then click Remove

    • Set decent theme

      Preferences -> Customize Look and Feel, select Greybird-dark -> Apply -> Close

      Preferences -> Openbox Configuration Manager, select Numix -> Close

      Right click on panel -> Panel Settings -> Appearance, under Background, select System theme -> Close

    • Disable screensaver to avoid unwanted CPU consumption

      Preferences -> XScreenSaver Settings -> Mode: Disable Screen Saver -> Close

    • (Windows only) Fix Windows Remote Desktop specific issues [3]

      Enable shared clipboard as well as drive redirection in Windows Remote Desktop client (to thinclient_drives mount): Make sure Windows Remote Desktop client is configured properly by unchecking Printers and Smart cards. Select the drive(s) to redirect, as well as Clipboard, then save the profile.

  2. Finish

    This toturial used the Remmina RDP client with custom screen resolution set to 1920x1080 (Figure 5).

    _images/uc-vdi-1.png

    Figure 5: Screenshot of the virtual DE with the GUI tools installed in this toturial.

Footnotes