NodeJS 后端开发 07 MySQL数据库连接池开发生产应用

前篇 【NodeJS 后端开发 06 连接MySQL 】简单尝试了mysql js库来连接数据库。

该文章分享的js代码不适用于生成环境使用。

在生产环境中,后端服务对数据库连接的管理都是通过一个 数据库连接池。

在接口需要获取数据库数据的时候,从池中取一个活跃连接,到数据库取完数据/执行数据变更操作后,释放连接并放回连接池。

  

上图所示,当业务线程处理数据时,使用连接;右边为业务处理结束,释放连接,放回连接池中。

这里分享一个连接池的JS代码

const mysql = require("mysql");

const port = 3306

//创建数据库连接池,连接到指定IP
const pool = mysql.createPool({
    host: 'localhost',
    port: port,
    user: 'root',
    password: '12345678',
    database: 'demo20210330',
    multipleStatements: true
});

// 定义sql执行函数
// 并允许用户输入连接执行成功的回调函数onSuccess,以及错误回调onError
const runSql = function(sql, onSuccess, onError) {
    pool.getConnection(function(err, conn) {
        if (err) {
            onError(err);
            return;
        }
        conn.query(sql, function(err, data) {
            try {
                if (err) {
                    onError(err);
                } else {
                    onSuccess(data);
                }
            } catch(err) {
                onError(err);
            } finally {
                console.log('release connection');
                conn.release();
            }
        });
    });
};

//查看池的状态
const showPool = function() {
    console.log('pool: ', pool);
};

module.exports.show = showPool;
module.exports.runSql = runSql;

这个工具JS库runSql函数中每次执行SQL,最后不管结果如何,总会在finally内释放链接,达到了连接自动回收的作用。

PS:上面的数据库配置密码过于简单,实际环境建议改复杂点(推荐:通过环境配置来解密数据库密码)。

保存代码为dbpool.js, 进入Node终端;然后输入以下代码并查看结果:

var pool = require('./dbpool')

pool.runSql("select * from company;", (e)=>console.log(e)

PS:下面的数据库在前一篇文章中提前创建好了

输入pool.show() 查看连接池状态, 比如连接信息,空闲的数据库连接等。

   

注意事项:连接池的连接不要手动去调用destroy(销毁连接)。
 

连接池的作用

因为销毁连接,当业务需要的时候调用数据库获取数据的时候,需要重新建立连接(TCP连接),这个过程开销是很大的。

相比之下,维持一个长连接省去很多建立重连TCP的时间。

起到了缓冲作用,而且所有数据库连接都会在缓存池里被统一管理。

上文是MySQL JS库自带的连接池,普通应用开发上面的足够,在Github上还有一个通用连接池项目:https://github.com/coopernurse/node-pool

对了,学委还有这个可以关注长期阅读 =>雷学委趣味编程故事汇编
或者=> 雷学委NodeJS系列

后面会单独发一篇解析。

持续学习持续开发,我是雷学委!
编程很有趣,关键是把技术搞透彻讲明白。
创作不易,请多多支持,点赞收藏支持学委吧!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

雷学委

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值