lampp mysql最大连接数_golang mysql 如何设置最大连接数和最大空闲连接数

本文介绍golang 中连接MySQL时,如何设置最大连接数和最大空闲连接数。

关于最大连接数和最大空闲连接数,是定义在golang标准库中database/sql的。

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

设置最大连接数的接口是

func (db *DB) SetMaxOpenConns(n int)

设置连接MySQL可以打开的最大连接数。

如果n <= 0,表示打开的连接数没有限制。

默认为0,也就是不限制连接数。

另一个与连接数相关的参数是MaxIdleConns,表示最大空闲连接数。

如果MaxIdleConns 大于0,且大于MaxOpenConns,那么将调整MaxIdleConns等于MaxOpenConns,有多余的连接时会关闭多余的连接。

设置最大空闲连接数的接口是:

func (db *DB) SetMaxIdleConns(n int)

如果n<=0,表示不使用空闲连接池,即一个连接如果不使用,不会放入空闲连接池。因此,这种方式不会复用连接,每次执行SQL语句,都会重新建立新的连接。

默认的最大空闲连接数为2:

const defaultMaxIdleConns = 2

关于打开的连接和空闲的连接之间的关系,补充一下:

打开的连接 = 正在使用的连接(inuse) + 处于空闲状态的连接(idle)

下面对最大连接数和最大空闲连接数做下测试和验证。

1.最大连接数测试

首先设置最大打开的连接数为1,接着开启20个goroutine,每个goroutine执行sql语句,打印执行sql使用的连接的connection id。并执行耗时的sql语句占用连接,观察其他需要执行SQL的goroutine的执行情况。

例子代码如下:

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)执行sql语句。

当连接被占用时,其他尝试使用连接的goroutine会被阻塞。直到连接使用完后,其他goroutine才可以使用连接。

即使多个goroutine在执行SQL,也没有创建多个连接。

因此,最大连接数设置生效。

有些读者可能会问,没有看到设置最大空闲连接数,此时最大空间连接数是多少?

前面已经提到,默认的最大空闲连接数是2.

下面再来测试下最大空间连接数。

2.最大空闲连接数测试

下面例子中,设置最大连接数为1,最大空闲连接数为0.

并且每隔3s执行一条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

从结果中可以看出,每次执行SQL使用的连接connection id都不同。

设置最大空闲连接数为0,每次执行SQL后,连接不会放入空闲连接池,而是会被关闭,下次执行SQL时,会重新建立新的连接。

3.参考

MYSQL 查看最大连接数和修改最大连接数

MySQL查看最大连接数和修改最大连接数 1.查看最大连接数show variables like '%max_connections%';2.修改最大连接数set GLOBAL max_connec ...

Docker搭建的MySQL容器出现 "Too many connections 1040" 最大连接数修改完未生效的解决方案

原文:Docker搭建的MySQL容器出现 "Too many connections 1040" 最大连接数修改完未生效的解决方案 版权声明:本文为博主原创文章,未经博主允许不得 ...

mysql 同时支持多少连接MYSQL 查看最大连接数和修改最大连接数

MySQL查看最大连接数和修改最大连接数 1.查看最大连接数 show variables like '%max_connections%'; 2.修改最大连接数 set GLOBAL max_con ...

Mysql字符集设置

转 基本概念 • 字符(Character)是指人类语言中最小的表义符号.例如’A'.’B'等:• 给定一系列字符,对每个字符赋予一个数值,用数值来代表对应的字符,这一数值就是字符的编码(Encodi ...

Ubuntu 16&period;04 安装mysql并设置远程访问

说明: 一个朋友在使用ubuntu-server 16.04安装mysql,设置远程访问的时候出现了问题,请我帮忙.但是,我也没有使用过ubuntu安装mysql,于是乎搜索了很多技术文件,比着葫芦画 ...

微信nickname乱码及mysql编码格式设置(utf8mb4)

微信nickname乱码及mysql编码格式设置(utf8mb4) 今天在写微信公众平台项目时,写到一个用户管理模块,接口神马的已经调试好了,于是将用户从微信服务器保存到本地数据库,发现报错: jav ...

Mysql 如何设置字段自动获取当前时间

应用场景: 1.在数据表中,要记录每条数据是什么时候创建的,不需要应用程序去特意记录,而由数据数据库获取当前时间自动记录创建时间: 2.在数据库中,要记录每条数据是什么时候修改的,不需要应用程序去特意 ...

mysql 的设置

网上的一些文章都已经比较老了,现在版本高了之后,其实配置是很省力的(不考虑什么负载的话) 分享全过程,出了文中提到的安装epel rpmfushion 源指令不同外,其他的过程也适用与Centos 5 ...

xampp默认mysql密码设置,修改mysql的默认空密码

xampp默认mysql密码设置,修改mysql的默认空密码 分类: xampp2012-09-12 11:24 30264人阅读 评论(5) 收藏 举报 mysqlphpmyadminauthent ...

随机推荐

Github Atom 1&period;12&period;0-beta3 发布

Github Atom 1.12.0-beta3 发布了,Atom 是 Github 专门为程序员推出的一个跨平台文本编辑器.具有简洁和直观的图形用户界面,并有很多有趣的特点:支持CSS,HTML,J ...

vb小程序浅析

系统 : Windows xp 程序 : BJCM10B 程序下载地址 :http://pan.baidu.com/s/1dFyXe29 要求 : 编写注册机 使用工具 : OD 可在看雪论坛中查找关 ...

unity3d——自带寻路Navmesh (三)(转)

继续介绍NavMesh寻路的功能,接下来阿赵打算讲一下以下两个例子,先看看完成的效果:   第一个例子对于喜欢DOTA的朋友应该很熟悉了,就是不同小队分不同路线进攻的寻路,红绿蓝三个队伍分别根据三条路 ...

settimeout 传递带有参数的函数

方法一:传递带有参数的function给settimeout,写个函数,该函数返回一个不带参数的函数

EF实体框架-从数据库更新模型 一部分表的外键(导航属性)无法显示

从数据库更新模型 要想让数据库表之间的外键关系 显示到实体模型的导航属性中去. 表的外键 对应另一张表的字段要是主键,唯一键显示不出来

iOS动画案例&lpar;1&rpar;

受人所托,做一个类似于qq账号信息里的一个动画,感觉挺有意思,也没感觉有多难,就开始做了,结果才发现学的数学知识都还给体育老师了,研究了大半天才做出来.    先看一下动画效果:   用到的知识 ...

前端学习笔记之HTML body内常用标签

阅读目录 一 HTML语义化 二 字符实体 三 h系列标签 四 p标签 五 img标签 六 a标签 七 列表标签 八 table标签 九 form标签 一 HTML语义化 body中的标签是会显示到浏 ...

order by 的用法

select * from emp order by sal desc  --将员工工资按照由高到低的顺序排列

Button按钮为什么无缘无故会提交form表单?

我的form表单里有好几个Button按钮,每个按钮有不同的功能,可是这些按钮居然都有提交功能,真是把我惊呆了

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值