Add HiveOS Telegraf configuration
Signed-off-by: Julien Riou <julien@riou.xyz>
This commit is contained in:
parent
2e90107641
commit
8cfb8fabf8
12 changed files with 209 additions and 1 deletions
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -1,3 +1,6 @@
|
||||||
docker/ssl/*
|
docker/ssl/*
|
||||||
!docker/ssl/.gitkeep
|
!docker/ssl/.gitkeep
|
||||||
docker/environment
|
docker/environment
|
||||||
|
telegraf/hiveos.conf
|
||||||
|
telegraf/hiveos/hiveos.conf
|
||||||
|
telegraf/hiveos/venv
|
||||||
|
|
|
@ -20,13 +20,15 @@ This stack is also known as the **TIG** stack.
|
||||||
This guide uses [Docker](https://www.docker.com/). Ensure you have `docker`, `docker-compose` and `openssl` binaries
|
This guide uses [Docker](https://www.docker.com/). Ensure you have `docker`, `docker-compose` and `openssl` binaries
|
||||||
installed.
|
installed.
|
||||||
|
|
||||||
Write your miner address, grafana and influxdb credentials:
|
Write grafana and influxdb credentials:
|
||||||
|
|
||||||
```
|
```
|
||||||
cp -p docker/environment.example docker/environment
|
cp -p docker/environment.example docker/environment
|
||||||
vi docker/environment
|
vi docker/environment
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Depending on inputs, you should also set the miner address and HiveOS token.
|
||||||
|
|
||||||
Generate a self-signed certificate:
|
Generate a self-signed certificate:
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
MINER_ADDRESS=
|
MINER_ADDRESS=
|
||||||
|
HIVEOS_TOKEN=
|
||||||
GF_SECURITY_ADMIN_USER=admin
|
GF_SECURITY_ADMIN_USER=admin
|
||||||
GF_SECURITY_ADMIN_PASSWORD=
|
GF_SECURITY_ADMIN_PASSWORD=
|
||||||
GF_USERS_DEFAULT_THEME=light
|
GF_USERS_DEFAULT_THEME=light
|
||||||
|
|
BIN
images/hiveos-001.png
Normal file
BIN
images/hiveos-001.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 5.3 KiB |
BIN
images/hiveos-002.png
Normal file
BIN
images/hiveos-002.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 22 KiB |
BIN
images/hiveos-003.png
Normal file
BIN
images/hiveos-003.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 18 KiB |
|
@ -1,3 +1,37 @@
|
||||||
# Telegraf inputs
|
# Telegraf inputs
|
||||||
|
|
||||||
Ensure to replace `MINER_ADDRESS` with your Ethereum wallet address.
|
Ensure to replace `MINER_ADDRESS` with your Ethereum wallet address.
|
||||||
|
|
||||||
|
## HiveOS API
|
||||||
|
|
||||||
|
### Create token
|
||||||
|
|
||||||
|
On your [account](https://the.hiveos.farm/account) page, go to *Authentication Tokens*, search for *Personal Tokens* and
|
||||||
|
create one for `telegraf`:
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Enter your 2FA code if needed:
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Clic on *Show*:
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
And add this value to the `HIVEOS_TOKEN` environment variable (see *Quickstart* section in the [README](../README.md)).
|
||||||
|
|
||||||
|
### Create Telegraf configuration
|
||||||
|
|
||||||
|
```
|
||||||
|
cd hiveos
|
||||||
|
sudo apt install python3-virtualenv
|
||||||
|
virtualenv venv
|
||||||
|
source venv/bin/activate
|
||||||
|
pip install -r requirements.txt
|
||||||
|
read -s HIVEOS_TOKEN
|
||||||
|
export HIVEOS_TOKEN
|
||||||
|
python3 generate.py --verbose
|
||||||
|
unset HIVEOS_TOKEN
|
||||||
|
mv hiveos.conf ../
|
||||||
|
```
|
||||||
|
|
8
telegraf/hiveos/farm.conf.j2
Normal file
8
telegraf/hiveos/farm.conf.j2
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
[[inputs.http]]
|
||||||
|
name_override = "hiveos_farm"
|
||||||
|
urls = ["https://api2.hiveos.farm/api/v2/farms/{{farm_id}}"]
|
||||||
|
headers = {"Content-Type" = "application/json"}
|
||||||
|
headers = {"Authorization" = "Bearer ${HIVEOS_TOKEN}"}
|
||||||
|
data_format = "json"
|
||||||
|
tagexclude = ["url"]
|
||||||
|
tag_keys = ["name", "id"]
|
102
telegraf/hiveos/generate.py
Normal file
102
telegraf/hiveos/generate.py
Normal file
|
@ -0,0 +1,102 @@
|
||||||
|
#!/usr/bin/env python3
|
||||||
|
import requests
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
import logging
|
||||||
|
import argparse
|
||||||
|
|
||||||
|
from jinja2 import Environment, FileSystemLoader
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
RETURN_OK=0
|
||||||
|
RETURN_ERROR=1
|
||||||
|
|
||||||
|
|
||||||
|
def parse_arguments():
|
||||||
|
parser = argparse.ArgumentParser()
|
||||||
|
parser.add_argument('-v', '--verbose', dest='loglevel', action='store_const', const=logging.INFO,
|
||||||
|
help='print more output')
|
||||||
|
parser.add_argument('-d', '--debug', dest='loglevel', action='store_const', const=logging.DEBUG,
|
||||||
|
default=logging.WARNING, help='print even more output')
|
||||||
|
args = parser.parse_args()
|
||||||
|
return args
|
||||||
|
|
||||||
|
|
||||||
|
def setup_logging(args):
|
||||||
|
log_format = '%(levelname)s: %(message)s'
|
||||||
|
logging.basicConfig(format=log_format, level=args.loglevel)
|
||||||
|
|
||||||
|
|
||||||
|
class HiveAPI:
|
||||||
|
def __init__(self, token):
|
||||||
|
session = requests.Session()
|
||||||
|
session.headers.update({'Content-Type': 'application/json', 'Authorization': f'Bearer {token}'})
|
||||||
|
self.session = session
|
||||||
|
self.base_url = 'https://api2.hiveos.farm/api/v2'
|
||||||
|
self.farms = {}
|
||||||
|
for farm_id in self.fetch_farms():
|
||||||
|
self.farms[farm_id] = self.fetch_workers(farm_id=farm_id)
|
||||||
|
|
||||||
|
def fetch_farms(self):
|
||||||
|
r = self.session.get(f'{self.base_url}/farms')
|
||||||
|
r.raise_for_status()
|
||||||
|
farms = r.json().get('data')
|
||||||
|
if farms:
|
||||||
|
return [f.get('id') for f in farms]
|
||||||
|
|
||||||
|
def fetch_workers(self, farm_id):
|
||||||
|
r = self.session.get(f'{self.base_url}/farms/{farm_id}/workers')
|
||||||
|
r.raise_for_status()
|
||||||
|
workers = r.json().get('data')
|
||||||
|
if workers:
|
||||||
|
return [w.get('id') for w in workers]
|
||||||
|
|
||||||
|
|
||||||
|
def create_farm_configuration(farm_id):
|
||||||
|
return create_configuration(template_name='farm.conf.j2', template_variables={'farm_id': farm_id})
|
||||||
|
|
||||||
|
|
||||||
|
def create_worker_configuration(farm_id, worker_id):
|
||||||
|
return create_configuration(template_name='worker.conf.j2',
|
||||||
|
template_variables={'farm_id': farm_id, 'worker_id': worker_id})
|
||||||
|
|
||||||
|
|
||||||
|
def create_configuration(template_name, template_variables):
|
||||||
|
template_path = os.path.split(os.path.abspath(__file__))[0]
|
||||||
|
loader = FileSystemLoader(template_path)
|
||||||
|
env = Environment(loader=loader)
|
||||||
|
template = env.get_template(template_name)
|
||||||
|
text = template.render(**template_variables)
|
||||||
|
return text
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
args = parse_arguments()
|
||||||
|
setup_logging(args)
|
||||||
|
|
||||||
|
token = os.getenv('HIVEOS_TOKEN')
|
||||||
|
if not token:
|
||||||
|
logger.error('Missing HIVEOS_TOKEN environment variable')
|
||||||
|
return RETURN_ERROR
|
||||||
|
|
||||||
|
logger.info('crawling HiveOS API')
|
||||||
|
api = HiveAPI(token=token)
|
||||||
|
|
||||||
|
configurations = []
|
||||||
|
for farm_id in api.farms:
|
||||||
|
logger.info(f'generating configuration for farm {farm_id}')
|
||||||
|
configurations.append(create_farm_configuration(farm_id=farm_id))
|
||||||
|
for worker_id in api.farms[farm_id]:
|
||||||
|
logger.info(f'generating configuration for worker {worker_id}')
|
||||||
|
configurations.append(create_worker_configuration(farm_id=farm_id, worker_id=worker_id))
|
||||||
|
|
||||||
|
logger.info('writing configuration to file')
|
||||||
|
with open('hiveos.conf', 'w') as fd:
|
||||||
|
fd.write('\n'.join(configurations))
|
||||||
|
|
||||||
|
return RETURN_OK
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
sys.exit(main())
|
20
telegraf/hiveos/hiveos.conf
Normal file
20
telegraf/hiveos/hiveos.conf
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
[[inputs.http]]
|
||||||
|
name_override = "hiveos_farm"
|
||||||
|
urls = ["https://api2.hiveos.farm/api/v2/farms/418240"]
|
||||||
|
headers = {"Content-Type" = "application/json"}
|
||||||
|
headers = {"Authorization" = "Bearer ${HIVEOS_TOKEN}"}
|
||||||
|
data_format = "json"
|
||||||
|
tagexclude = ["url"]
|
||||||
|
tag_keys = ["name", "id"]
|
||||||
|
[[inputs.http]]
|
||||||
|
name_override = "hiveos_gpu"
|
||||||
|
urls = ["https://api2.hiveos.farm/api/v2/farms/418240/workers/1150566"]
|
||||||
|
headers = {"Content-Type" = "application/json"}
|
||||||
|
headers = {"Authorization" = "Bearer ${HIVEOS_TOKEN}"}
|
||||||
|
data_format = "json"
|
||||||
|
tagexclude = ["url"]
|
||||||
|
tag_keys = ["bus_number"]
|
||||||
|
json_query = "gpu_stats"
|
||||||
|
[inputs.http.tags]
|
||||||
|
farm_id = "418240"
|
||||||
|
worker_id = "1150566"
|
25
telegraf/hiveos/requirements.txt
Normal file
25
telegraf/hiveos/requirements.txt
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
appdirs==1.4.3
|
||||||
|
CacheControl==0.12.6
|
||||||
|
certifi==2019.11.28
|
||||||
|
chardet==3.0.4
|
||||||
|
colorama==0.4.3
|
||||||
|
contextlib2==0.6.0
|
||||||
|
distlib==0.3.0
|
||||||
|
distro==1.4.0
|
||||||
|
html5lib==1.0.1
|
||||||
|
idna==2.8
|
||||||
|
ipaddr==2.2.0
|
||||||
|
Jinja2==2.11.3
|
||||||
|
lockfile==0.12.2
|
||||||
|
MarkupSafe==1.1.1
|
||||||
|
msgpack==0.6.2
|
||||||
|
packaging==20.3
|
||||||
|
pep517==0.8.2
|
||||||
|
progress==1.5
|
||||||
|
pyparsing==2.4.6
|
||||||
|
pytoml==0.1.21
|
||||||
|
requests==2.22.0
|
||||||
|
retrying==1.3.3
|
||||||
|
six==1.14.0
|
||||||
|
urllib3==1.25.8
|
||||||
|
webencodings==0.5.1
|
13
telegraf/hiveos/worker.conf.j2
Normal file
13
telegraf/hiveos/worker.conf.j2
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
[[inputs.http]]
|
||||||
|
name_override = "hiveos_gpu"
|
||||||
|
urls = ["https://api2.hiveos.farm/api/v2/farms/{{farm_id}}/workers/{{worker_id}}"]
|
||||||
|
headers = {"Content-Type" = "application/json"}
|
||||||
|
headers = {"Authorization" = "Bearer ${HIVEOS_TOKEN}"}
|
||||||
|
data_format = "json"
|
||||||
|
tagexclude = ["url"]
|
||||||
|
tag_keys = ["bus_number"]
|
||||||
|
json_query = "gpu_stats"
|
||||||
|
[inputs.http.tags]
|
||||||
|
farm_id = "{{farm_id}}"
|
||||||
|
worker_id = "{{worker_id}}"
|
||||||
|
|
Reference in a new issue