Monitor SlapOS Network

Monitor SlapOS Network

This tutorial will guide through the process of setting up and using the SlapOS Monitor, a tool to observe the health of a SlapOS network.

Think of SlapOS providing a macro view on a network and the Monitor giving the corresponding micro view into underlying process, logs and Promises.

This tutorial requires to have a computer with a SlapOS node installed and as well as access to an account on a SlapOS Master (install SlapOS Master). It is also mandatory to have a Frontend Slave to access the SlapOS Master (the steps are included in the setup of the SlapOS node (COMP-0).

Table of Content

  • Monitor Access
  • Monitor Usage
 

Monitor Access

The SlapOS Monitor is a stand-alone application hosted on Nexedi's OfficeJS appstore (more information on OfficeJS).

The Monitor can connect to and observe any SlapOS deployment. It covers network and individual computers status as well as partition processes running. Once connected with a SlapOS deployment, the Monitor is tightly integrated into the SlapOS Master Dashboard and can be accessed in multiple ways which are alos shown in this section.

Accessing the Monitor

SlapOS Interface - Monitor Menu Access

The easiest way to access the monitor is via the Access button on the side menu of the SlapOS Dashboard. Click Access Monitor in the left menu.

Import SlapOS Configuration

SlapOS Interface - Import Configuration

The Monitor has a different side panel than the SlapOS Dashboard:

  • Promises: all promises of all services on all computers (see next slides).
  • Software Instances: all instances (hosting subscriptions) of all services on all computers.
  • Hosting Subscriptions: all services from all computers (similar to SlapOS Dashboard).
  • Monitor Configurations: all data sources (instances), loaded from master (see below).
  • Syncronisation: update the monitor data by querying all services and crawling data.
  • OPML Import / Export: used to import and export the current configuration.

By default, the Monitor is not connected to any application. It is necessary to load a deployment configuration (called data sources) to "feed" the Monitor with the network parameters to observe. This configuration can be provided directly (using Settings Content) or via a remote storage.

To continue select SlapOS Master ERP5 and click Proceed

Launch Synchronisation

SlapOS Interface - Provide Master Url

The monitor requires the configuration of your instance to sync. To provide it, paste the the Frontend url of your SlapOS Master and append /hateoas/. In the example, this is https://master.slaptest.erp5.net/hateoas/.

The Frontend url can be found in the connection parameters of the Frontend Slave being used to access the SlapOS Master. Note, it is not possible to use the monitor with the default IPv4 address.

Click Proceed to launch synchronisation of SlapOS Master and the monitor.

Promise List

SlapOS Interface - Monitor Promise List

Once synchronisation finishes the Monitor will load and display the list of Promises for the SlapOS Master.

Promises in SlapOS are executables doing arbitrary tasks and exiting with exit code 0 ("it works") or greater ("it doesn't work"). Everything in SlapOS is based on such Promises in order to automate the management of a SlapOS network. In case a Promise fails (eg a computer not responding), a ticket will be created on the SlapOS Master in order for a user to follow up with this failing promise (more info in Understanding SlapOS Promises).

Note, that the Monitor reports detailed instance status but does not provide any management functions such as handling of tickets. This has to be done in the SlapOS Master Dashboard which in turn only displays the global status of an instance (green, orange, red). Also note that the Monitor works autonomously from the SlapOS Master, so even if the Master is down, the Monitor will continue working.

Finally, as the Monitor was not accessed for a specific computer or instance, it will show the global network status. Clicking on one of the red/yellow/green computer or instance buttons will load the monitor with a scope set on the respective computer/instance.

Filter Promise List

Monitor Interface - Promise List Filter

You can use the Filter button in the subheader and the search field to filter the list of promises.

Filter Failing Promises

Monitor Interface - Filter Failing Promises

One common use case for the filter is to display only erroring promises by filtering for the status field with exact match ERROR. This helps to keeping track of what to fix only.

Head back to the SlapOS Dashboard to see the different ways to accessing the monitor.

Access Monitor for a Site

SlapOS Interface - Access Monitor for a Site

On the map displaying your sites (how to classify computers in a network), click on the small screen icon next to the site name (next to FIRST-SITE on the map!).

Monitor Software Instances for a Site

Monitor Interface - Software Instance Promises for a Site

This will list all promises for software instances deployed on this computer. In the example, the computer is the COMP-0 machine which runs an instance of the Re6st Registry for connecting nodes in a network, the Frontend (Apache) for managing access between nodes and the monitor as well as the Frontend Slave (providing the url we used to connect to the monitor). The status of all instances can be monitored here.

Head back to the SlapOS Master Dashboard

Access Monitor for an Instance

SlapOS Interface - Access Monitor for a Service

In the side menu, click on Services to access all services on your SlapOS Network. Click on one of the Instances buttons on a service.

Monitor Hosting Subscriptions of a Service

Monitor Interface - Subscription Promises for a Service

This will show the list of Hosting Subscriptions of this service (a Hosting Subscription is the instantiation of an installed software on a computer partition of a SlapOS node) along with their status.

Head back to the SlapOS Master Dashboard.

Access Monitor for a Computer

SlapOS Interface - Access Monitor for a Server

In the side menu, click on Servers to access all services on your SlapOS network. Click on one the Computers without any partitions (instances).

Monitor Instances of a Computer

Monitor Interface - Instance Promises of an empty server

If the server is still "empty" (no instances of software have been installed yet), the monitor will not report anything.

Monitor Usage

This section will show how the monitor can be used to analyse data collected from a SlapOS network.

Access Software Instance on Monitor

Monitor Interface - Software Instance List

Stay in the Monitor and click Software Instances to access the list of all instances in the network. A software instance is one instantiated and configured instance of a software available on the SlapOS Master and installed on a computer).

Click on any of the available software instances (the table at the bottom).

Monitor Software Instance Details

Monitor Interface - Software Instance Details

The detailed view of an instance will provide configuration and promise status information for this instance. All promises are listed in the bottom table, the global promise status is shown on top.

Click on of the promises in the bottom table.

Monitor Software Instance Promise History

Monitor Interface - Software Instance Promise History

This is the overview of the history of promise failures (similar to the graph displayed on the previous menu).

Go back to the software instance (clicking on the header). Then click on Processes in the subheader.

Monitor Software Instance Promise Details

Monitor Interface - Software Instance Promise Details

This will show details on this specific Promise and the processes it contains.

Click on "Resources" in the subheader.

Monitor Software Instance Resource Details

Monitor Interface - Software Instance Resource Details

This will show details on the resource consumption.

You can switch back to the processes by clicking Processes in the subheader, then click in the top navigation to access the main instance view again.

Monitor Software Instance Private Files

Monitor Interface - Software Instance Access Private Files

Click on Access Private Files.

Monitor Software Instance Log Files

Monitoring Interface - Software Instance Private Files

This allows to access the private files of this computer partition.

Click on log to continue

Monitor Software Instance Log Files

Monitoring Interface - Software Instance Log Files

This will open the folder of log files. Open one of the files.

Monitor Software Instance Log File

Monitoring Interface - Software Instance Log File

Accessing instances like this allows to easily monitor and dig down into log files of a specific service in case of a failing Promise for example.

Thank You

Image Nexedi Office
  • Nexedi SA
  • 147 Rue du Ballon
  • 59110 La Madeleine
  • France