cdcca37ce0
* route txes through tor and i2p proxies * include entry script * update docker-files with dependency order and use new monerod command * Update dockerfiles/i2p Co-authored-by: nahuhh <50635951+nahuhh@users.noreply.github.com> * Update dockerfiles/i2p Co-authored-by: nahuhh <50635951+nahuhh@users.noreply.github.com> * Update dockerfiles/i2p-entrypoint.sh Co-authored-by: nahuhh <50635951+nahuhh@users.noreply.github.com> * Update dockerfiles/monero-entrypoint.sh Co-authored-by: nahuhh <50635951+nahuhh@users.noreply.github.com> * Update dockerfiles/monero-entrypoint.sh Co-authored-by: nahuhh <50635951+nahuhh@users.noreply.github.com> * remove q install and dns, specify private ip for tor/i2p * fix ips * use ubuntu 22.04 for tor build * fix i2pd configs * adjust i2p config, no depends on monerod * use gunicorn for flask app, faster restart time --------- Co-authored-by: nahuhh <50635951+nahuhh@users.noreply.github.com> |
6 days ago | |
---|---|---|
.github/workflows | 1 year ago | |
dockerfiles | 6 days ago | |
files | 10 months ago | |
static | 1 year ago | |
.dockerignore | 1 year ago | |
.gitignore | 1 year ago | |
LICENSE | 4 years ago | |
Makefile | 4 years ago | |
README.md | 1 year ago | |
cloud-init.sh | 1 year ago | |
docker-compose.full.yaml | 6 days ago | |
docker-compose.yaml | 6 days ago | |
env-example | 4 years ago | |
release.sh | 3 weeks ago |
README.md
docker-monero-node
Simple way to run a Monero node with some basic monitoring tools packaged in.
Leverages Prometheus, Grafana, nodemapper, and monero-exporter on top of monerod
.
Setup
The only requirements are Docker and Docker Compose. Ensure those are installed on your system. There's an optional Makefile
provided if you'd like to use that, just ensure make
is installed.
# Clone and enter the repository
git clone https://github.com/lalanza808/docker-monero-node
cd docker-monero-node
# OPTIONAL: Setup Grafana password, blockchain storage location, or port and container image tag overrides
cp env-example .env
vim .env
# Build containers
docker-compose build # make build
The following ports will be bound for monerod
by default, but you can override in .env
:
- 18080 # p2p
- 18081 # restricted rpc
- 18082 # zmq
- 18083 # unrestricted rpc
The following ports are commented out but can be enabled to test things locally:
- 9090 # prometheus web ui
- 3000 # grafana web ui
- 9000 # exporter web api (/metrics)
- 5000 # nodemapper web api (/metrics)
You will want to open/allow ports 18080 and 18081 in your firewall for usage as a remote/public node (or whichever p2p and restricted ports you picked).
Also, you may want to setup a reverse proxy to Grafana if you would like to expose the visualizations for the world to see. Be sure to lock down the administrative settings or leave login disabled!
Usage
It's fairly simple, use docker-compose
to bring the containers up and down and look at logs.
# Run containers
docker-compose up -d # make up
# Check all logs
docker-compose logs -f
# Check monerod logs
docker-compose logs -f monerod # make logs
Navigate to http://localhost:3000 and log into Grafana. Find the Node Stats
dashboard to get those sweet, sweet graphs.
If you've installed this on another system you will want to use SSH tunnels (local forwarding) to reach Grafana (if not exposing via reverse proxy):
ssh <VPS OR SERVER IP> -L 3000:localhost:3000
Then navigate to http://localhost:3000. Here is what the graph looks like: