Monero public node aggregator.
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Go to file
lza_menace 2fb28e90fb split resources out 2 years ago
conf add tor support 4 years ago
xmrnodes split resources out 2 years ago
.gitignore add mirror to monero infodump site 2 years ago
Dockerfile-torsocks add tor support 4 years ago
LICENSE Initial commit 4 years ago
Makefile update docs, remove bin, fix ux on no data 2 years ago
README.md add more info in docs 2 years ago
crontab store crontab sample 3 years ago
docker-compose.yaml add tor support 4 years ago
env-example update docs, remove bin, fix ux on no data 2 years ago
manage.sh update docs, remove bin, fix ux on no data 2 years ago
migrate_schema.sh add simple schema migration script 2 years ago
requirements.txt update docs, remove bin, fix ux on no data 2 years ago
scrape.py split resources out 2 years ago

README.md

monero.fail

Monero node tracker

Setup

Tools you will need:

  • Docker # apt-get install docker.io
  • docker-compose # apt-get install docker-compose
  • python3 (linux os will have this)
  • python3-venv # apt-get install python3-venv

Development

I have provided a Makefile with some helpful stuff...make sure to install make to use it.

The map portion of the service requires the GeoLite2 db...the make setup command fetches a copy via wget.

# install python virtual environment and install application dependencies
make setup

# default configs work out of the box, modify .env if needed
# setup .env
cp env-example .env
vim .env

# run services (tor, i2p, etc)
make up

# run development server
make dev

# access at http://127.0.0.1:5000

Background Tasks

There are 3 things that need to run in the background:

  • validating nodes that have been added
  • checking existing node health
  • scraping peer lists

I accomplish this via crontab and some management scripts.

./manage.sh validate
./manage.sh check
./manace.sh get_peers

Production

For production, update SERVER_NAME in .env to your production URL/domain. Use manage.sh (or provided Makefile) to serve the Flask process using Gunicorn.

./manage.sh prod

Runs the Gunicorn process on port 4000. Setup a web server to proxy requests to that port.

Kill production Gunicorn with make kill.