src.dualinventive.com/go/redis-proxy/vendor/github.com/pebbe/zmq4/examples/bstarsrv2.go

44 lines
1.0 KiB
Go

//
// Binary Star server, using bstar reactor.
//
package main
import (
zmq "github.com/pebbe/zmq4"
"github.com/pebbe/zmq4/examples/bstar"
"fmt"
"os"
)
// Echo service
func echo(socket *zmq.Socket) (err error) {
msg, err := socket.RecvMessage(0)
if err != nil {
return
}
_, err = socket.SendMessage(msg)
return
}
func main() {
// Arguments can be either of:
// -p primary server, at tcp://localhost:5001
// -b backup server, at tcp://localhost:5002
var bst *bstar.Bstar
if len(os.Args) == 2 && os.Args[1] == "-p" {
fmt.Println("I: Primary active, waiting for backup (passive)")
bst, _ = bstar.New(bstar.PRIMARY, "tcp://*:5003", "tcp://localhost:5004")
bst.Voter("tcp://*:5001", zmq.ROUTER, echo)
} else if len(os.Args) == 2 && os.Args[1] == "-b" {
fmt.Println("I: Backup passive, waiting for primary (active)")
bst, _ = bstar.New(bstar.BACKUP, "tcp://*:5004", "tcp://localhost:5003")
bst.Voter("tcp://*:5002", zmq.ROUTER, echo)
} else {
fmt.Println("Usage: bstarsrvs { -p | -b }")
return
}
bst.Start()
}