You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
66 lines
929 B
Go
66 lines
929 B
Go
4 years ago
|
package dq
|
||
|
|
||
|
import (
|
||
|
"sync"
|
||
|
|
||
|
"github.com/beanstalkd/beanstalk"
|
||
|
)
|
||
|
|
||
|
type connection struct {
|
||
|
lock sync.RWMutex
|
||
|
endpoint string
|
||
|
tube string
|
||
|
conn *beanstalk.Conn
|
||
|
}
|
||
|
|
||
|
func newConnection(endpint, tube string) *connection {
|
||
|
return &connection{
|
||
|
endpoint: endpint,
|
||
|
tube: tube,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func (c *connection) Close() error {
|
||
|
c.lock.Lock()
|
||
|
conn := c.conn
|
||
|
c.conn = nil
|
||
|
defer c.lock.Unlock()
|
||
|
|
||
|
if conn != nil {
|
||
|
return conn.Close()
|
||
|
}
|
||
|
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (c *connection) get() (*beanstalk.Conn, error) {
|
||
|
c.lock.RLock()
|
||
|
conn := c.conn
|
||
|
c.lock.RUnlock()
|
||
|
if conn != nil {
|
||
|
return conn, nil
|
||
|
}
|
||
|
|
||
|
c.lock.Lock()
|
||
|
defer c.lock.Unlock()
|
||
|
|
||
|
var err error
|
||
|
c.conn, err = beanstalk.Dial("tcp", c.endpoint)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
c.conn.Tube.Name = c.tube
|
||
|
return c.conn, err
|
||
|
}
|
||
|
|
||
|
func (c *connection) reset() {
|
||
|
c.lock.Lock()
|
||
|
defer c.lock.Unlock()
|
||
|
|
||
|
if c.conn != nil {
|
||
|
c.conn.Close()
|
||
|
c.conn = nil
|
||
|
}
|
||
|
}
|