golang結合mysql設置最大連接數(shù)和最大空閑連接數(shù)
本文介紹golang 中連接MySQL時,如何設置最大連接數(shù)和最大空閑連接數(shù)。
關于最大連接數(shù)和最大空閑連接數(shù),是定義在golang標準庫中database/sql的。
文中例子連接MySQL用的SQL driver package是github.com/go-sql-driver/mysql.
設置最大連接數(shù)的接口是
func (db *DB) SetMaxOpenConns(n int)
設置連接MySQL可以打開的最大連接數(shù)。
如果n <= 0,表示打開的連接數(shù)沒有限制。
默認為0,也就是不限制連接數(shù)。
另一個與連接數(shù)相關的參數(shù)是MaxIdleConns,表示最大空閑連接數(shù)。
如果MaxIdleConns 大于0,且大于MaxOpenConns,那么將調整MaxIdleConns等于MaxOpenConns,有多余的連接時會關閉多余的連接。
設置最大空閑連接數(shù)的接口是:
func (db *DB) SetMaxIdleConns(n int)
如果n<=0,表示不使用空閑連接池,即一個連接如果不使用,不會放入空閑連接池。因此,這種方式不會復用連接,每次執(zhí)行SQL語句,都會重新建立新的連接。
默認的最大空閑連接數(shù)為2:
const defaultMaxIdleConns = 2
關于打開的連接和空閑的連接之間的關系,補充一下:
打開的連接 = 正在使用的連接(inuse) + 處于空閑狀態(tài)的連接(idle)
下面對最大連接數(shù)和最大空閑連接數(shù)做下測試和驗證。
1.最大連接數(shù)測試
首先設置最大打開的連接數(shù)為1,接著開啟20個goroutine,每個goroutine執(zhí)行sql語句,打印執(zhí)行sql使用的連接的connection id。并執(zhí)行耗時的sql語句占用連接,觀察其他需要執(zhí)行SQL的goroutine的執(zhí)行情況。
例子代碼如下:
package main import ( "database/sql" "log" _ "github.com/go-sql-driver/mysql" ) var DB *sql.DB var dataBase = "root:Aa123456@tcp(127.0.0.1:3306)/?loc=Local&parseTime=true" func Init() { var err error DB, err = sql.Open("mysql", dataBase) if err != nil { log.Fatalln("open db fail:", err) } DB.SetMaxOpenConns(1) err = DB.Ping() if err != nil { log.Fatalln("ping db fail:", err) } } func main() { Init() //開啟20個goroutine for i:=0; i < 20; i++ { go one_worker(i) } select { } } func one_worker(i int) { var connection_id int err := DB.QueryRow("select CONNECTION_ID()").Scan(&connection_id) if err != nil { log.Println("query connection id failed:", err) return } log.Println("worker:", i, ", connection id:", connection_id) var result int err = DB.QueryRow("select sleep(10)").Scan(&result) if err != nil { log.Println("query sleep connection id faild:", err) return } }
output
2019/10/02 18:14:25 worker: 2 , connection id: 55
2019/10/02 18:14:25 worker: 17 , connection id: 55
2019/10/02 18:14:25 worker: 11 , connection id: 55
2019/10/02 18:14:35 worker: 3 , connection id: 55
2019/10/02 18:14:45 worker: 0 , connection id: 55
2019/10/02 18:14:45 worker: 4 , connection id: 55
2019/10/02 18:14:45 worker: 5 , connection id: 55
2019/10/02 18:15:05 worker: 7 , connection id: 55
2019/10/02 18:15:25 worker: 15 , connection id: 55
2019/10/02 18:15:25 worker: 6 , connection id: 55
2019/10/02 18:15:35 worker: 13 , connection id: 55
2019/10/02 18:15:45 worker: 19 , connection id: 55
2019/10/02 18:15:45 worker: 10 , connection id: 55
2019/10/02 18:15:45 worker: 12 , connection id: 55
2019/10/02 18:15:55 worker: 14 , connection id: 55
2019/10/02 18:16:15 worker: 8 , connection id: 55
2019/10/02 18:16:35 worker: 18 , connection id: 55
2019/10/02 18:16:35 worker: 1 , connection id: 55
2019/10/02 18:17:05 worker: 16 , connection id: 55
2019/10/02 18:17:35 worker: 9 , connection id: 55
使用show processlist查看連接
mysql> show processlist; +----+------+-----------------+------+---------+------+------------+------------------+ | Id | User | Host | db | Command | Time | State | Info | +----+------+-----------------+------+---------+------+------------+------------------+ | 20 | root | localhost | NULL | Query | 0 | starting | show processlist | | 55 | root | localhost:59518 | NULL | Query | 5 | User sleep | select sleep(10) | +----+------+-----------------+------+---------+------+------------+------------------+ 2 rows in set (0.00 sec)
使用netstat 查看連接
netstat -an | grep 3306 tcp4 0 0 127.0.0.1.3306 127.0.0.1.59518 ESTABLISHED tcp4 0 0 127.0.0.1.59518 127.0.0.1.3306 ESTABLISHED tcp46 0 0 *.3306 *.* LISTEN
從結果可以看到,20個goroutine輪流使用同一個連接(connection id 為55)執(zhí)行sql語句。
當連接被占用時,其他嘗試使用連接的goroutine會被阻塞。直到連接使用完后,其他goroutine才可以使用連接。
即使多個goroutine在執(zhí)行SQL,也沒有創(chuàng)建多個連接。
因此,最大連接數(shù)設置生效。
有些讀者可能會問,沒有看到設置最大空閑連接數(shù),此時最大空間連接數(shù)是多少?
前面已經(jīng)提到,默認的最大空閑連接數(shù)是2.
下面再來測試下最大空間連接數(shù)。
2.最大空閑連接數(shù)測試
下面例子中,設置最大連接數(shù)為1,最大空閑連接數(shù)為0.
并且每隔3s執(zhí)行一條SQL語句。
代碼如下:
package main import ( ? ? ? ? "database/sql" ? ? ? ? "log" ? ? ? ? "time" ? ? ? ? _ "github.com/go-sql-driver/mysql" ) var DB *sql.DB var dataBase = "root:Aa123456@tcp(127.0.0.1:3306)/?loc=Local&parseTime=true" func mysqlInit() { ? ? ? ? var err error ? ? ? ? DB, err = sql.Open("mysql", dataBase) ? ? ? ? if err != nil { ? ? ? ? ? ? ? ? log.Fatalln("open db fail:", err) ? ? ? ? } ? ? ? ? DB.SetMaxOpenConns(1) ? ? ? ? DB.SetMaxIdleConns(0) ? ? ? ? err = DB.Ping() ? ? ? ? if err != nil { ? ? ? ? ? ? ? ? log.Fatalln("ping db fail:", err) ? ? ? ? } } func main() { ? ? ? ? mysqlInit() ? ? ? ? for { ? ? ? ? ? ? ? ? execSql() ? ? ? ? ? ? ? ? time.Sleep(3*time.Second) ? ? ? ? } } func execSql() { ? ? ? ? var connection_id int ? ? ? ? err := DB.QueryRow("select CONNECTION_ID()").Scan(&connection_id) ? ? ? ? if err != nil { ? ? ? ? ? ? ? ? log.Println("query connection id failed:", err) ? ? ? ? ? ? ? ? return ? ? ? ? } ? ? ? ? log.Println("connection id:", connection_id) }
output:
2019/10/13 23:06:00 connection id: 26
2019/10/13 23:06:03 connection id: 27
2019/10/13 23:06:06 connection id: 28
2019/10/13 23:06:09 connection id: 29
2019/10/13 23:06:12 connection id: 30
2019/10/13 23:06:15 connection id: 31
2019/10/13 23:06:18 connection id: 32
2019/10/13 23:06:21 connection id: 33
2019/10/13 23:06:24 connection id: 34
2019/10/13 23:06:27 connection id: 35
2019/10/13 23:06:30 connection id: 36
2019/10/13 23:06:33 connection id: 37
2019/10/13 23:06:36 connection id: 38
從結果中可以看出,每次執(zhí)行SQL使用的連接connection id都不同。
設置最大空閑連接數(shù)為0,每次執(zhí)行SQL后,連接不會放入空閑連接池,而是會被關閉,下次執(zhí)行SQL時,會重新建立新的連接。
3.參考
到此這篇關于golang結合mysql設置最大連接數(shù)和最大空閑連接數(shù)的文章就介紹到這了,更多相關golang 最大連接數(shù)和最大空閑連接數(shù)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
GO語言判斷一個網(wǎng)段是否屬于另一個網(wǎng)段的子網(wǎng)
這篇文章主要介紹了GO語言判斷一個網(wǎng)段是否屬于另一個網(wǎng)段的子網(wǎng)的相關資料,內容介紹詳細,具有一定的參考價值,需要的朋友可任意參考一下2022-03-03go開發(fā)alertmanger實現(xiàn)釘釘報警
本文主要介紹了go開發(fā)alertmanger實現(xiàn)釘釘報警,通過自己的url實現(xiàn)alertmanager的釘釘報警,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-07-07Go結合Gin導出Mysql數(shù)據(jù)到Excel表格
本文主要介紹了Go結合Gin導出Mysql數(shù)據(jù)到Excel表格,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-08-08在Mac中搭建go語言開發(fā)環(huán)境的操作步驟
go語言在開發(fā)效率和運行效率中的優(yōu)勢讓很多人青睞,所以有傾向打算轉向go語言的開發(fā)。下面介紹在Mac中golang的開發(fā)環(huán)境配置。有需要的可以參考借鑒。2016-08-08