/open-ethereum-pool

以太坊开源开采矿池-开源 / *版权所有©️OPENETHMINE以太坊矿业* /

Primary LanguageGoGNU General Public License v3.0GPL-3.0

open-ethereum-pool

进一步开发中,为以太坊矿工提供一个易于使用的矿池。 该软件功能正常,但预计不久将优化版本库。欢迎测试和错误提交!

支持HTTP和Stratum挖掘 具有运气比例和全部奖励的详细区块统计数据 故障转移geth实例:geth内置高可用性 建立在Linux上

go >= 1.9 geth or parity redis-server >= 2.8.0 nodejs >= 4 LTS nginx 我强烈建议使用Ubuntu 16.04 LTS。

首先安装 go-ethereum。

克隆和编译:

git clone https://github.com/OpenEthMine/open-ethereum-pool cd open-ethereum-pool make 安装redis-server。

运行池 ./build/bin/open-ethereum-pool config.json

npm install -g ember-cli@2.9.1 npm install -g bower npm install bower install ./build.sh

upstream api { server 127.0.0.1:8080; }

location /api { proxy_pass http://api; }

{ // Set to the number of CPU cores of your server "threads": 2, // Prefix for keys in redis store "coin": "eth", // Give unique name to each instance "name": "main",

"proxy": { "enabled": true,

// Bind HTTP mining endpoint to this IP:PORT
"listen": "0.0.0.0:8888",

// Allow only this header and body size of HTTP request from miners
"limitHeadersSize": 1024,
"limitBodySize": 256,

/* Set to true if you are behind CloudFlare (not recommended) or behind http-reverse
  proxy to enable IP detection from X-Forwarded-For header.
  Advanced users only. It's tricky to make it right and secure.
*/
"behindReverseProxy": false,

// Stratum mining endpoint
"stratum": {
  "enabled": true,
  // Bind stratum mining socket to this IP:PORT
  "listen": "0.0.0.0:8008",
  "timeout": "120s",
  "maxConn": 8192
},

// Try to get new job from geth in this interval
"blockRefreshInterval": "120ms",
"stateUpdateInterval": "3s",
// Require this share difficulty from miners
"difficulty": 2000000000,

/* Reply error to miner instead of job if redis is unavailable.
  Should save electricity to miners if pool is sick and they didn't set up failovers.
*/
"healthCheck": true,
// Mark pool sick after this number of redis failures.
"maxFails": 100,
// TTL for workers stats, usually should be equal to large hashrate window from API section
"hashrateExpiration": "3h",

"policy": {
  "workers": 8,
  "resetInterval": "60m",
  "refreshInterval": "1m",

  "banning": {
    "enabled": false,
    /* Name of ipset for banning.
    Check http://ipset.netfilter.org/ documentation.
    */
    "ipset": "blacklist",
    // Remove ban after this amount of time
    "timeout": 1800,
    // Percent of invalid shares from all shares to ban miner
    "invalidPercent": 30,
    // Check after after miner submitted this number of shares
    "checkThreshold": 30,
    // Bad miner after this number of malformed requests
    "malformedLimit": 5
  },
  // Connection rate limit
  "limits": {
    "enabled": false,
    // Number of initial connections
    "limit": 30,
    "grace": "5m",
    // Increase allowed number of connections on each valid share
    "limitJump": 10
  }
}

},

// Provides JSON data for frontend which is static website "api": { "enabled": true, "listen": "0.0.0.0:8080", // Collect miners stats (hashrate, ...) in this interval "statsCollectInterval": "5s", // Purge stale stats interval "purgeInterval": "10m", // Fast hashrate estimation window for each miner from it's shares "hashrateWindow": "30m", // Long and precise hashrate from shares, 3h is cool, keep it "hashrateLargeWindow": "3h", // Collect stats for shares/diff ratio for this number of blocks "luckWindow": [64, 128, 256], // Max number of payments to display in frontend "payments": 50, // Max numbers of blocks to display in frontend "blocks": 50,

/* If you are running API node on a different server where this module
  is reading data from redis writeable slave, you must run an api instance with this option enabled in order to purge hashrate stats from main redis node.
  Only redis writeable slave will work properly if you are distributing using redis slaves.
  Very advanced. Usually all modules should share same redis instance.
*/
"purgeOnly": false

},

// Check health of each geth node in this interval "upstreamCheckInterval": "5s",

/* List of geth nodes to poll for new jobs. Pool will try to get work from first alive one and check in background for failed to back up. Current block template of the pool is always cached in RAM indeed. */ "upstream": [ { "name": "main", "url": "http://127.0.0.1:8545", "timeout": "10s" }, { "name": "backup", "url": "http://127.0.0.2:8545", "timeout": "10s" } ],

// This is standard redis connection options "redis": { // Where your redis instance is listening for commands "endpoint": "127.0.0.1:6379", "poolSize": 10, "database": 0, "password": "" },

// This module periodically remits ether to miners "unlocker": { "enabled": false, // Pool fee percentage "poolFee": 1.0, // Pool fees beneficiary address (leave it blank to disable fee withdrawals) "poolFeeAddress": "", // Donate 10% from pool fees to developers "donate": true, // Unlock only if this number of blocks mined back "depth": 120, // Simply don't touch this option "immatureDepth": 20, // Keep mined transaction fees as pool fees "keepTxFees": false, // Run unlocker in this interval "interval": "10m", // Geth instance node rpc endpoint for unlocking blocks "daemon": "http://127.0.0.1:8545", // Rise error if can't reach geth in this amount of time "timeout": "10s" },

// Pay out miners using this module "payouts": { "enabled": false, // Require minimum number of peers on node "requirePeers": 25, // Run payouts in this interval "interval": "12h", // Geth instance node rpc endpoint for payouts processing "daemon": "http://127.0.0.1:8545", // Rise error if can't reach geth in this amount of time "timeout": "10s", // Address with pool balance "address": "0x0", // Let geth to determine gas and gasPrice "autoGas": true, // Gas amount and price for payout tx (advanced users only) "gas": "21000", "gasPrice": "50000000000", // Send payment only if miner's balance is >= 0.5 Ether "threshold": 500000000, // Perform BGSAVE on Redis after successful payouts session "bgsave": false } }