近期,我想測試一下Go連接MySQL的性能,但是發現很難找到并發很少的工具,于是我使用了Go自帶的go test
命令進行測試。
首先,我需要安裝Go的MySQL驅動程序go-sql-driver/mysql
。安裝的命令如下:
go get -u github.com/go-sql-driver/mysql
接下來是測試代碼:
package main
import (
"database/sql"
"fmt"
"log"
"sync"
"testing"
_ "github.com/go-sql-driver/mysql"
)
func BenchmarkSelect(b *testing.B) {
db, err := sql.Open("mysql", "root:password@tcp(127.0.0.1:3306)/testdb")
if err != nil {
log.Fatal(err)
}
defer db.Close()
wg := sync.WaitGroup{}
for i := 0; i< b.N; i++ {
wg.Add(1)
go func() {
defer wg.Done()
rows, err := db.Query("SELECT * FROM users WHERE id=?", 1)
if err != nil {
log.Fatal(err)
}
defer rows.Close()
for rows.Next() {
var id int
var name string
if err := rows.Scan(&id, &name); err != nil {
log.Fatal(err)
}
fmt.Println(id, name)
}
}()
}
wg.Wait()
}
這段代碼使用了Go的sync.WaitGroup
來實現等待所有協程完成任務。在循環的每個迭代中,通過wg.Add(1)
來增加WaitGroup
的計數器,然后使用go func()
來啟動一個協程執行查詢。查詢的結果會在標準輸出中打印。
接下來,我在終端中使用命令go test -bench=. -benchtime=1s
來運行測試。其中,-bench=.
表示運行所有基準測試函數,-benchtime=1s
表示每個測試函數運行1秒。
$ go test -bench=. -benchtime=1s
goos: darwin
goarch: amd64
pkg: database/sql
BenchmarkSelect-4 50 21259044 ns/op
PASS
ok database/sql 1.176s
這個測試的結果顯示,在這個測試環境中,每個查詢大約需要21.3ms。這個性能表現非常好,因為Go的MySQL驅動程序在內部使用了連接池,可以重復使用已經創建的連接,而不是每次創建新的連接。這樣可以大大提高性能和并發能力。