Как я могу получить драйвер golang mysql для проверки времени ожидания через 2 секунды? - PullRequest
0 голосов
/ 04 сентября 2018

У меня возникли проблемы с поиском правильного истечения времени ожидания попытки подключения к базе данных в Go. Я использую некоторые примеры из этого превосходного ресурса в качестве базы. Я полагаю, что я все настраиваю правильно, но мои пинги просто отказываются делать перерыв через 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-адрес, так что по этому адресу нет базы данных), база данных иногда сразу же отключается, а иногда истекает время ожидания.

Я использую Go 1.10.1 в Ubuntu 18.04.

1 Ответ

0 голосов
/ 05 сентября 2018

Может быть, это проблема: 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

...