-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathclient.go
53 lines (44 loc) · 854 Bytes
/
client.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
package pool
import (
"context"
)
type Client struct {
p Pooler
opts *Options
}
func NewClient(dialFunc DialFunc, log Logger, o ...Option) *Client {
opts := &Options{Dialer: dialFunc}
for _, fn := range o {
fn(opts)
}
p := NewConnPool(opts, log)
return &Client{
p: p,
opts: opts,
}
}
func (c *Client) Send(ctx context.Context, data []byte) error {
var (
conn *Conn
err error
)
if conn, err = c.p.Get(ctx); err != nil {
return err
}
defer c.p.Put(ctx, conn)
if c.opts.WriteFunc != nil {
err = conn.WithWriter(ctx, 0, c.opts.WriteFunc(data))
} else {
_, err = conn.Write(data)
}
return err
}
func (c *Client) Close() error {
return c.p.Close()
}
type PoolStats Stats
// PoolStats returns connection pool stats.
func (c *Client) PoolStats() *PoolStats {
stats := c.p.Stats()
return (*PoolStats)(stats)
}