免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3915 | 回复: 5

max_connections参数的疑问 [复制链接]

论坛徽章:
9
射手座
日期:2014-07-29 13:05:07双子座
日期:2015-01-11 17:01:522015年亚洲杯之朝鲜
日期:2015-02-01 16:14:282015亚冠之阿尔艾因
日期:2015-06-04 17:54:40数据库技术版块每日发帖之星
日期:2015-08-02 06:20:00数据库技术版块每日发帖之星
日期:2015-10-28 06:20:00数据库技术版块每日发帖之星
日期:2015-11-26 06:20:0015-16赛季CBA联赛之天津
日期:2016-06-20 17:09:2015-16赛季CBA联赛之青岛
日期:2017-02-26 15:54:19
发表于 2015-07-29 18:07 |显示全部楼层
为了做测试,my.cnf将参数设置为5
  1. root@localhost] ((none)) 17:57> show variables like '%max_connections%';
  2. +-----------------+-------+
  3. | Variable_name   | Value |
  4. +-----------------+-------+
  5. | max_connections | 5     |
  6. +-----------------+-------+
  7. 1 row in set (0.00 sec)
复制代码
然后我为了达到最大连接数,开了5个终端均执行如下命令
  1. [root@my63 ~]# mysql
  2. Welcome to the MySQL monitor.  Commands end with ; or \g.
  3. ....................

  4. [root@localhost] ((none)) 18:01>
复制代码
第6个终端再次连接
  1. [root@my63 ~]# mysql
  2. ERROR 1040 (HY000): Too many connections
复制代码
如愿以偿的报错了


但是我登录该mysql所在主机
  1. [root@my63 ~]# netstat -anput|grep 3306
  2. tcp        0      0 192.168.1.12:3306           0.0.0.0:*                   LISTEN      6533/mysqld         
  3. tcp        0      0 192.168.1.12:49595          192.168.1.12:3306           ESTABLISHED 6534/mysqld         
  4. tcp        0      0 192.168.1.12:3306           192.168.1.12:49595          ESTABLISHED 6533/mysqld     
复制代码
明明有5个mysql客户端发起的连接,但这里只显示了一个

在已经连接上的mysql上执行
  1. [root@localhost] (ProjectM) 17:51> show processlist;
  2. +----+--------+--------------------+----------+-------------+------+-----------------------------------------------------------------------+------------------+
  3. | Id | User   | Host               | db       | Command     | Time | State                                                                 | Info             |
  4. +----+--------+--------------------+----------+-------------+------+-----------------------------------------------------------------------+------------------+
  5. |  1 | backup | 192.168.1.12:49595 | NULL     | Binlog Dump |  894 | Master has sent all binlog to slave; waiting for binlog to be updated | NULL             |
  6. |  2 | root   | localhost          | NULL     | Sleep       |  875 |                                                                       | NULL             |
  7. |  3 | root   | localhost          | ProjectM | Query       |    0 | init                                                                  | show processlist |
  8. |  4 | root   | localhost          | ProjectM | Sleep       |  752 |                                                                       | NULL             |
  9. |  5 | root   | localhost          | ProjectM | Sleep       |  731 |                                                                       | NULL             |
  10. |  7 | root   | localhost          | NULL     | Sleep       |  202 |                                                                       | NULL             |
  11. +----+--------+--------------------+----------+-------------+------+-----------------------------------------------------------------------+------------------+
复制代码
发现也看不到其他几个连接,

问:当生产系统mysql 报错 too many connections 而无法连接的时候,netstat -anput只能发现从非本机发起的连接,若本机多次发起连接则无法检索出来(netstat 将之视为一个连接,但mysql却视为多个),有什么办法能直接看到 造成too many connections的所有连接吗?包括由本机发起的多个连接

求职 : Linux运维
论坛徽章:
203
拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:57:092015小元宵徽章
日期:2015-03-06 15:58:182015年亚洲杯之约旦
日期:2015-04-05 20:08:292015年亚洲杯之澳大利亚
日期:2015-04-09 09:25:552015年亚洲杯之约旦
日期:2015-04-10 17:34:102015年亚洲杯之巴勒斯坦
日期:2015-04-10 17:35:342015年亚洲杯之日本
日期:2015-04-16 16:28:552015年亚洲杯纪念徽章
日期:2015-04-27 23:29:17操作系统版块每日发帖之星
日期:2015-06-06 22:20:00操作系统版块每日发帖之星
日期:2015-06-09 22:20:00
发表于 2015-07-30 00:14 |显示全部楼层
再开几个连接  

论坛徽章:
9
射手座
日期:2014-07-29 13:05:07双子座
日期:2015-01-11 17:01:522015年亚洲杯之朝鲜
日期:2015-02-01 16:14:282015亚冠之阿尔艾因
日期:2015-06-04 17:54:40数据库技术版块每日发帖之星
日期:2015-08-02 06:20:00数据库技术版块每日发帖之星
日期:2015-10-28 06:20:00数据库技术版块每日发帖之星
日期:2015-11-26 06:20:0015-16赛季CBA联赛之天津
日期:2016-06-20 17:09:2015-16赛季CBA联赛之青岛
日期:2017-02-26 15:54:19
发表于 2015-07-30 09:24 |显示全部楼层
回复 2# lyhabc
1、已经too many connections 了,如何再开连接
2、就算释放掉一两个连接,然后连接上了,有什么用 ?

   

论坛徽章:
2
数据库技术版块每日发帖之星
日期:2015-08-04 06:20:00数据库技术版块每日发帖之星
日期:2015-08-28 06:20:00
发表于 2015-08-01 11:40 |显示全部楼层
本帖最后由 swenzhao 于 2015-08-01 11:41 编辑

本机访问使用name pipe,使用netstat 看不到。

除非你带-h参数访问mysql。

论坛徽章:
223
2022北京冬奥会纪念版徽章
日期:2015-08-10 16:30:32操作系统版块每日发帖之星
日期:2016-05-10 19:22:58操作系统版块每日发帖之星
日期:2016-02-18 06:20:00操作系统版块每日发帖之星
日期:2016-03-01 06:20:00操作系统版块每日发帖之星
日期:2016-03-02 06:20:0015-16赛季CBA联赛之上海
日期:2019-09-20 12:29:3219周年集字徽章-周
日期:2019-10-01 20:47:4815-16赛季CBA联赛之八一
日期:2020-10-23 18:30:5320周年集字徽章-20	
日期:2020-10-28 14:14:2615-16赛季CBA联赛之广夏
日期:2023-02-25 16:26:26CU十四周年纪念徽章
日期:2023-04-13 12:23:10操作系统版块每日发帖之星
日期:2016-05-10 19:22:58
发表于 2015-08-03 00:19 |显示全部楼层
本机都是local socket连接的吧

看client的配置文件

论坛徽章:
59
2015七夕节徽章
日期:2015-08-24 11:17:25ChinaUnix专家徽章
日期:2015-07-20 09:19:30每周论坛发贴之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38荣誉版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年纪念徽章
日期:2015-07-20 11:05:27IT运维版块每日发帖之星
日期:2015-07-20 11:05:34操作系统版块每日发帖之星
日期:2015-07-20 11:05:36程序设计版块每日发帖之星
日期:2015-07-20 11:05:40数据库技术版块每日发帖之星
日期:2015-07-20 11:05:432015年辞旧岁徽章
日期:2015-07-20 11:05:44
发表于 2015-08-13 10:22 |显示全部楼层
链接数是内部保存的吧。比如你用JDBC连接呢。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP