我遇到了一个有趣的问题,即即使数据库自第一次尝试以来已被杀死,db.Ping()也不会返回错误.
源代码如下:
import (
"database/sql"
"fmt"
"log"
"time"
_ "github.com/go-sql-driver/mysql"
)
type database struct {
datasource string
conn *sql.DB
}
// Connect creates and initialises a Database struct
func (db *database) Connect(server, user, password, DBPort string) error {
var err error
db.datasource = fmt.Sprintf("%s:%s@/", user, password)
db.conn, err = sql.Open(server, db.datasource)
if err != nil {
log.Fatal(err)
}
err = db.conn.Ping()
if err != nil {
db.conn.Close()
return err
}
log.Println("Waiting for 15 seconds, kill the DB")
<-time.After(15 * time.Second)
err = db.conn.Ping()
if err != nil {
db.conn.Close()
return err
}
log.Println("Second ping successful")
return nil
}
Run Code Online (Sandbox Code Playgroud)
首先,数据库已启动,因此第一个Ping成功.但是,为了测试,我在那里放了一个延迟.在那15秒内我停止了数据库(sudo service mysql stop),然而,db.Ping()仍然成功.
如果我要执行任何实际的查询(通过db.Query,db.QueryRow或db.Exec),那么sql包将使用Broken Pipe(预期)发生混乱.
难道我做错了什么?
另外:go go go7.1.1 linux/amd64
提前致谢!
| 归档时间: |
|
| 查看次数: |
1706 次 |
| 最近记录: |