ConnPool.Begin/BeginIso will retry if they Acquire a dead connection

pull/92/head
Joseph Glanville 2015-09-11 03:05:39 +10:00
parent 8b296b9d58
commit 4868929ff1
1 changed files with 32 additions and 20 deletions

View File

@ -214,34 +214,46 @@ func (p *ConnPool) QueryRow(sql string, args ...interface{}) *Row {
// Begin acquires a connection and begins a transaction on it. When the
// transaction is closed the connection will be automatically released.
func (p *ConnPool) Begin() (*Tx, error) {
c, err := p.Acquire()
if err != nil {
return nil, err
}
for {
c, err := p.Acquire()
if err != nil {
return nil, err
}
tx, err := c.Begin()
if err != nil {
return nil, err
}
tx, err := c.Begin()
if err == ErrDeadConn {
p.Release(c)
continue
}
if err != nil {
return nil, err
}
tx.pool = p
return tx, nil
tx.pool = p
return tx, nil
}
}
// BeginIso acquires a connection and begins a transaction in isolation mode iso
// on it. When the transaction is closed the connection will be automatically
// released.
func (p *ConnPool) BeginIso(iso string) (*Tx, error) {
c, err := p.Acquire()
if err != nil {
return nil, err
}
for {
c, err := p.Acquire()
if err != nil {
return nil, err
}
tx, err := c.BeginIso(iso)
if err != nil {
return nil, err
}
tx, err := c.BeginIso(iso)
if err == ErrDeadConn {
p.Release(c)
continue
}
if err != nil {
return nil, err
}
tx.pool = p
return tx, nil
tx.pool = p
return tx, nil
}
}