EthStats - CLI Client
The application connects to your Ethereum node through RPC and extract data that will be sent to the
EthStats - Server
for analytics purposes.
See active nodes or add your own on the following running deployments of the EthStats Network Monitor
- Mainnet - ethstats.io
- Rinkeby Testnet - rinkeby.ethstats.io
- Görli Testnet - goerli.ethstats.io
Geth, Parity, Besu, basically any Ethereum node that has RPC enabled.
Please make sure you have the following installed and running properly
- Node.js >= 8.11
- NPM >= 5.6 (Usually NPM is distributed with Node.js)
- Build Tools - To compile and install native addons from NPM you may also need to install tools like: make, gcc, g++. E.q. on ubuntu
build-essential
package has all the necessary tools. - Yarn >= 1.5 Yarn is
optional
, being an alternative to NPM. - Git - Some dependencies are downloaded through Git.
- Geth or Parity running in one of the supported configurations synced on the Ethereum main/foundation chain
- JSON-RPC http or websockets or ipc APIs enabled and accessible on the Ethereum node of choice (Geth/Parity)
Install ethstats-cli
globally
With npm:
npm install -g ethstats-cli
If you encounter permissions issues at install time please see troubleshooting section.
Or yarn:
yarn global add ethstats-cli
If after installing the package with yarn, the binaries are not found please see troubleshooting section: Binaries not found
Update ethstats-cli
to the latest available version
With npm:
npm install -g ethstats-cli@latest
Or yarn:
yarn global upgrade ethstats-cli
To run the app use the following command:
$ ethstats-cli
The app is configured by default to connect to the Ethereum node on your local host (http://localhost:8545).
To connect to a node running on a different host see --client-url
under CLI Options.
The server that is connecting to by default is the one deployed for the Ethereum mainnet
. For sending stats for a different network see the --net
flag under CLI Options.
Changing the network requires a new registration of the node. This is required because based on the network you specify at registration time the stats will be sent to a different server. Each server has its own nodes/secretKeys.
A new registration is possible if the config file is deleted.
IMPORTANT: To be able to extract all statistics from the Ethereum node we recommend running the app on the same host. The usage information about the node like cpu and memory load cannot be extracted if on a different host.
On the first run of the app the first thing it does is to register the Ethereum node in our platform. For this you will be asked about the network the node is running on, email address and node name.
It is possible to register the node also in non interactive mode without asking the necessary infos by specifying the --register
option like in the example bellow:
$ ethstats-cli --register --account-email your@email.com --node-name your_node_name
For more details on these options please see CLI Options.
If the node is already registered and you still specify the --register
option, it will be avoided.
A new registration is possible if the config file is deleted.
NOTE: Every registered node will and must have its own secret key.
After the node was successfully registered, a config file is created in the following location:
~/.config/configstore/ethstats-cli.json
It persists the node name, the secret key received on successfully registration and the values of the following CLI options:
--configurator-url
--server-url
--client-url
--client-ipc-path
--network
IMPORTANT: This is available ONLY in interactive mode.
If you lost your secret key or config file or accidentally deleted it and want to use the same node name previously registered, there is possible to recover it.
To do that start ethstats-cli
and on startup by not having a config file it will try to register by asking you:
? Is your node already registered ?
New node
> Existing node
Using arrow keys select "Existing node", then you need to enter your email account which was used to register your node.
? Please enter account email:
After typing that in, next an email will be sent to that account with a list of all nodes registered with that email account. Every node name in the list will have attached a recovery hash. Select the recovery hash of the node you want to recover and type it in at the following step.
? Please enter node recovery hash:
This should end with a successful registration of an existing node name. Keep in mind that the list of recovery hashes sent in the email expires in 30 minutes.
--help, -h Show help
--version, -V Show version
--debug, -d Output values sent to server
--verbose, -v Output more detailed information
--server-url Server URL (Must include protocol and port if any)
--net, -n Specify Ethereum network your node is running on (Default: mainnet)
Available networks: mainnet|rinkeby|goerli
If --server-url is specified, this option is ignored
--client-url Client URL (Must include protocol and port if any; Default: http://localhost:8545)
Based on the protocol specified in the url (http | ws) the app sets the corresponding Web3 provider
If --client-ipc-path is specified, this option is ignored
--client-ipc-path Client IPC path
--configurator-url Configurator URL (Must include protocol and port if any). Custom configuration service to provide application specific configs.
--register, -r Register node in non-interactive mode
--account-email Account identification, also used in case of node/secret-key recovery
It is possible to have multiple nodes under the same account-email
--node-name Name of the node. If node is already registered, a unique 5 char hash will be appended
To keep the app running at all times, you can run it as a daemon using the following command:
$ ethstats-daemon
start Start daemon
stop Stop daemon
restart Restart daemon. If it is already started, the process will be stopped first.
status Show infos about the daemon.
kill Ethstats daemon uses PM2 as a process manager. This command will kill PM2 god daemon.
If any CLI options are specified after the Daemon option, they will be forwarded to the forked process. The Daemon mode is implemented programmatically through the PM2 API. The API does not support the "startup" feature. To handle start on boot, check out the PM2 instructions.
For more control you can use directly PM2. Here is a JSON format process file that we recommend:
{
"apps": [{
"name": "ethstats-cli",
"script": "ethstats-cli",
"pid": "~/.ethstats-cli/ethstats-cli.pid",
"error": "~/.ethstats-cli/ethstats-cli.log",
"output": "~/.ethstats-cli/ethstats-cli.log",
"args": "--verbose",
"restartDelay": 1000
}]
}
To handle daemon start at boot time, please visit PM2-Startup.
The following commands assume that the Ethereum node is either running locally or in docker with --net host
.
For other options you should check out CLI options.
Make a directory where your configuration files will be persisted.
mkdir /opt/ethstats-cli
Then run the following command to run from alethio/ethstats-cli
docker image:
docker run -d \
--restart always \
--net host \
-v /opt/ethstats-cli/:/root/.config/configstore/ \
alethio/ethstats-cli --register --account-email your@email.com --node-name your_node_name
or from node:latest
docker image:
docker \
run -d \
--name ethstats-cli \
--restart always \
--net host \
-v /opt/ethstats-cli/:/root/.config/configstore/ \
node:latest \
/bin/sh -c "yarn global add ethstats-cli && ethstats-cli --register --account-email your@email.com --node-name your_node_name"
IMPORTANT: If you are running ethstats-cli
through docker on a Mac OS X and the node is running on the same host, but not through docker make sure you specify the correct client url by adding --client-url http://docker.for.mac.localhost:8545
If you started from alethio/ehtstats-cli
docker image:
docker pull alethio/ethstats-cli
docker stop ethstats-cli && docker rm ethstats-cli
then run it again.
If you started from node:latest
docker image, just stop and remove the ethstats-cli
container:
docker stop ethstats-cli && docker rm ethstats-cli
then run it again.
MIT © Alethio