This is a Stratum Proxy for Zcash using JSON-RPC.
Originally developed by the Cryptense team.
Working with Dwarfpool and Nanopool. Also tried on Miningspeed on Zclassic / BitcoinZ / ZenCash coins. Some issues with flypool, better not use with this pool.
Successfully tested with EWBF's Zcash CUDA miner. 0.3.4b and dstm's ZCash Nvidia Miner v0.5 (Linux) with several GPUs Rigs.
WARNING This work is still in development. Please report any broken features or issues.
- Additional up to 10-20% increase of earning compared to standard pools
- Zcash stratum proxy
- Pool failover system
- Only one connection to the pool
- Workers get new jobs immediately
- Submit of shares without network delay, it's like solo-mining but with benefits of professional pool
- Central Wallet configuration, miners doesn't need wallet as username
- Bypasse worker_id for detailed statistic and per rig monitoring - not supported on flypool yet / working on nanopool
- PM2 support
- SSL / TCP protocols support
Pool A < ---+ +------------- > Rig 1 / Worker 1
(Active) | |
| +------------- > Rig 2 / Worker 2
| |
Pool B < ---+--- > StratumProxy < ----+------------- > Rig 3 / Worker 3
(FailOver) |
+------------- > Rig 4 / Worker 4
- Logfile setup
- ASCII UI
- Watchdog system (alive / gpu failure)
- Hashrate computation
git clone https://github.com/BScrk/zecproxy.git
cd zec_stratum
npm install
npm start
The proxy will automatically listen on port 8000 for miners.
- all configs in file config.json to change settings.
{
"wallet": "<Your wallet>",
"password" : "<Pool password or just 'x'>",
"port": <Proxy port>,
"proxy_name" : "<Proxy default name>" (shown on the pool if enable_worker_id set to false),
"enable_worker_id": true|false (send worker name to the pool or not),
"pool" : { "host" : "<HOST>" , "port" : <PORT>, "ssl" : true|false },
"pool_failover_enabled": true|false,
"pool_failover" : [ { "host" : "<HOST>" , "port" : <PORT>, "ssl" : true|false },
{ "host" : "<HOST>" , "port" : <PORT>, "ssl" : true|false },
{ "host" : "<HOST>" , "port" : <PORT>, "ssl" : true|false }],
"restart_delay": <delay before restarting the proxy on error>,
"on_rejected_share": {
"strategy" : "<On Rejected Share strategy>" (continue / kill / restart),
"threshold" : <number of rejected shares before applying strategy>
},
"debug" : true|false
}
continue
: ignore and continuerestart
: Restart the proxy (without pm2)kill
: Kill the process (hard restart using pm2)
./miner --server <PROXY_ADDRSS> --user <RIG_NAME> --pass --port <PROXY_PORT>
exemple : ./miner --server 192.168.0.10 --user miner_1 --pass "x" --port 8000 --solver 0
./miner --server <PROXY_ADDRSS> --user <RIG_NAME> --pass --port <PROXY_PORT>
exemple : ./miner --server $192.168.0.10 --port 8000 --user miner_1 --pass "x"
The project is now dockerized for more convenience :)
Find the official image on the Docker Hub bscrk/zecproxy :
docker pull bscrk/zecproxy
git clone https://github.com/BScrk/zecproxy.git
cd zec_stratum
- edit config file
docker run -d --name=zecproxy -p 8000:8000 -v $(pwd)/config.json:/usr/src/app/config.json bscrk/zecproxy:latest
Setup and make your own image :
git clone https://github.com/BScrk/zecproxy.git
cd zec_stratum
- edit config file
docker build . -t zecproxy
docker run -p 8000:8000 -d zecproxy
- ETH: 0x1212eF39d945aB9A9568Aa5a72c5CBA99Bbe46c1
- ZEC: t1YAdYcnKR2ozADWPUvmgnDgf86gfsxQEEE
zec_stratum is build with nodeJS. The requirements for running zec_stratum are:
- linux (recommend)
- nodeJS
- npm
- We are available via dev@cryptense.com
This software is provides AS-IS without any warranties of any kind. Please use at your own risk.