接続の最大数を設定しgolang mysqlの

この記事では、接続の最大数を設定する方法、接続のMySQLにgolangを説明しています。

例では、とのパッケージのMySQL接続を与えていますgithub.com/go-sql-driver/mysql

接続のインターフェースの最大数を設定してあります

func (db *DB) SetMaxOpenConns(n int) 

MySQLはオープンできる接続の最大数を設定します。

<= 0 N場合、オープン接続の数は限定されない表します。

デフォルトでは、つまり、接続数を制限しない、0です。

別の関連するパラメータは、接続数がMaxIdleConnsアイドル状態の接続の最大数を示します。

もしMaxIdleConns0より大きく、そしてより大きくMaxOpenConns、そして最後MaxIdleConnsの最後等しいですMaxOpenConns

1.試験例

まず、接続の最大数は、開口部1のために提供され、その後、各ゴルーチンSQLステートメントの実行を20ゴルーチンになって、使用する印刷実行SQL接続IDに接続されています。そして、時間のかかるSQL文の占有接続、結果を観察します。

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()

        for {
                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
        }

}

出力

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

出力から見ることができる、接続(55のような接続ID)を用いて20のターンは、SQLステートメントを実行ゴルーチン。

2.接続を確認してください

ショー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

それだけで、接続を確立見ることができます。

おすすめ

転載: www.cnblogs.com/lanyangsh/p/11618821.html