Skip to content

Latest commit

 

History

History
72 lines (62 loc) · 1.31 KB

README.md

File metadata and controls

72 lines (62 loc) · 1.31 KB

pool

Simple implementation of a tcp connection pool using the Go standard library.

Chinese Version

中文文档

/*
  pool behavior
*/
type IPool interface {
    Close() error
    Get() (c *Conn, err error)
    Put(c *Conn, err error)
}

Demo

Start listening

func TestListenAndServer(t *testing.T) {
    ListenAndServer()
}

init pool and post request concurrently

var opt = &Option{
    addr: "127.0.0.1:3000",
    size:        5,
    readTimeout: 30 * time.Second,
    dialTimeout: 5 * time.Second,
    keepAlive:   30 * time.Second,
}

func TestNewPool(t *testing.T) {
    pool, err := NewPool(opt)
    if err != nil {
        t.Fatal(err)
    }

    for i := 0; i < 10; i++ {
        go func(id int) {
            if err := SendInPool(pool, "Uid-"+strconv.Itoa(id)); err != nil {
                log.Print("Send in pool err: ", err)
            }
        }(i)
    }

    for {
        time.Sleep(1)
    }
}

func SendInPool(p *Pool, uid string) (err error) {
    var c *Conn
    if c, err = p.Get(); err != nil {
        return
    }
    defer p.Put(c, err)
    msg := &body.Message{Uid: uid, Val: "pixelpig!"}
    rec, err := c.Send(context.Background(), msg)
    if err != nil {
        log.Print(err)
    } else {
        log.Print(uid, ", Msg: ", <-rec)
    }
    return
}