Performance Monitoring & Testing
Nym Mixnet has been running on mainnet for quite some time. There is still work to be done in order for the network to meet its full potential - mass adoption of privacy through fully distributed Mixnet.
As developers we need to be constantly improving the software. Operators have as much important role, keep their nodes up to date, monitor their performance and share their feedback with the rest of the community and core developers.
Therefore monitoring and testing are essential pieces of our common work. We call out all Nym operators to join the efforts!
Monitoring
There are multiple ways to monitor performance of nodes and the machines on which they run. For the purpose of maximal privacy and decentralisation of the data - preventing Nym Mixnet from any global adversary takeover - we created these pages as a source of mutual empowerment, a place where operators can share and learn new skills to setup metrics monitors on their own infrastructure.
Guides to Setup Own Metrics
A list of different scripts, templates and guides for easier navigation:
nym-gateway-probe
- a useful tool used under the hood of harbourmaster.nymtech.net (opens in a new tab)- Prometheus and Grafana self-hosted setup
- Nym-node CPU cron service (opens in a new tab) - an easy bash script by Nym core developer @tommy1987 (opens in a new tab), designed to monitor a CPU usage of your node, running locally
- Nym's script
prom_targets.py
(opens in a new tab) - a useful python program to request data from API and can be run on its own or plugged to more sophisticated flows
Collecting Testing Metrics
For the purpose of the performance testing Nym core developers plan to run instances of Prometheus and Grafana connected to Node explorer in the house. The network overall key insights we seek from these tests are primarily internal. We're focused on pinpointing bottlenecks, capacity loads, and monitoring cpu usage on the nodes' machines.
Testing
For the moment we paused Fast and Furious perf
environment. All load and speed testing is carried on directly Nym Mainnet as this is the only way to collect real performance data.
We do testing in order to understand and increase the overall quality of the Nym Network. The main takeaways of such event are:
- Understanding of the network behavior under full load
- How many mixnet client users can all active set entry gateways handle simultaneously?
- How much sustained IP traffic can a subset of mainnet nodes sustain?
- Needed improvements of Nym Node binaries to improve the throughput on mainnet
- Measurement of required machine specs
- Raw data record
- Increase quality of Nym Nodes
- Show each operator a way to monitor their nodes in a distributed fashion
- Adjust rewarding based on the machine specs and server pricing
Visit Nym Harbour Master (opens in a new tab) monitoring page to monitor network components (nodes) performance.