Using a graphical interface on Seapath

Seapath is designed to be used shell based terminal and don’t provide any graphical or modern graphical desktop environment such as Gnome/KDE. However, it is possible to manage a cluster using a web UI interface, such as Cockpit.

What is Cockpit?

Cockpit is a web-based graphical interface designed to make server administration easier. It is capable, for example, in a fancy interface to:

  • Inspect server logs

  • Start containers and virtual machines

  • Configure networks

  • Access terminal

  • Etc

The project is supported by RedHat, and is an active repository with 20K commits since 2013. It provides also a plugin system used to extend Cockpit functionalities.

Cockpit is packaged on both Yocto and Debian.

For plugins hosted on a different repository from the main Cockpit repository, some of them are not yet packaged in Yocto.

Finally, note that Cockpit is not designed for massive deployment/configuration like Ansible does.

Why using Cockpit in Seapath

Debugging each machine in a Seapath cluster can be tricky. Each machine is only accessible though CLI, and some tools used are not that simple to use (Libvirt, Ceph, etc.). Cockpit offers a way to simplify the use of Seapath by gathering all the administration and the monitoring in one place, for all cluster machines.

Keep in mind that Cockpit is an optional feature, and is a graphical abstraction of a shell based CLI. Everything that can be done in Cockpit can be achieve in a CLI.

How does it work?

Cockpit is designed along a client/server schema. When using it on Seapath, one Cockpit instance is installed and running on each cluster machine. Cockpit used in back-end SSH protocol to dial with client and between each cluster cockpit instance. This implementation makes the use more secure, as Cockpit authentication inherits SSH and users configuration deployed on each machine. By doing so, it is easier to give access to Cockpit to only desired users.

Installation

On Seapath Debian

Cockpit is packaged inside ISO image generated by build_debian_iso (https://github.com/seapath/build_debian_iso/blob/main/srv_fai_config/class/99-seapath), and is then installed with APT. Cockpit can be installed by adding the class `SEAPATH_COCKPIT` to the list of classes in used, in `99-seapath` file: https://github.com/seapath/build_debian_iso/blob/main/srv_fai_config/class/99-seapath

On already set up machines it can be installed using apt: 

sudo apt install cockpit cockpit-machines

Be careful to not install cockpit-network plugin, as it depend of network-manager package, which is not currently supported in Seapath.

On Seapath Yocto

Cockpit can be installed in Seapath Yocto by adding it to the IMAGE_INSTALL variable corresponding to the image you are building. For example, if you want to install it on host machines, you must add following lines in file sources/meta-seapath/recipes-core/images/seapath-host-common.inc:

IMAGE_INSTALL:append = " \
    cockpit \
    cockpit-dashboard \
    cockpit-ws \
    cockpit-bridge \
    cockpit-shell \
    cockpit-users \
    cockpit-systemd \
    cockpit-machines \
    cockpit-cluster-dashboard \
    cockpit-cluster-vm-management \
    cockpit-update \
"

This will install cockpit with the basic functionalities and 4 optional plugins (cockpit-machines,cockpit-cluster-dashboard, cockpit-cluster-vm-management, cockpit-update) as described below.

Usage

Once Seapath is installed and configured on a Seapath machine, Cockpit is accessible through the interface connected to your network on the port 9090. It can be accessible in any web browser with the following URL: https://<TARGET_IP>:9090/

You can use the command netstat -tupn to identify the address in use to access to the Cockpit interface.

When connecting directly to a Cockpit instance, you are prompted to log in:

The credentials used to log in are the same as those configured on your Linux system.

By default, for security reason it is not possible to log in using root user.

Once connected, the main menu of Cockpit presents an overview of the machine state:

For a simpler usage, we recommend to use a Cockpit instance hosted on a laptop or a VM, and connect it using Add new host menu entry to connect it to the different Cockpit instance of the Seapath cluster. By doing so, it is possible to gathered all Cockpit instance in one place, and to use one machine as a gateway.

Log inspection

This menu is a graphical abstraction of the journalctl command, and allows you to inspect logs of your machine along different filters (date, priority, etc).

Virtual machines

This menu allows you to manage virtual machines, such as:

  • Creating a VM image from remote repository (Ubuntu, Fedora, etc), or import it from .qcow2 file

  • Edit VM configuration (memory, CPU, machine type, network, etc)

  • Access to VM though VNC or serial connection

Accounts

This menu is used to manage the users of your machine. Among accessible privileges, it is possible to:

  • Add or delete users

  • Give new privileges

  • Force the use of a new password

  • Etc

Services

This menu is used to manage the systemd services of your system, and offers same uses such as systemctl command.

Terminal

A simple bash terminal.

Cluster dashboard

This menu is used to have an overview of the cluster. It displays the following information:

  • Status of the cluster nodes
  • Status of the cluster
  • List of Pacemaker resources deployed
  • Status of the shared storage Ceph


Update

This menu can be used to update a SEAPATH Yocto hypervisor. 

Plugin features:

  • Fetch the swu image
  • Perform the update using SWUpdate
  • Reboot after update
  • Get the status of the last update and the active slot

Cluster VM management

This menu lets you manage all VM in the cluster, unlike cockpit-machine, which has a local scope.

Plugin features:

  • Create a VM
    • Using existing qcow2 and xml files
    • Uploading qcow2 and xml files
  • Perform an action on a VM
    • Start
    • Stop / force stop
    • Enable
    • Disable / force disable
    • Restart
    • Migrate
    • Remove
    • Snapshot (create and apply)
    • Console access

cockpit-cluster-dashboard, cockpit-update and cockpit-cluster-vm-management are unofficial Cockpit plugins. They are packaged on Yocto, but deploying them on Debian SEAPATH will require the use of Ansible.

Cockpit and Cybersecurity

Even if Seapath provides a secure environment, adding Cockpit increase mechanically the attack surface of your system. As already said earlier, Cockpit is a graphical abstraction of the system CLI, and so, inherits from all Cybersecurity rules implemented.

It is important to mention that currently, there is no Cybersecurity hardening configured for Cockpit specifically, but is planned to be in late 2024.

Further works planned for 2024

  • Hardened Cockpit for Cybersecurity