zoukankan      html  css  js  c++  java
  • [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

  • 相关阅读:
    web前端优化之reflow(减少页面的回流)
    Javascript深拷贝
    MySQL 配置优化
    MySQ中Lmax_connections的合理设置
    Too many connections解决方案
    Linux 查看文件内容
    ON DUPLICATE KEY UPDATE
    jquery $.each 和for怎么跳出循环终止本次循环
    使用redis避免客户端频繁提交数据
    windows下为mysql添加日志
  • 原文地址:https://www.cnblogs.com/enix/p/3654894.html
Copyright © 2011-2022 走看看