[nodejs]解决mysql和连接池(pool)自动断开问题

   最近在做一个个人项目,数据库尝试使用了mongodb、sqlite和mysql。分享一下关于mysql的连接池用法。项目部署于appfog,项目中我使用连接池链接数据库,本地测试一切正常。上线以后,经过几次请求两个数据接口总是报503。一直不明就里,今天经过一番排查终于顺利解决了。

 

1.mysql 链接普通模式

 

mysql的普通用法如下所示:

复制代码
  var mysql = require('mysql'),

      env = {
        host : 'localhost',
        user : 'root',
        password : '2212',
        database : 'image_marker'
      };

    db = mysql.createConnection(env);
    db.connect();

    exports.do = function (sql, callback) {

      db.query(sql, callback);

    }

复制代码

MySQL中有一个名叫wait_timeout的变量,表示操作超时时间,当连接超过一定时间没有活动后,会自动关闭该连接,这个值默认为28800(即8小时)。关于普通用法链接丢失后重新链接,请看这里 传送门

 

2.使用连接池

之前我的错误代码,官网上只给出了连接池用法,但是没有给出和请求结合的实例。由于欠缺经验,我认为多个请求使用一个connection比较节省资源。后面发现,connetion经过一段时间后会自动断开,这样问题就出现了。

复制代码
pool.getConnection(function (err, connection){
    exports.do = function (sql, callback){
        
        connection.query(sql, function (){
            callback.apply(connection, arguments);
            connection.release();
        });
    }
})
复制代码

google/baidu后发现了一个使用pool的实例

发现他的代码每一次请求都用pool创建一个connection,改进我的代码终于解决了一段时间后connection自动断开的问题。

 

正确代码为

复制代码
pool  = mysql.createPool(env);

    exports.do = function (sql, callback){
        this.getConnection(function (err, connection){
            connection.query(sql, function (){
                callback.apply(connection, arguments);
                connection.release();
            });
        })
    }.bind(pool)
复制代码

为每一个请求都建立一个connection使用完后调用connection.release(); 直接释放资源。

 

参考资料

1.在Node.js使用mysql模块时遇到的坑

2.connection-pools-in-node-mysql-for-node-js

posted @   小玉西瓜  阅读(13075)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示