consul: helper to make RPC calls

This commit is contained in:
Armon Dadgar 2013-12-09 14:58:49 -08:00
parent ae30ace448
commit e699a14fe3

View File

@ -15,6 +15,10 @@ type Conn struct {
client *rpc.Client
}
func (c *Conn) Close() error {
return c.conn.Close()
}
// ConnPool is used to maintain a connection pool to other
// Consul servers. This is used to reduce the latency of
// RPC requests between servers. It is only used to pool
@ -50,7 +54,7 @@ func (p *ConnPool) Shutdown() error {
for _, conns := range p.pool {
for _, c := range conns {
c.conn.Close()
c.Close()
}
}
p.pool = make(map[string][]*Conn)
@ -131,7 +135,7 @@ func (p *ConnPool) Return(conn *Conn) {
// Check for limit on connections or shutdown
if p.shutdown || len(conns) >= p.maxConns {
conn.conn.Close()
conn.Close()
return
}
@ -139,3 +143,29 @@ func (p *ConnPool) Return(conn *Conn) {
conns = append(conns, conn)
p.pool[conn.addr.String()] = conns
}
// RPC is used to make an RPC call to a remote host
func (p *ConnPool) RPC(addr net.Addr, method string, args interface{}, reply interface{}) error {
// Try to get a conn first
conn, err := p.Acquire(addr)
if err != nil {
return err
}
// Make the RPC call
err = conn.client.Call(method, args, reply)
// Fast path the non-error case
if err == nil {
p.Return(conn)
return nil
}
// If not a network error, save the connection
if _, ok := err.(net.Error); !ok {
p.Return(conn)
} else {
conn.Close()
}
return err
}