mirror of
https://github.com/8lecramm/derohe-proxy.git
synced 2025-01-10 13:57:56 +00:00
worker support; minor fixes
This commit is contained in:
parent
9f399ed393
commit
2ad8f96749
@ -1,6 +1,7 @@
|
|||||||
# derohe-proxy
|
# derohe-proxy
|
||||||
|
|
||||||
Proxy to combine miners and to reduce network load.
|
Proxy to combine miners and to reduce network load.
|
||||||
|
Long To-Do list, but this is a working release.
|
||||||
|
|
||||||
**Features**
|
**Features**
|
||||||
- random nonces
|
- random nonces
|
||||||
@ -8,16 +9,16 @@ Proxy to combine miners and to reduce network load.
|
|||||||
- notification of incoming and lost connections / submitted results / stats
|
- notification of incoming and lost connections / submitted results / stats
|
||||||
- user-defined logging interval
|
- user-defined logging interval
|
||||||
- pool mining support (not stratum)
|
- pool mining support (not stratum)
|
||||||
- set user-defined wallet address
|
- worker support (wallet_address.worker_name)
|
||||||
|
|
||||||
**Usage**
|
**Usage**
|
||||||
|
|
||||||
```derohe-proxy [--listen-address=<127.0.0.1:11111>] [--log-interval=<60>] [--minimal] [--nonce] [--pool] --daemon-address=<1.2.3.4:10100> --wallet-address=<deroi...>```
|
```derohe-proxy [--listen-address=<127.0.0.1:11111>] [--log-interval=<60>] [--minimal] [--nonce] [--pool] --daemon-address=<1.2.3.4:10100>```
|
||||||
|
|
||||||
```--listen-address (optional): bind to address:port for incoming miner connections. By default, proxy listens on 0.0.0.0:10200
|
```--listen-address (optional): bind to address:port for incoming miner connections. By default, proxy listens on 0.0.0.0:10200
|
||||||
--daemon-address: address:port of daemon
|
--daemon-address: address:port of daemon
|
||||||
--wallet address (optional): use this wallet address for connection to node
|
|
||||||
--log-interval (optional): logging every X seconds, where X >= 60. Default is 60 seconds
|
--log-interval (optional): logging every X seconds, where X >= 60. Default is 60 seconds
|
||||||
--minimal (optional): forward only 2 jobs per block (1 for first 9 miniblocks, 1 for final miniblock)
|
--minimal (optional): forward only 2 jobs per block (1 for first 9 miniblocks, 1 for final miniblock)
|
||||||
--nonce (optional): enable random nonces, disabled by default```
|
--nonce (optional): enable random nonces, disabled by default```
|
||||||
--pool (optional): enable pool mining, disable keyhash replacement
|
--pool (optional): enable pool mining, disable keyhash replacement
|
||||||
|
--wallet-address=<dero1....> use this wallet address for all connections
|
@ -4,12 +4,12 @@ var Command_line string = `derohe-proxy
|
|||||||
Proxy to combine all miners and to reduce network load
|
Proxy to combine all miners and to reduce network load
|
||||||
|
|
||||||
Usage:
|
Usage:
|
||||||
derohe-proxy [--listen-address=<127.0.0.1:10100>] [--log-interval=<60>] [--minimal] [--nonce] [--pool] --daemon-address=<1.2.3.4:10100> --wallet-address=<deroi...>
|
derohe-proxy --daemon-address=<1.2.3.4:10100> [--listen-address=<127.0.0.1:10100>] [--log-interval=<60>] [--minimal] [--nonce] [--pool] [--wallet-address=<dero1...>]
|
||||||
|
|
||||||
Options:
|
Options:
|
||||||
--listen-address=<127.0.0.1:10100> bind to specific address:port, default is 0.0.0.0:10200
|
--listen-address=<127.0.0.1:10100> bind to specific address:port, default is 0.0.0.0:10200
|
||||||
--daemon-address=<1.2.3.4:10100> connect to this daemon
|
--daemon-address=<1.2.3.4:10100> connect to this daemon
|
||||||
--wallet-address=<deroi....> use this wallet address for all connections
|
--wallet-address=<dero1....> use this wallet address for all connections
|
||||||
--log-interval=<60> set logging interval in seconds (range 60 - 3600), default is 60 seconds
|
--log-interval=<60> set logging interval in seconds (range 60 - 3600), default is 60 seconds
|
||||||
--minimal forward only 2 jobs per block (1 for miniblocks and 1 for final miniblock), by default all jobs are forwarded
|
--minimal forward only 2 jobs per block (1 for miniblocks and 1 for final miniblock), by default all jobs are forwarded
|
||||||
--nonce enable nonce editing, default is off
|
--nonce enable nonce editing, default is off
|
||||||
|
@ -9,6 +9,7 @@ import (
|
|||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/deroproject/derohe/globals"
|
||||||
"github.com/docopt/docopt-go"
|
"github.com/docopt/docopt-go"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -42,7 +43,11 @@ func main() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if config.Arguments["--wallet-address"] != nil {
|
if config.Arguments["--wallet-address"] != nil {
|
||||||
config.WalletAddr = config.Arguments["--wallet-address"].(string)
|
addr, err := globals.ParseValidateAddress(config.Arguments["--wallet-address"].(string))
|
||||||
|
if err != nil {
|
||||||
|
fmt.Printf("%v Wallet address is invalid!\n", time.Now().Format(time.Stamp))
|
||||||
|
}
|
||||||
|
config.WalletAddr = addr.String()
|
||||||
fmt.Printf("%v Using wallet %s for all connections\n", time.Now().Format(time.Stamp), config.WalletAddr)
|
fmt.Printf("%v Using wallet %s for all connections\n", time.Now().Format(time.Stamp), config.WalletAddr)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6,6 +6,7 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"math/rand"
|
"math/rand"
|
||||||
"net/url"
|
"net/url"
|
||||||
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"derohe-proxy/config"
|
"derohe-proxy/config"
|
||||||
@ -38,7 +39,12 @@ type (
|
|||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
var connection *websocket.Conn
|
type clientConn struct {
|
||||||
|
conn *websocket.Conn
|
||||||
|
sync.Mutex
|
||||||
|
}
|
||||||
|
|
||||||
|
var connection clientConn
|
||||||
var Blocks uint64
|
var Blocks uint64
|
||||||
var Minis uint64
|
var Minis uint64
|
||||||
var Rejected uint64
|
var Rejected uint64
|
||||||
@ -68,7 +74,7 @@ func Start_client(w string) {
|
|||||||
} else {
|
} else {
|
||||||
fmt.Printf("%v Connected to node %v using wallet %v\n", time.Now().Format(time.Stamp), config.Daemon_address, w)
|
fmt.Printf("%v Connected to node %v using wallet %v\n", time.Now().Format(time.Stamp), config.Daemon_address, w)
|
||||||
}
|
}
|
||||||
connection, _, err = websocket.DefaultDialer.Dial(u.String(), nil)
|
connection.conn, _, err = websocket.DefaultDialer.Dial(u.String(), nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
time.Sleep(5 * time.Second)
|
time.Sleep(5 * time.Second)
|
||||||
fmt.Println(err)
|
fmt.Println(err)
|
||||||
@ -78,7 +84,7 @@ func Start_client(w string) {
|
|||||||
var params GetBlockTemplate_Result
|
var params GetBlockTemplate_Result
|
||||||
|
|
||||||
for {
|
for {
|
||||||
msg_type, recv_data, err := connection.ReadMessage()
|
msg_type, recv_data, err := connection.conn.ReadMessage()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
@ -128,7 +134,7 @@ func SendUpdateToDaemon() {
|
|||||||
time.Sleep(60 * time.Second)
|
time.Sleep(60 * time.Second)
|
||||||
}
|
}
|
||||||
|
|
||||||
connection.WriteJSON(MinerInfo_Params{Wallet_Address: Address, Miner_Tag: "", Miner_Hashrate: Hashrate})
|
connection.conn.WriteJSON(MinerInfo_Params{Wallet_Address: Address, Miner_Tag: "", Miner_Hashrate: Hashrate})
|
||||||
|
|
||||||
count++
|
count++
|
||||||
}
|
}
|
||||||
@ -137,5 +143,9 @@ func SendUpdateToDaemon() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func SendToDaemon(buffer []byte) {
|
func SendToDaemon(buffer []byte) {
|
||||||
connection.WriteMessage(websocket.TextMessage, buffer)
|
connection.Lock()
|
||||||
|
defer connection.Unlock()
|
||||||
|
|
||||||
|
connection.conn.WriteMessage(websocket.TextMessage, buffer)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -38,6 +38,7 @@ type user_session struct {
|
|||||||
miniblocks uint64
|
miniblocks uint64
|
||||||
lasterr string
|
lasterr string
|
||||||
address rpc.Address
|
address rpc.Address
|
||||||
|
worker string
|
||||||
orphans uint64
|
orphans uint64
|
||||||
hashrate float64
|
hashrate float64
|
||||||
valid_address bool
|
valid_address bool
|
||||||
@ -80,7 +81,7 @@ func Start_server() {
|
|||||||
TLSConfig: tlsConfig,
|
TLSConfig: tlsConfig,
|
||||||
Handler: mux,
|
Handler: mux,
|
||||||
MaxLoad: 10 * 1024,
|
MaxLoad: 10 * 1024,
|
||||||
MaxWriteBufferSize: 32 * 1024,
|
MaxWriteBufferSize: 5 * 1024 * 1024,
|
||||||
ReleaseWebsocketPayload: true,
|
ReleaseWebsocketPayload: true,
|
||||||
KeepaliveTime: 240 * time.Hour, // we expects all miners to find a block every 10 days,
|
KeepaliveTime: 240 * time.Hour, // we expects all miners to find a block every 10 days,
|
||||||
NPoller: runtime.NumCPU(),
|
NPoller: runtime.NumCPU(),
|
||||||
@ -107,7 +108,9 @@ func Start_server() {
|
|||||||
func CountMiners() int {
|
func CountMiners() int {
|
||||||
client_list_mutex.Lock()
|
client_list_mutex.Lock()
|
||||||
defer client_list_mutex.Unlock()
|
defer client_list_mutex.Unlock()
|
||||||
|
|
||||||
miners_count = len(client_list)
|
miners_count = len(client_list)
|
||||||
|
|
||||||
return miners_count
|
return miners_count
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -151,6 +154,15 @@ func onWebsocket(w http.ResponseWriter, r *http.Request) {
|
|||||||
}
|
}
|
||||||
address := strings.TrimPrefix(r.URL.Path, "/ws/")
|
address := strings.TrimPrefix(r.URL.Path, "/ws/")
|
||||||
|
|
||||||
|
// check for worker suffix
|
||||||
|
var parseWorker []string
|
||||||
|
var worker string
|
||||||
|
if strings.Contains(address, ".") {
|
||||||
|
parseWorker = strings.Split(address, ".")
|
||||||
|
worker = parseWorker[1]
|
||||||
|
address = parseWorker[0]
|
||||||
|
}
|
||||||
|
|
||||||
addr, err := globals.ParseValidateAddress(address)
|
addr, err := globals.ParseValidateAddress(address)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Fprintf(w, "err: %s\n", err)
|
fmt.Fprintf(w, "err: %s\n", err)
|
||||||
@ -167,7 +179,7 @@ func onWebsocket(w http.ResponseWriter, r *http.Request) {
|
|||||||
addr_raw := addr.PublicKey.EncodeCompressed()
|
addr_raw := addr.PublicKey.EncodeCompressed()
|
||||||
wsConn := conn.(*websocket.Conn)
|
wsConn := conn.(*websocket.Conn)
|
||||||
|
|
||||||
session := user_session{address: *addr, address_sum: graviton.Sum(addr_raw)}
|
session := user_session{address: *addr, address_sum: graviton.Sum(addr_raw), worker: worker}
|
||||||
wsConn.SetSession(&session)
|
wsConn.SetSession(&session)
|
||||||
|
|
||||||
client_list_mutex.Lock()
|
client_list_mutex.Lock()
|
||||||
@ -183,9 +195,9 @@ func onWebsocket(w http.ResponseWriter, r *http.Request) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if !config.Pool_mode {
|
if !config.Pool_mode {
|
||||||
fmt.Printf("%v Incoming connection: %v, Wallet: %v\n", time.Now().Format(time.Stamp), wsConn.RemoteAddr().String(), address)
|
fmt.Printf("%v Incoming connection: %v (%v), Wallet: %v\n", time.Now().Format(time.Stamp), wsConn.RemoteAddr().String(), worker, address)
|
||||||
} else {
|
} else {
|
||||||
fmt.Printf("%v Incoming connection: %v\n", time.Now().Format(time.Stamp), wsConn.RemoteAddr().String())
|
fmt.Printf("%v Incoming connection: %v (%v)\n", time.Now().Format(time.Stamp), wsConn.RemoteAddr().String(), worker)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -224,7 +236,7 @@ func newUpgrader() *websocket.Upgrader {
|
|||||||
*/
|
*/
|
||||||
SendToDaemon(data)
|
SendToDaemon(data)
|
||||||
if !config.Pool_mode {
|
if !config.Pool_mode {
|
||||||
fmt.Printf("%v Submitting result from miner: %v, Wallet: %v\n", time.Now().Format(time.Stamp), c.RemoteAddr().String(), client_list[c].address.String())
|
fmt.Printf("%v Submitting result from miner: %v (%v), Wallet: %v\n", time.Now().Format(time.Stamp), c.RemoteAddr().String(), client_list[c].worker, client_list[c].address.String())
|
||||||
} else {
|
} else {
|
||||||
shares++
|
shares++
|
||||||
fmt.Printf("%v Shares submitted: %d\n", time.Now().Format(time.Stamp), shares)
|
fmt.Printf("%v Shares submitted: %d\n", time.Now().Format(time.Stamp), shares)
|
||||||
@ -236,7 +248,7 @@ func newUpgrader() *websocket.Upgrader {
|
|||||||
client_list_mutex.Lock()
|
client_list_mutex.Lock()
|
||||||
defer client_list_mutex.Unlock()
|
defer client_list_mutex.Unlock()
|
||||||
Wallet_count[client_list[c].address.String()]--
|
Wallet_count[client_list[c].address.String()]--
|
||||||
fmt.Printf("%v Lost connection: %v\n", time.Now().Format(time.Stamp), c.RemoteAddr().String())
|
fmt.Printf("%v Lost connection: %v (%v)\n", time.Now().Format(time.Stamp), c.RemoteAddr().String(), client_list[c].worker)
|
||||||
delete(client_list, c)
|
delete(client_list, c)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user