[MySQL]长连接和短链接(转载)

前端之家收集整理的这篇文章主要介绍了[MySQL]长连接和短链接(转载)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

转载于http://www.cnblogs.com/pipelone/archive/2010/06/02/1750026.html

什么是长连接?

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

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

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

  1. 而长连接通常就是:

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

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

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

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

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

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

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

在使用@R_403_198@_real_connect连接数据库之后,再使用@R_403_198@_options( &@R_403_198@,@R_403_198@_OPT_RECONNECT,… ) 来设置为自动重连。这样当@R_403_198@连接丢失的时候,使用@R_403_198@_ping能够自动重连数据库。如果是在@R_403_198@ 5.1.6之前,那么则应在每次执行完real_connect 之后执行@R_403_198@_options( &@R_403_198@,… ),如果是@R_403_198@ 5.1.6+,则在connect之前执行一次就够了。

查看@R_403_198@连接数

@R_403_198@admin -uroot -p processlist

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

在@R_403_198@的默认设置中,如果一个数据库连接超过8小时没有使用(闲置8小时),服务器将断开这条连接,后续在该连接上进行的查询操作都将失败。网络上对该问题的描述非常多。也提供了相应的解决办法。我在这里提一些我自己的看法。

解决办法:修改@R_403_198@服务器的配置参数

道理非常简单,@R_403_198@的默认设置是在数据库连接超过8小时没有使用后将其断开,如果我们将这个时间改成更大的数值,那么连接超时所需的时间就会更长,也就意味着更不容易超时。网络上提供的修改方法一般是修改/etc/my.cnf,在这个文件添加一行wait_timeout=你需要设置的超时时间 。实际上有一种比较简单的方法修改这个参数:

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

show global variables like 'wait_timeout';

猜你在找的MySQL相关文章