欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

golang結(jié)合mysql設(shè)置最大連接數(shù)和最大空閑連接數(shù)

 更新時(shí)間:2022年02月20日 10:41:05   作者:翔云123456  
本文介紹golang?中連接MySQL時(shí),如何設(shè)置最大連接數(shù)和最大空閑連接數(shù),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文介紹golang 中連接MySQL時(shí),如何設(shè)置最大連接數(shù)和最大空閑連接數(shù)。

關(guān)于最大連接數(shù)和最大空閑連接數(shù),是定義在golang標(biāo)準(zhǔn)庫(kù)中database/sql的。

文中例子連接MySQL用的SQL driver package是github.com/go-sql-driver/mysql.

設(shè)置最大連接數(shù)的接口是

func (db *DB) SetMaxOpenConns(n int) 

設(shè)置連接MySQL可以打開(kāi)的最大連接數(shù)。

如果n <= 0,表示打開(kāi)的連接數(shù)沒(méi)有限制。

默認(rèn)為0,也就是不限制連接數(shù)。

另一個(gè)與連接數(shù)相關(guān)的參數(shù)是MaxIdleConns,表示最大空閑連接數(shù)。

如果MaxIdleConns 大于0,且大于MaxOpenConns,那么將調(diào)整MaxIdleConns等于MaxOpenConns,有多余的連接時(shí)會(huì)關(guān)閉多余的連接。

設(shè)置最大空閑連接數(shù)的接口是:

func (db *DB) SetMaxIdleConns(n int)

如果n<=0,表示不使用空閑連接池,即一個(gè)連接如果不使用,不會(huì)放入空閑連接池。因此,這種方式不會(huì)復(fù)用連接,每次執(zhí)行SQL語(yǔ)句,都會(huì)重新建立新的連接。

默認(rèn)的最大空閑連接數(shù)為2:
const defaultMaxIdleConns = 2

關(guān)于打開(kāi)的連接和空閑的連接之間的關(guān)系,補(bǔ)充一下:

打開(kāi)的連接 = 正在使用的連接(inuse) + 處于空閑狀態(tài)的連接(idle)

下面對(duì)最大連接數(shù)和最大空閑連接數(shù)做下測(cè)試和驗(yàn)證。

1.最大連接數(shù)測(cè)試

首先設(shè)置最大打開(kāi)的連接數(shù)為1,接著開(kāi)啟20個(gè)goroutine,每個(gè)goroutine執(zhí)行sql語(yǔ)句,打印執(zhí)行sql使用的連接的connection id。并執(zhí)行耗時(shí)的sql語(yǔ)句占用連接,觀察其他需要執(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()
        
        //開(kāi)啟20個(gè)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

從結(jié)果可以看到,20個(gè)goroutine輪流使用同一個(gè)連接(connection id 為55)執(zhí)行sql語(yǔ)句。

當(dāng)連接被占用時(shí),其他嘗試使用連接的goroutine會(huì)被阻塞。直到連接使用完后,其他goroutine才可以使用連接。

即使多個(gè)goroutine在執(zhí)行SQL,也沒(méi)有創(chuàng)建多個(gè)連接。

因此,最大連接數(shù)設(shè)置生效。

有些讀者可能會(huì)問(wèn),沒(méi)有看到設(shè)置最大空閑連接數(shù),此時(shí)最大空間連接數(shù)是多少?

前面已經(jīng)提到,默認(rèn)的最大空閑連接數(shù)是2.

下面再來(lái)測(cè)試下最大空間連接數(shù)。

2.最大空閑連接數(shù)測(cè)試

下面例子中,設(shè)置最大連接數(shù)為1,最大空閑連接數(shù)為0.

并且每隔3s執(zhí)行一條SQL語(yǔ)句。

代碼如下:

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

從結(jié)果中可以看出,每次執(zhí)行SQL使用的連接connection id都不同。

設(shè)置最大空閑連接數(shù)為0,每次執(zhí)行SQL后,連接不會(huì)放入空閑連接池,而是會(huì)被關(guān)閉,下次執(zhí)行SQL時(shí),會(huì)重新建立新的連接。

3.參考

Connection pool and timeouts

Golang MySQL 連接和連接池

到此這篇關(guān)于golang結(jié)合mysql設(shè)置最大連接數(shù)和最大空閑連接數(shù)的文章就介紹到這了,更多相關(guān)golang 最大連接數(shù)和最大空閑連接數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • GO語(yǔ)言判斷一個(gè)網(wǎng)段是否屬于另一個(gè)網(wǎng)段的子網(wǎng)

    GO語(yǔ)言判斷一個(gè)網(wǎng)段是否屬于另一個(gè)網(wǎng)段的子網(wǎng)

    這篇文章主要介紹了GO語(yǔ)言判斷一個(gè)網(wǎng)段是否屬于另一個(gè)網(wǎng)段的子網(wǎng)的相關(guān)資料,內(nèi)容介紹詳細(xì),具有一定的參考價(jià)值,需要的朋友可任意參考一下
    2022-03-03
  • go開(kāi)發(fā)alertmanger實(shí)現(xiàn)釘釘報(bào)警

    go開(kāi)發(fā)alertmanger實(shí)現(xiàn)釘釘報(bào)警

    本文主要介紹了go開(kāi)發(fā)alertmanger實(shí)現(xiàn)釘釘報(bào)警,通過(guò)自己的url實(shí)現(xiàn)alertmanager的釘釘報(bào)警,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • Go結(jié)合Gin導(dǎo)出Mysql數(shù)據(jù)到Excel表格

    Go結(jié)合Gin導(dǎo)出Mysql數(shù)據(jù)到Excel表格

    本文主要介紹了Go結(jié)合Gin導(dǎo)出Mysql數(shù)據(jù)到Excel表格,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • Skywalking-go自動(dòng)監(jiān)控增強(qiáng)使用探究

    Skywalking-go自動(dòng)監(jiān)控增強(qiáng)使用探究

    這篇文章主要介紹了Skywalking-go自動(dòng)監(jiān)控增強(qiáng)使用深入探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2024-01-01
  • Go語(yǔ)言自定義linter靜態(tài)檢查工具

    Go語(yǔ)言自定義linter靜態(tài)檢查工具

    這篇文章主要介紹了Go語(yǔ)言自定義linter靜態(tài)檢查工具,Go語(yǔ)言是一門(mén)編譯型語(yǔ)言,編譯器將高級(jí)語(yǔ)言翻譯成機(jī)器語(yǔ)言,會(huì)先對(duì)源代碼做詞法分析,詞法分析是將字符序列轉(zhuǎn)換為T(mén)oken序列的過(guò)程,文章詳細(xì)介紹需要的小伙伴可以參考一下
    2022-05-05
  • Go?select使用與底層原理講解

    Go?select使用與底層原理講解

    這篇文章主要介紹了Go?select使用與底層原理講解,select是Go提供的IO多路復(fù)用機(jī)制,可以用多個(gè)cas同時(shí)監(jiān)聽(tīng)多個(gè)channl的讀寫(xiě)狀態(tài),相關(guān)內(nèi)容需要的朋友可以參考一下
    2022-07-07
  • Go語(yǔ)言使用Etcd實(shí)現(xiàn)分布式鎖

    Go語(yǔ)言使用Etcd實(shí)現(xiàn)分布式鎖

    etcd是近幾年比較火熱的一個(gè)開(kāi)源的、分布式的鍵值對(duì)數(shù)據(jù)存儲(chǔ)系統(tǒng),本文將介紹如何利用Etcd實(shí)現(xiàn)分布式鎖,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-05-05
  • Go編譯原理之函數(shù)內(nèi)聯(lián)

    Go編譯原理之函數(shù)內(nèi)聯(lián)

    這篇文章主要為大家介紹了Go編譯原理之函數(shù)內(nèi)聯(lián)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • 深入剖析Go語(yǔ)言編程中switch語(yǔ)句的使用

    深入剖析Go語(yǔ)言編程中switch語(yǔ)句的使用

    這篇文章主要介紹了Go語(yǔ)言編程中switch語(yǔ)句的使用,是Go語(yǔ)言入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-10-10
  • 在Mac中搭建go語(yǔ)言開(kāi)發(fā)環(huán)境的操作步驟

    在Mac中搭建go語(yǔ)言開(kāi)發(fā)環(huán)境的操作步驟

    go語(yǔ)言在開(kāi)發(fā)效率和運(yùn)行效率中的優(yōu)勢(shì)讓很多人青睞,所以有傾向打算轉(zhuǎn)向go語(yǔ)言的開(kāi)發(fā)。下面介紹在Mac中g(shù)olang的開(kāi)發(fā)環(huán)境配置。有需要的可以參考借鑒。
    2016-08-08

最新評(píng)論