Code Monkey home page Code Monkey logo

mother-of-dragons's Introduction

Build Status Maintainability Test Coverage PyPI version Dependabot Status

πŸ²πŸ‘ΈπŸ”₯πŸ‰ Mother of Dragons πŸ²πŸ‘ΈπŸ”₯πŸ‰

Be smart. Be mother. Be Mother of Dragons.

DragonMint/Innosilicon T1/T2/B29/B52/A9 management tool based on dragon-rest

Mom with dragons

Features

Mother of Dragons can:

  • Auto-detect new dragons on your local network and configure them: just plug in your miners and they're ready to go!
  • Scale easily to 1000s of miners using the gevent library
  • Collect metrics from dragons and forward them to statsd
  • Automatically update to the latest firmware version when new miners are added
  • Keep your dragons happy and healthy by rebooting them when they’re sick
  • Apply different pool configurations to different dragons based on their MAC address
  • Should work with both most DragonMint or Innosilicon branded miners
  • Free you up from having to manually manage your dragons so you can go vacation like a movie star 😎

How it works

When you run mother-of-dragons, it will start 3 separate closed loops:

  • Scan loop: scans the local network at a specified interval (main.scan_interval) looking for dragons. It checks for the dragons by making an HTTP request and checking the result. The scan only works if your local network allows traffic on port 80 to all the specified IPs, which you define with the main.local_network.network parameter.

    • When a new dragon is found, the dragon will be configured with the desired pool and autotune. If you specify a pool configuration with a MAC address, mother will assign the pool config with the matching address.

    • If auto_upgrade is set, dragons will be updated to the latest firmware version when added.

  • Metrics loop: fetches metrics from every known dragon according to main.statsd.interval and forwards those metrics to statsd provided you have configured main.statsd.host.

  • Health loop: checks each dragon according to the specified interval health_check_interval and may (optionally) reboot a dragon if:

    • The dragon has 1 or more devices (ASIC boards) marked as 'Dead'.

    • The dragon has 1 or more devices which have been below health_hashrate_minimum for at least health_hashrate_duration.

The tool itself can be run on a low-cost server, such as a Raspberry Pi or Intel NUC. If you intend to set up a Prometheus/Grafana dashboard for metrics, it's probably worthwhile to use a more powerful machine such as an Intel NUC with adequate storage.

It's recommended you use a mainline Linux distro, such as Debian, Ubuntu or CentOS.

Super Quickstart

$ pip install mother-of-dragons
$ mother-of-dragons --print-config-toml > config.toml
### Edit config.toml to your liking ###
$ mother-of-dragons --config=config.toml

Alternatively, using Docker:

$ docker run -it mother-of-dragons --print-config-toml
...

Configuration

See the default config.toml for details on configuration.

Usage

usage: mother-of-dragons [-h] [-c CONFIG] [--print-config-toml]
                         [--print-config-json]

Management tool for DragonMint/Innosilicon miners.

optional arguments:
  -h, --help            show this help message and exit
  -c CONFIG, --config CONFIG
                        Path to config file in either TOML or JSON format.
                        (default: config.toml)
  --print-config-toml   Print default config in TOML and exit (default: False)
  --print-config-json   Print default config in JSON and exit (default: False)

The script is meant to be run continuously within the same local network as your dragons. The script can be installed with Python's pip by running a pip install mother-of-dragons.

An example systemd unit might look like this (assuming the user mother-of-dragons exists):

[Unit]
Description=mother-of-dragons
After=network.target

[Service]
ExecStart=/usr/local/bin/mother-of-dragons \
  --config=config.toml
Restart=always
User=mother-of-dragons
Group=users

[Install]
WantedBy=multi-user.target

Sample Dashboard

One of the significant value-adds of this tool is the StatsD integration. It allows you to forward metrics to Prometheus/Grafana, DataDog, or another time series metrics and dashboarding tool.

Sample Grafana Dashboard

mother-of-dragons's People

Contributors

brndnmtthws avatar dependabot-preview[bot] avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar

mother-of-dragons's Issues

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    πŸ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. πŸ“ŠπŸ“ˆπŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❀️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.