1. 在连接URL中添加参数:驱动程序会识别并将连接设置为持久连接,比如:jdbc:mysql://localhost:3306/dbname?autoReconnect=true
2. 使用JDBC连接对象的setAutoCommit()方法设置自动提交为false,例如:conn.setAutoCommit(false)
3. 使用数据库连接池,通过连接池可以设置长连接,有助于提高性能和可靠性。
其实长连接是相对于通常的短连接而说的,也就是长时间保持客户端与服务端的连接状态。通常的短连接 *** 作步骤是:
连接-》数据传输-》关闭连接;
而长连接通常就是:
连接-》数据传输-》保持连接-》数据传输-》保持连接-》…………-》关闭连接;
这就要求长连接在没有数据通信时,定时发送数据包,以维持连接状态,短连接在没有数据传输时直接关闭就行了
什么时候用长连接,短连接?
长连接主要用于在少数客户端与服务端的频繁通信,因为这时候如果用短连接频繁通信常会发生Socket出错,并且频繁创建Socket连接也是对资源的浪费。
但是对于服务端来说,长连接也会耗费一定的资源,需要专门的线程(unix下可以用进程管理)来负责维护连接状态。
总之,长连接和短连接的选择要视情况而定。
在配置文件设置属性:webb/config/main.php中添加persistent或者attributes属性;
检测是否成功启用长连接
可以调用frameworkdbCDbConnection.php下的getPersistent()函数,返回true为启用成功,false为启用失败;
如果使用了长连接而长期没有对数据库进行任何 *** 作,那么在timeout值后,mysql
server就会关闭此连接,而客户端在执行查询的时候就会得到一个类似于“MySQL server has gone away“这样的错误。
望采纳,谢谢!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)