この記事では、接続の最大数を設定する方法、接続のMySQLにgolangを説明しています。
例では、とのパッケージのMySQL接続を与えていますgithub.com/go-sql-driver/mysql
。
接続のインターフェースの最大数を設定してあります
func (db *DB) SetMaxOpenConns(n int)
MySQLはオープンできる接続の最大数を設定します。
<= 0 N場合、オープン接続の数は限定されない表します。
デフォルトでは、つまり、接続数を制限しない、0です。
別の関連するパラメータは、接続数がMaxIdleConns
アイドル状態の接続の最大数を示します。
もしMaxIdleConns
0より大きく、そしてより大きく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
それだけで、接続を確立見ることができます。