node.js 出现错误代码 Cannot enqueue Handshake after invoking quit

本文探讨了数据库连接管理策略,包括连接后是否关闭的问题。分析了重新建立连接的性能成本,并提出了适用于小型应用或低频操作场景的连接保持方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

出现错误的原因是 数据库的连接对象被设计成一挂掉就无法重连。

但是我们还是希望数据库不用的时候end因为数据库的连接次数有限。


但是重新打开链接相对于一般的新增数据操作(insert)来说确实比较耗性能,约为新增数据操作(insert)的10-100倍,但是除非日处理数据千万级以上的应用,否则重新关闭打开数据库链接所带来的性能损耗不明显。

所以人数少的或者操作不频繁可以考虑用这种方式--连接之后不关闭,

如果你是在伺服web请求,你就不该在每次请求处理完时关掉连接了。服务器启动时创建一个连接,然后一直用connection/client对象查询就好。

解决方法

1.例如我的config.js的配置,因为使用该网页的人数不多,所以我采用了连接后不关闭的做法

//数据库配置
//连接数据库
var mysql = require('mysql');
	

var connection = mysql.createConnection({
    host: "localhost",
    user: "root",
    password: "123456",
    database:'zxd_data'
});

connection.connect();

function selectfun(username,password,callback){

	connection.query('select password from user_info where username="'+username+'"',function(err,results){
		if(err) throw err;
		callback(results);		
	});	

}

function getSql(sql,callback){	

	
	connection.query(sql,function(err,results){
		if(err) throw err;
		console.log('从数据库中提取数据');		
		callback(results);		
	});

	
}



2.


https://stackoverflow.com/questions/14087924/cannot-enqueue-handshake-after-invoking-quit#




参考

http://www.cnblogs.com/LoveJenny/archive/2011/08/09/2131664.html#!comments

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值