gpt4 book ai didi

mysql - 如何让 golang mysql 驱动程序在 2 秒内超时 ping?

转载 作者:IT王子 更新时间:2023-10-29 01:44:05 27 4
gpt4 key购买 nike

我在弄清楚如何在 Go 中正确设置数据库连接尝试超时时遇到了一些问题。我正在使用 this excellent resource 中的一些示例作为基地。我相信我已正确设置所有内容,但我的 ping 只是在 2 秒后拒绝超时。我已经将有问题的代码提取到示例程序中,如下所示。请注意,在 172.1.2.3 上没有运行数据库。

package main

import (
"context"
"database/sql"
_ "github.com/go-sql-driver/mysql" //MySQL driver
"log"
"time"
)

func main() {
log.Print("Trying to ping database!")

//Prepare a "context" to execute queries in, this will allow us to use timeouts
var bgCtx = context.Background()
var ctx2SecondTimeout, cancelFunc2SecondTimeout = context.WithTimeout(bgCtx, time.Second*2)
defer cancelFunc2SecondTimeout()

//Open database connection
db, err := sql.Open("mysql", "root:@tcp(172.1.2.3)/testdb?parseTime=true")
if err != nil {
log.Printf("Unable to open db, %s", err.Error())
return
}
log.Print("Successfully called open()")

//Ping database connection with 2 second timeout
err = db.PingContext(ctx2SecondTimeout)
if err != nil {
log.Printf("Can't ping database server in order to use storage, %s", err.Error())
return
}
log.Print("Successfully pinged database!")
}

运行该程序最多需要 2 秒,但实际需要 2 分钟以上:

$ go run lambdatry.go
2018/09/03 16:33:33 Trying to ping database!
2018/09/03 16:33:33 Successfully called open()
2018/09/03 16:35:43 Can't ping database server in order to use storage, dial tcp 172.1.2.3:3306: connect: connection timed out

如果我更改“数据库”的 IP(我只是选择了一个随机 IP,因此该地址没有数据库)数据库有时会立即超时,有时需要很长时间才能超时。

我在 ubuntu 18.04 上运行 go 1.10.1。

最佳答案

会不会是这个问题:https://github.com/golang/go/issues/27476

我的问题略有不同,它会超时一个 1 而不是 2 或 3 秒! https://media.dev.unee-t.com/2018-09-05/pingcontext.mp4

我的来源在这里:https://media.dev.unee-t.com/2018-09-05/main.go

关于mysql - 如何让 golang mysql 驱动程序在 2 秒内超时 ping?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52156175/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com