/SuperGreenCloud

A bunch of softwares that run on the cloud to remotely monitor and (soon) control your SuperGreenDrivers.

Primary LanguageHTMLGNU General Public License v3.0GPL-3.0

SuperGreenLab

SuperGreenLab

Table of Contents

SuperGreenCloud

Collection of pre-configured softwares to run the SuperGreenOS's cloud.

ScreenShot

Features

  • Everything in a docker-compose.yml for easy deployement
  • MQTT sink port to receive all logs from the driver
  • Minimal log post-processor to redirect to:
    • Redis: stores all last values of each keys sent through the logs
    • Promethes: stores all numeric values as timeseries for monitoring and alerts
    • Elasticsearch (COMMENTED OUT): indexation and data analysis engine, indexes all logs for further analysis, haven't used it yet.
  • Prometheus' alertManager: Allows to describe alert conditions from prometheus timeseries. Then produces alerts on various bias, slack, sms, pigeon, whatnot..
  • cAdvisor/node-exporter: The server running the cloud's own monitoring.
  • Grafana: Produce nice graphs and dashboard from Prometheus timeseries.
  • Kibana (COMMENTED OUT): Produce nice graphs and dashboard from Elasticsearch timeseries.
  • Update http server for Over-The-Air (OTA) updates for the SuperGreenOS.

TODO

  • Better way to upload the new builds' firmware update files

Quickstart

Only requirement in a working docker installation:

Configuration

There's not much to configure:

  • mqtt login/pass: search for mqtt_username and mqtt_password in docker-compose.
  • domain names used: search for VIRTUAL_HOST in docker-compose
  • http access passwords in nginx/htpasswd/

Installation

Now that docker is installed and running, clone this repo, and from the repo's directory run the command docker-compose up

git clone git@github.com:supergreenlab/SuperGreenCloud.git
cd SuperGreenCloud
docker-compose up

When ran locally you might want to have the ports of each services accessible directly, just uncomment the ports sections in docker-compose.yml.

Attach firmware

In your firmware intance, set the BROKER_URL value through the http API to point to your installation, be sure to have configured the wifi access.

Should be somehting like mqtt://sink.supergreenlab.com:1883. (If running locally, use your IP address, whatever the domain you set in docker-compose.yml)

Restart the firmware.

View logs remotely

The first thing we can do is view the MQTT broker's logs coming inside our log post-processor:

docker attach --no-stdin --sig-proxy=false supergreencloud_mqttparser_1

You can safely Ctrl+C to exit that.

If nothing happens there might be something wrong, directly viewing the firmware's logs through usb will give hints.

Graphs, Dashboards and monitoring

At that point we have:


firmware -> MQTT -> post-processor -> Prometheus

So we're ready to view our data as graphs.

Just point to the URL you specified in your docker-compose.yml with your browser, if you left the default, you'll have grafana.supergreenlab.com, DON'T FORGET TO ADD IT TO YOUR /etc/hosts OR THAT WON'T BE WHAT YOU THINK IT BE.

Default access are:

  • login: supergreen
  • password: multipass

Now everthing should be setup for you to start their tutorial from this section.