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

2023-11-09

   最近在做一个个人项目,数据库尝试使用了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

转载于:https://www.cnblogs.com/enix/p/3654894.html

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

[nodejs]解决mysql和连接池(pool)自动断开问题 的相关文章

随机推荐

  • JUST技术:时空轨迹挖掘助力物流小哥减负增效

    电商的发展需要依赖高效而可靠的物流服务 如何通过大数据和人工智能技术提升物流小哥的配送效率是我们一直在深入研究的问题 在刚刚结束的数据挖掘顶会KDD2020中 这篇 Doing in One Go Delivery Time Inferen
  • 31岁拿了阿里P6的offer,还有必要去吗?

    前几天看到一个非常现实且扎心的提问 31岁拿了阿里P6的offer 要去吗 首先给大家简单普及一下 估计很多小伙伴对阿里P6的概念比较模糊 甚至不少人觉得阿里P几啊什么的 就都很牛b 其实不然 P级只是阿里现行的职级划分体系 校招生进入阿里
  • sbt入门

    sbt入门 sbt 介绍 sbt 下载 sbt 安装 sbt 入门 helloworld sbt 目录结构 sbt 命令 总结 sbt 介绍 sbt是什么 sbt到底是什么 在网上找找 似乎找不到一个非常准确 而且大家都认可的定义 我自己对
  • FASTJSON和JACKSON基本使用

    Json是一种轻量级的数据交换格式 采用一种 键 值 对的文本格式来存储和表示数据 在系统交换数据过程中常常被使用 是一种理想的数据交换语言 在使用Java做Web开发时 不可避免的会遇到Json的使用 JSON形式与语法 JSON对象 我
  • linux使用xe命令管理远程xenserver机器

    1 linux下安装xe工具 xenserver6 2的dom0是32位centos5系统 xenserver6 5是64位centos系统 xe工具都是以rpm包形式提供 在ubuntu下安装时 先要用alien转换rpm包为deb包 注
  • group by的使用场景

    group by的使用场景 自我理解 一般配合sum使用 用来分组统计总 量 面试的时候最好说我们当时用的group 加sum查询每个sku的销量 group by 分组 查询 就是把记录集中的记录按一定规则进行 分组统计 假设一个学生名单
  • Android 关于inflate

    通俗的说 inflate就相当于将一个xml中定义的布局找出来 因为在一个Activity里如果直接用findViewById 的话 对应的是setConentView 的那个layout里的组件 因此如果你的Activity里如果用到别的
  • AWK入门到精通系列——awk快速入门

    简介 AWK是一个优良的文本处理工具 Linux及Unix环境中现有的功能最强大的数据处理引擎之一 这种编程及数据操作语言 其名称得自于它的创始人阿尔佛雷德 艾侯 彼得 温伯格和布莱恩 柯林汉姓氏的首个字母 的最大功能取决于一个人所拥有的知
  • nrm下载报错(C:\Users\16500\AppData\Roaming\npm\node_modules\nrm\cli.js:9const open = require(‘open‘)问题解决

    问题报错 建议大家下载nrm的时候尽量在node js 16版本之上 不然会造成很多报错问题无法解决 node 16版本下载地址 node js 16 问题原因是应该使用 open 的 CommonJs规范的包 现在 open v9 0 0
  • 华为云计算01——虚拟化技术

    云计算概述 云计算不是一个新的技术 它是通过虚拟化技术 将物理硬件资源虚拟化成为多个能独立运行且相同的 能为多个虚拟机提供服务 最开始云计算由亚马逊提出 并完成了云计算的初步架构 但是 亚马逊云是私有的 未公布其代码与实现原理 而后来开源社
  • Flutter drawer 侧滑实现二(通过点击现实显示侧滑栏)

    1 首先在需要使用的页面加入下方代码 GlobalKey
  • FreeRTOS(1):任务

    目录 一 FreeRTOS 介绍 什么是 FreeRTOS 为什么选择 FreeRTOS FreeRTOS 资料与源码下载 FreeRTOS 实现多任务的原理 二 移植 FreeRTOS 到STM32 手动移植 使用CubeMX快速移植 快
  • printf() 函数不加 \n 无法及时输出

    for printf worker进程休息1秒 sleep 1 printf 函数末尾不加 n 就无法及时地将信息显示到屏幕上 这是因为行缓存 Windows上一般没有 类Unix上才有 行缓存 需要输出的数据不直接显示到终端 而是首先缓存
  • 关于详解Java的对象创建

    前言 在 还不清楚怎样面向对象 和 面向对象再探究 两篇文章中 都介绍了关于面向对象程序设计的概念和特点 其中也涉及到了许多代码 比如 Dog dog new Dog 这篇文章就主要来谈谈创建对象时的具体操作 2 引入例子 下面是一个Dog
  • 洛谷 P5710 数的性质

    题目描述 一些数字可能拥有以下的性质 性质 1 是偶数 性质 2 大于 4 且不大于 12 小A 喜欢这两个性质同时成立的数字 Uim 喜欢这至少符合其中一种性质的数字 八尾勇喜欢刚好有符合其中一个性质的数字 正妹喜欢不符合这两个性质的数字
  • VR开发——Unity中导入常用的VR开发插件及简单使用

    VR开发 Unity中导入VIVE的VR开发插件及简单使用 V客学院 今天我们来讲解如何进行简单的htc vive设备的软体开发 今天的教程主要讲解从插件的导入到基本的设置以及场景搭建 小白向 首先 我们需要进入Unity中的AssetsS
  • MySQL explain 、explain extended用法

    explain显示了mysql如何使用索引来处理select语句以及连接表 可以帮助选择更好的索引和写出更优化的查询语句 使用方法 在select语句前加上explain就可以了 如 explain select from statuses
  • Unity基础之Vuforia

    Vuforia官网 https developer vuforia com Vuforia Agumented Reality SDK Vuforia增强现实扩展工具包 所属公司 高通 支持平台 Android IOS UWP 支持设备 前
  • 基于langChain 的privateGPT 文档问答 研究

    参考 gihtub代码 https github com imartinez privateGPT 官网 privateGPT可以在断网的情况下 借助GPT和文档进行交互 有利于保护数据隐私 privateGPT可以有四个用处 1 增强知识
  • [nodejs]解决mysql和连接池(pool)自动断开问题

    最近在做一个个人项目 数据库尝试使用了mongodb sqlite和mysql 分享一下关于mysql的连接池用法 项目部署于appfog 项目中我使用连接池链接数据库 本地测试一切正常 上线以后 经过几次请求两个数据接口总是报503 一直