diff --git a/CHANGELOG.md b/CHANGELOG.md index a4c9ee8..596cdbf 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,10 @@ # Changelog All notable changes to this project will be documented in this file. +## [2.4.17] - 2019-02-17 +- Fixed server reconnection bug +- Updated Readme file + ## [2.4.16] - 2019-02-14 - Fixed web3 WebSocketProvider connection issue diff --git a/README.md b/README.md index 2a13826..fdedacd 100644 --- a/README.md +++ b/README.md @@ -3,13 +3,16 @@ > EthStats - Network Monitor - CLI Client > > -> The client application connects to your Ethereum node through RPC and extract data that will be sent to the `EthStats - Network Monitor - Server` for analytics purposes. +> The application connects to your Ethereum node through RPC and extract data that will be sent to the `EthStats - Network Monitor - Server` for analytics purposes. # Live deployments See active nodes or add your own on the following running deployments of the EthStats Network Monitor -[Mainnet](https://net.ethstats.io/) -[Görli Testnet](https://net.goerli.ethstats.io/) + - Mainnet - [net.ethstats.io](https://net.ethstats.io/) + - Görli Testnet - [net.goerli.ethstats.io](https://net.goerli.ethstats.io/) + +# Supported Ethereum nodes +Geth, Parity, Pantheon, basically any Ethereum node that has RPC enabled. # Contents - [Getting Started](#getting-started) @@ -17,10 +20,11 @@ See active nodes or add your own on the following running deployments of the Eth - [Install](#install) - [Update](#update) - [Running](#running) - - [CLI](#cli) - - [Daemon](#daemon) - - [With PM2](#with-pm2) - - [In Docker](#in-docker) + - [Register node](#register-node) + - [Config file](#config-file) + - [CLI Options](#cli-options) + - [Daemon](#daemon) + - [Docker](#docker) - [Troubleshooting](https://github.com/Alethio/ethstats-cli/blob/master/TROUBLESHOOTING.md) - [Changelog](https://github.com/Alethio/ethstats-cli/blob/master/CHANGELOG.md) - [License](https://github.com/Alethio/ethstats-cli/blob/master/LICENSE) @@ -37,18 +41,6 @@ Please make sure you have the following installed and running properly - [Geth](https://geth.ethereum.org/install/) or [Parity](https://wiki.parity.io/Setup) 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) -## Supported node configurations -Geth -- fast (`--syncmode "fast"`) -- full (`--syncmode "full"`) -- light (`--syncmode "light"`) -> tested 1.8.1, - -Parity -- fast (`--pruning fast`) -- archive (`--pruning archive`) -- with no ancient blocks (`--no-ancient-blocks`) -> tested 1.7.11, 1.8.6, 1.8.7, 1.9.0, 1.9.1, 1.9.2, 1.10.0, ## Install @@ -81,25 +73,42 @@ yarn global upgrade ethstats-cli ``` ## Running -On the first run the app will start in interactive mode and you will be asked a series of questions to setup your node. -Either follow the on screen instructions or see [CLI options](#cli-options) for a non-interactive mode. - -The app is configured by default to connect to an Ethereum node on the local machine (http://localhost:8545). -To connect to a node running on another host see `--client-url` under [CLI options](#cli-options). - -After the setup is done, your node will be visible on [net.ethstats.io](https://net.ethstats.io/) +To run the app use the following command: +```sh +$ 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](#cli-options). 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. -### CLI +## Register node -To run the app in interactive mode you can use the following command: +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: ```sh -$ ethstats-cli +$ ethstats-cli --register --account-email your@email.com --node-name your_node_name ``` -#### CLI options: +For more details on these options please see [CLI Options](#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](#config-file) is deleted. + +## Config file +After the node was successfully registered, a config file is created in the following location: +```sh +~/.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` + +# CLI Options: ```sh --help, -h Show help @@ -109,6 +118,7 @@ $ ethstats-cli --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|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) @@ -124,20 +134,7 @@ $ ethstats-cli --node-name Name of the node. If node is already registered, a unique 5 char hash will be appended ``` -Running the app in non-interactive mode for the first time, you'll need to specify the `--register` option together with `--account-email` and `--node-name`. -Like this no questions will be asked. All other CLI options have default values. - -Example: -```sh -$ ethstats-cli --register --account-email your@email.com --node-name your_node_name -``` - -If the app is already registered and you still specify the registration CLI option like in the example command above, they will be avoided. - -If the node was successfully registered, a configuration file is created to persist the values of the CLI options previously specified. -Every CLI option that passes a value, once specified, it's value is stored in this configuration file, so the next time the app is started there's no need to specify does CLI options again. - -### Daemon +# Daemon To keep the app running at all times, you can run it as a daemon using the following command: @@ -145,7 +142,7 @@ To keep the app running at all times, you can run it as a daemon using the follo $ ethstats-daemon ``` -#### Daemon options: +## Daemon options: ```sh start Start daemon @@ -158,7 +155,7 @@ $ ethstats-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](#with-pm2) instructions. -### With PM2 +## PM2 For more control you can use directly [PM2](http://pm2.keymetrics.io). Here is a JSON format process file that we recommend: @@ -178,9 +175,9 @@ For more control you can use directly [PM2](http://pm2.keymetrics.io). Here is a To handle daemon start at boot time, please visit [PM2-Startup](http://pm2.keymetrics.io/docs/usage/startup/). -### In Docker +# Docker -#### Installing and running +## Installing and running 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](#cli-options). @@ -211,13 +208,7 @@ node:latest \ /bin/sh -c "yarn global add ethstats-cli && ethstats-cli --register --account-email your@email.com --node-name your_node_name" ``` -The docker commands are run with `-d`, that means `ethstats-cli` is started in non-interactive mode. - -To run in interactive mode change `-d` to `-it` and remove the `--register` option along with `--account-email` and `--node-name`. - -If you already had a configuration file, the settings from that file will be used and the command line ignored. Delete the files in `/opt/ethstats-cli` to add a node with different settings. - -#### Updating +## Updating If you started from `alethio/ehtstats-cli` docker image: @@ -228,7 +219,7 @@ 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`: +If you started from `node:latest` docker image, just stop and remove the `ethstats-cli` container: ```sh docker stop ethstats-cli && docker rm ethstats-cli diff --git a/lib/Cli.js b/lib/Cli.js index 2cb54b9..5d323ae 100644 --- a/lib/Cli.js +++ b/lib/Cli.js @@ -27,6 +27,7 @@ export default class CLI { --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|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) diff --git a/lib/Server.js b/lib/Server.js index 34cbbc0..58d25da 100644 --- a/lib/Server.js +++ b/lib/Server.js @@ -105,9 +105,9 @@ export default class Server { this.socket = new PrimusSocket(`${this.url}`, { reconnect: { - min: 1 + (Math.floor(Math.random() * 10)), // Random between 1 and 10 seconds + min: (1 + (Math.floor(Math.random() * 10))) * 1000, // Random between 1 and 10 seconds factor: 1, - retries: 300 // Retries for 25 hours + retries: 8640 } }); @@ -225,7 +225,10 @@ export default class Server { } destroy() { - this.socket.destroy(); + if (this.socket) { + this.socket.destroy(); + } + clearInterval(this.pingIntervalId); clearInterval(this.checkLastBlockInterval); } diff --git a/package-lock.json b/package-lock.json index 73077f3..1cd7970 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,6 +1,6 @@ { "name": "ethstats-cli", - "version": "2.4.16", + "version": "2.4.17", "lockfileVersion": 1, "requires": true, "dependencies": { @@ -44,14 +44,14 @@ } }, "@babel/generator": { - "version": "7.3.2", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.3.2.tgz", - "integrity": "sha512-f3QCuPppXxtZOEm5GWPra/uYUjmNQlu9pbAD8D/9jze4pTY83rTtB1igTBSwvkeNlC5gR24zFFkz+2WHLFQhqQ==", + "version": "7.3.3", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.3.3.tgz", + "integrity": "sha512-aEADYwRRZjJyMnKN7llGIlircxTCofm3dtV5pmY6ob18MSIuipHpA2yZWkPlycwu5HJcx/pADS3zssd8eY7/6A==", "dev": true, "requires": { - "@babel/types": "^7.3.2", + "@babel/types": "^7.3.3", "jsesc": "^2.5.1", - "lodash": "^4.17.10", + "lodash": "^4.17.11", "source-map": "^0.5.0", "trim-right": "^1.0.1" }, @@ -279,9 +279,9 @@ } }, "@babel/parser": { - "version": "7.3.2", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.3.2.tgz", - "integrity": "sha512-QzNUC2RO1gadg+fs21fi0Uu0OuGNzRKEmgCxoLNzbCdoprLwjfmZwzUrpUNfJPaVRwBpDY47A17yYEGWyRelnQ==", + "version": "7.3.3", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.3.3.tgz", + "integrity": "sha512-xsH1CJoln2r74hR+y7cg2B5JCPaTh+Hd+EbBRk9nWGSNspuo6krjhX0Om6RnRQuIvFq8wVXCLKH3kwKDYhanSg==", "dev": true }, "@babel/plugin-proposal-async-generator-functions": { @@ -412,9 +412,9 @@ } }, "@babel/plugin-transform-classes": { - "version": "7.2.2", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.2.2.tgz", - "integrity": "sha512-gEZvgTy1VtcDOaQty1l10T3jQmJKlNVxLDCs+3rCVPr6nMkODLELxViq5X9l+rfxbie3XrfrMCYYY6eX3aOcOQ==", + "version": "7.3.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.3.3.tgz", + "integrity": "sha512-n0CLbsg7KOXsMF4tSTLCApNMoXk0wOPb0DYfsOO1e7SfIb9gOyfbpKI2MZ+AXfqvlfzq2qsflJ1nEns48Caf2w==", "dev": true, "requires": { "@babel/helper-annotate-as-pure": "^7.0.0", @@ -573,9 +573,9 @@ } }, "@babel/plugin-transform-parameters": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.2.0.tgz", - "integrity": "sha512-kB9+hhUidIgUoBQ0MsxMewhzr8i60nMa2KgeJKQWYrqQpqcBYtnpR+JgkadZVZoaEZ/eKu9mclFaVwhRpLNSzA==", + "version": "7.3.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.3.3.tgz", + "integrity": "sha512-IrIP25VvXWu/VlBWTpsjGptpomtIkYrN/3aDp4UKm7xK6UxZY88kcJ1UwETbzHAlwN21MnNfwlar0u8y3KpiXw==", "dev": true, "requires": { "@babel/helper-call-delegate": "^7.1.0", @@ -754,13 +754,13 @@ } }, "@babel/types": { - "version": "7.3.2", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.3.2.tgz", - "integrity": "sha512-3Y6H8xlUlpbGR+XvawiH0UXehqydTmNmEpozWcXymqwcrwYAl5KMvKtQ+TF6f6E08V6Jur7v/ykdDSF+WDEIXQ==", + "version": "7.3.3", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.3.3.tgz", + "integrity": "sha512-2tACZ80Wg09UnPg5uGAOUvvInaqLk3l/IAhQzlxLQOIXacr6bMsra5SH6AWw/hIDRCSbCdHP2KzSOD+cT7TzMQ==", "dev": true, "requires": { "esutils": "^2.0.2", - "lodash": "^4.17.10", + "lodash": "^4.17.11", "to-fast-properties": "^2.0.0" } }, @@ -1821,9 +1821,9 @@ } }, "caniuse-lite": { - "version": "1.0.30000936", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000936.tgz", - "integrity": "sha512-orX4IdpbFhdNO7bTBhSbahp1EBpqzBc+qrvTRVUFfZgA4zta7TdM6PN5ZxkEUgDnz36m+PfWGcdX7AVfFWItJw==", + "version": "1.0.30000938", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000938.tgz", + "integrity": "sha512-ekW8NQ3/FvokviDxhdKLZZAx7PptXNwxKgXtnR5y+PR3hckwuP3yJ1Ir+4/c97dsHNqtAyfKUGdw8P4EYzBNgw==", "dev": true }, "capture-stack-trace": { @@ -2354,9 +2354,9 @@ } }, "core-js": { - "version": "2.6.4", - "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.6.4.tgz", - "integrity": "sha512-05qQ5hXShcqGkPZpXEFLIpxayZscVD2kuMBZewxiIPPEagukO4mqgPA9CWhUvFBJfy3ODdK2p9xyHh7FTU9/7A==" + "version": "2.6.5", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.6.5.tgz", + "integrity": "sha512-klh/kDpwX8hryYL14M9w/xei6vrv6sE8gTHDG7/T/+SEovB/G4ejwcfE/CBzO6Edsu+OETZMZ3wcX/EjUkrl5A==" }, "core-util-is": { "version": "1.0.2", @@ -3230,9 +3230,9 @@ } }, "es6-promise": { - "version": "4.2.5", - "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.2.5.tgz", - "integrity": "sha512-n6wvpdE43VFtJq+lUDYDBFUwV8TZbuGXLV4D6wKafg13ldznKsyEvatubnmUe31zcvelSzOHF+XbaT+Bl9ObDg==" + "version": "4.2.6", + "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.2.6.tgz", + "integrity": "sha512-aRVgGdnmW2OiySVPUC9e6m+plolMAJKjZnQlCwNSuK5yQ0JN61DZSO1X1Ufd1foqWRAlig0rhduTCHe7sVtK5Q==" }, "es6-promisify": { "version": "5.0.0", @@ -3428,12 +3428,12 @@ "dev": true }, "espree": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.0.tgz", - "integrity": "sha512-1MpUfwsdS9MMoN7ZXqAr9e9UKdVHDcvrJpyx7mm1WuQlx/ygErEQBzgi5Nh5qBHIoYweprhtMkTCb9GhcAIcsA==", + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.1.tgz", + "integrity": "sha512-qWAZcWh4XE/RwzLJejfcofscgMc9CamR6Tn1+XRXNzrvUSSbiAjGOI/fggztjIi7y9VLPqnICMIPiGyr8JaZ0A==", "dev": true, "requires": { - "acorn": "^6.0.2", + "acorn": "^6.0.7", "acorn-jsx": "^5.0.0", "eslint-visitor-keys": "^1.0.0" } @@ -6909,16 +6909,16 @@ "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==" }, "mime-db": { - "version": "1.37.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.37.0.tgz", - "integrity": "sha512-R3C4db6bgQhlIhPU48fUtdVmKnflq+hRdad7IyKhtFj06VPNVdk2RhiYL3UjQIlso8L+YxAtFkobT0VK+S/ybg==" + "version": "1.38.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.38.0.tgz", + "integrity": "sha512-bqVioMFFzc2awcdJZIzR3HjZFX20QhilVS7hytkKrv7xFAn8bM1gzc/FOX2awLISvWe0PV8ptFKcon+wZ5qYkg==" }, "mime-types": { - "version": "2.1.21", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.21.tgz", - "integrity": "sha512-3iL6DbwpyLzjR3xHSFNFeb9Nz/M8WDkX33t1GFQnFOllWk8pOrh/LSrB5OXlnlW5P9LH73X6loW/eogc+F5lJg==", + "version": "2.1.22", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.22.tgz", + "integrity": "sha512-aGl6TZGnhm/li6F7yx82bJiBZwgiEa4Hf6CNr8YO+r5UHr53tSTYZb102zyU50DOWWKeOv0uQLRL0/9EiKWCog==", "requires": { - "mime-db": "~1.37.0" + "mime-db": "~1.38.0" } }, "mimic-fn": { diff --git a/package.json b/package.json index bacb77f..a90b6f1 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "ethstats-cli", - "version": "2.4.16", + "version": "2.4.17", "description": "EthStats - Network Monitor - CLI Client (net.ethstats.io)", "homepage": "https://github.com/alethio/ethstats-cli", "author": {