linux-dash-monitoring-agent

Linux Dash monitoring agent.

Usage no npm install needed!

<script type="module">
  import linuxDashMonitoringAgent from 'https://cdn.skypack.dev/linux-dash-monitoring-agent';
</script>

README

Monitoring Agent

Linux Dash monitoring agent for servers.

To install Linux Dash, Please see linux-dash/cli

Description

This tool contains a node server which is open to websocket connections from Linux Dash Service (LDS). It also periodically reports server status to LDS.

The agent is an internal depedency and should not be directly installed.

Linux Dash Service: Refers to a publicly accessible subset of Linux Dash API endpoints.

Requirements

When starting the monitoring agent, a User Access Key is required via --user-access-key [key] flag

Example:

node linux-dash-monitor.js --user-access-key ABC-123-456

Settings

Settings may be updated via config.json in the root directory of the monitoring agent module.

They may also be updated via flags

node linux-dash-settings.js --update [key] [value]

List of Setting Defaults

Key Default Description
PORT 8080 Server port on which linux dash node server listens for connection requests from LDS
ET_INTERVAL 60000 Interval in milliseconds at which the monitoring agent phones home to LDS

LDS Endpoints

Name Method Endpoint
VALIDATE_USER POST /user/:userId/servers
ADD_SERVER POST /user/:userId/servers/
UPDATE_SERVER PUT /user/:userId/servers/:serverId
DELETE_SERVER DELETE /user/:userId/servers/:serverId

Architecture

  • Upon starting, the agent
    • validates User Access Key via LDS:VALIDATE_USER
    • registers Server via LDS:ADD_SERVER
      • The serverId received as response is stored in process env.
  • At Settings:ET_INTERVAL, the agent reports the following to LDS:UPDATE_SERVER`:
    • RAM utilization
    • CPU utilization
    • Uptime
  • Upon exiting (error or stop), the agent
    • Server is de-registered via LDS:DELETE_SERVER
  • Upon a websocket connection from LDS, the monitoring agent begins to stream all available system stats to the originating dashboard
  • Replace legacy python modules with JS streams
    • speedtest
  • Remove legacy module config
  • Remove internet speed module (sh)