1、什么是长连接

长连接是相对于通常的短连接而说的,也就是长时间保持客户端与服务端的连接状态。

通常的短连接操作步骤是:

连接-》数据传输-》关闭连接;

而长连接通常就是:

连接-》数据传输-》保持连接-》数据传输-》保持连接-》…………-》关闭连接;

这就要求长连接在没有数据通信时,定时发送数据包,以维持连接状态,短连接在没有数据传输时直接关闭就行了

1.1、什么时候用长连接,短连接?

长连接主要用于在少数客户端与服务端的频繁通信,因为这时候如果用短连接频繁通信常会发生Socket出错,并且频繁创建Socket连接也是对资源的浪费。

但是对于服务端来说,长连接也会耗费一定的资源,需要专门的线程(unix下可以用进程管理)来负责维护连接状态。

总之,长连接和短连接的选择要视情况而定。

首先,如果使用了长连接而长期没有对数据库进行任何操作,那么在timeout值后,mysql server就会关闭此连接,而客户端在执行查询的时候就会得到一个类似于“MySQL server has gone away“这样的错误。

在使用mysql_real_connect连接数据库之后,再使用mysql_options(&mysql, MYSQL_OPT_RECONNECT, … ) 来设置为自动重连。

这样当mysql连接丢失的时候,使用mysql_ping能够自动重连数据库。如果是在mysql 5.1.6之前,那么则应在每次执行完real_connect 之后执行mysql_options( &mysql, MYSQL_OPT_RECONNECT, … ) ,

如果是mysql 5.1.6+,则在connect之前执行一次就够了。

1.2、查看长连接

mysqladmin -uroot -p  processlist

实际的测试中我发现,当设置了MYSQL_OPT_RECONNECT为1时,超时后再查看processlist,则自动建立的连接不在列表中,但事实上连接确实建立并被使用了。

在MYSQL的默认设置中,如果一个数据库连接超过8小时没有使用(闲置8小时),服务器将断开这条连接,后续在该连接上进行的查询操作都将失败。

网络上对该问题的描述非常多。也提供了相应的解决办法。我在这里提一些我自己的看法。

2、解决方法

2.1、方法一:修改mysql配置参数

道理非常简单,MYSQL的默认设置是在数据库连接超过8小时没有使用后将其断开,如果我们将这个时间改成更大的数值,那么连接超时所需的时间就会更长,

也就意味着更不容易超时。

网络上提供的修改方法一般是修改/etc/my.cnf,在这个文件中添加一行wait_timeout=你需要设置的超时时间 。实际上有一种比较简单的方法来修改这个参数:

首先作为超级用户登录到MYSQL,注意必须是超级用户,否则后面会提示没有修改权限。

然后输入

showglobal variables like 'wait_timeout';

回车执行后显示目前的超时时间:+---------------+-------+

| Variable_name | Value |

+---------------+-------+

| wait_timeout | 28800 |

+---------------+-------+

1 row in set (0.00sec)

上面显示的是默认的超时时间,即8个小时(单位是秒)。现在重新设置该参数,例如我们要将超时时间设置成10个小时,可以输入:

然后在配置文件里修改:

[mysqld]

interactive_timeout= 120 #<==此参数设置后wait_timeout自动生效。

wait_timeout= 120回车执行,显示:

Query OK,0 rows affected (0.00sec)

表示设置成功,可以重新使用showglobal variables like 'wait_timeout'来验证。

这种方法比较直观,而且设置的参数立即生效。但如果/etc/my.cnf中没有配置,则重启服务后,global变量会从/etc/my.cnf中读取新的变量值。

2.2、 方法二:杀掉长连接进程

mysql>show processlist;+----+------+-----------+------+---------+------+-------+------------------+

| Id | User | Host | db | Command | Time | State | Info |

+----+------+-----------+------+---------+------+-------+------------------+

| 1 | root | localhost | NULL | Query | 0 | init | show processlist |

+----+------+-----------+------+---------+------+-------+------------------+

1 row in set (0.00sec)

mysql> kill 212555221;

2.3、补充方法:

# 在PHP程序中,不使用持久连接,即使用mysql_connetct而不是pconnect

# PHP程序执行完毕,应该显式调用mysql_close

#Java程序调整连接池(c3P0)或者调整Java服务(tomcat有关连接池参数)

# 逐步分析mysql的SQL查询及慢查询日志,找到查询过慢的sql,优化他。

关键词解释:

(1)interactive_timeout:

参数含义:服务器关闭交互式连接前等待活动的秒数。交互式客户端定义为在mysql_real_connect()中使用CLIENT_INTERACTIVE选项的客户端。

参数默认值:28800秒(8小时)

(2)wait_timeout:

参数含义:服务器关闭非交互连接之前等待活动的秒数。

在线程启动时,根据全局wait_timeout值或全局interactive_timeout值初始化会话wait_timeout值,取决于客户端类型(由mysql_real_connect()的连接选项CLIENT_INTERACTIVE定义)。

参数默认值:28800秒(8小时)

问题1:这里为什么要同时设置interactive_timeout,wait_timeout的设置才会生效?

答: 不设置interactive_timeout,wait_timeout也会生效。

问题2:interactive的值如果设置的和wait_timeout不同,为什么Interactive_timeout会覆盖wait_timeout?答:在交互模式下(CLIENT_INTERACTIVE),interactive_timeout才生效,非交互模式下,不生效。

问题3:在进行MySQL优化时,因为interactive_timeout决定的是交互连接的时间长短,而wait_timeout决定的是非交互连接的时间长短。如果在进行连接配置时mysql_real_connect()最后一个参数client_flag不设置为CLIENT_INTERACTIVE,是不是interactive_timeout的值不会覆盖wait_timeout?答:可以做实验试试。

问题4:为了减少长连接的数量,在设置优化时是不是可以将interactive_timeout的值设置的大些,而wait_timeout的值设置的小些?但是问题2的描述好像又不允许这样。。。

答:如2所述,在交互模式下,interactive_timeout取代wait_timeout。这样,如果有的客户端是交互模式方式连接mysql server。那么客户端的timeout受制于interactive_timeout。如果有的客户端是非交互模式,长连接mysql server。那么客户端的timeout受制于wait_timeout。(是否是交互模式的连接,由客户端决定)

MySQL客户端连接被频繁杀掉,企业案例(一):由于mysql sleep线程过多小故障相关推荐

  1. mysql客户端启动失败_MySQL Study案例之--MySQL客户端连接故障

    MySQL Study案例之--MySQL客户端连接故障 系统环境: 操作系统:RedHat EL6 DB Soft:  MySQL 5.6.4-m7 在系统安装了源码包 MySQL 5.6.4-m7 ...

  2. MySQL客户端连接网络不稳定解决办法

    博文背景 作者是中国移动的校园网,网络连接不是很稳定,连接远程MySQL服务器会经常性出现断连现象,所以导致每次只要在客户端等几分钟不操作后再去执行操作时会导致需要新的新的连接建立需要十几秒中,大大降 ...

  3. linux mysql 客户端连接,linux系统中启动mysql方式已经客户端如和连接mysql服务器

    零点间的记录 一.启动方式 1.使用linux命令service 启动: service mysqld start 2.使用 mysqld 脚本启动: /etc/inint.d/mysqld star ...

  4. mysql 客户端连接日志_MySQL 日志详解

    一.MySQL 日志分类 MySQL 日志主要包含:错误日志.查询日志.慢查询日志.事务日志.二进制日志. 错误日志: -log-err (记录启动.运行.停止 MySQL 服务时出现的信息) 查询日 ...

  5. mysql客户端连接10060_mysql客户端连接失败处理方法(can't connect to MySQL server on localhost'(10060))...

    之前很少接触数据库,虽然培训过oracle,但是也只是简单的安装,备份和恢复,其他的一概不懂,还在琢磨中.甚至于大学时候学习的sql语句也是忘的差不多一干二净了.所以等于一切从零开始. mysql的安 ...

  6. mysql客户库_你应该知道的10个MySQL客户启动选项

    大部分服务器管理员知道MySQL数据库管理系统(RDBMS)是高度灵活的软件块,带有范围广阔的启动选项,可以用来修改相关行为.然而,大部分人却不清楚,标准MySQL客户端带有同等大量的启动选项,其中一 ...

  7. mysql客户端连接hive_连接Hive的客户端界面工具–SQuirrel SQL Client

    关键字:Hive客户端.界面.SQuirrel SQL Client 刚看到一个可以连接Hive的客户端界面工具–SQuirrel SQL Client,试了一下,用起来还行,在这里记录一下安装及使用 ...

  8. mysql客户端连接10060,Navicat远程连接MySQL出现10060解决办法小结

    Navicat远程连接MySQL出现10060解决办法小结 Navicat远程连接MySQL出现10060解决办法小结 问题背景:服务器环境使用的是lnmp一键包,mysql版本5.7.26,phpM ...

  9. Mysql客户端连接服务端提示“Access denied for user ‘user_name‘@‘xxx.xxx.xx.xx‘ (using password: YES)”

    1. 检查Mysql服务端的3306端口是否监听,发现监听在127.0.0.1上: 之后修改mysql配置文件/etc/mysql/mysql.conf/mysqld.cnf,将里面的bind ip修 ...

最新文章

  1. 使用 mysql workbench 建议
  2. 使用 Python 一步步搭建自己的区块链
  3. msc货物跟踪查询_运联研究 | 货物全程可视,能否真正消除物流信息盲点?
  4. 缓存系列之一:buffer、cache与浏览器缓存
  5. EditPlus构建轻量级编译环境
  6. uwsgi03----直接部署
  7. 同一个按钮绑定多个事件_带你走进JavaScript世界系列——事件处理程序之 IE 事件处理...
  8. react轮播图插件_React 基础面试题 - 和你随便聊聊 React
  9. javascript 同时下载多个文件
  10. WireShark抓包原理解析及抓包实战教程
  11. 菜鸟版JAVA设计模式—从笔记本电源线看适配器模式
  12. 理解Celery的worker
  13. qt android图片自适应大小,Qt on Android:怎样适应不同的屏幕尺寸
  14. 134_人人后台管理系统-立即执行定时任务失败(坑)
  15. 一车abs线路怎么量_汽车ABS传感器怎么测量好坏?
  16. Windows双显示器扩展怎么设置上下扩展
  17. SAP请求释放怎么撤回
  18. 孔雀优化算法(Peafowl (Pavo Muticus/Cristatus) Optimization Algorithm, POA)
  19. ubuntu无网卡使用360wifi 联网
  20. Failed to connect to raw.githubusercontent.com port 443 处理方法

热门文章

  1. perl -p -i -e s/aaaaa/bbbbb/g ./*.sql
  2. xml实现删除一个节点
  3. vc picture控件的分类总结(转载)
  4. 人民大学的《统计学》
  5. Kafka监控KafkaOffsetMonitor【转】
  6. [BZOJ4568][SCOI2016]幸运数字(倍增LCA,点分治+线性基)
  7. 实体框架(Entity Framework)简介
  8. leetcode @python 130. Surrounded Regions
  9. Linux高级权限管理
  10. java学习日记(9)———socket,网络编程的学习