连接池 generic-pool之MySQL

前言

对于为什么要使用连接池,说白了就是降低系统开销,当我们在频繁创建和销毁的时候就会产生非常大的系统开销。

在我们平时使用时,没什么感觉,都是自己一个人用,系统开销非常小,但是当成百上千人在使用呢?而连接池的作用就是限制我们进行频繁的创建和销毁,使每次的访问都是之前已经创建好的,即重复利用。

好处

1.可以不必为建立连接和释放连接消耗更多的响应时间,一个连接在高并发下可以被高度重用。

2.有队列机制,当池子中连接都用完了,其他请求在排队时,有一些紧急的任务需要插队,我们可以很方便的做到这点

安装方式

$ npm install generic-pool@3.8.2

创建pool,在对应字段填写对应 mysqlip, port, user, password 等信息
由于我使用的是MySQL数据库,所以就以MySQL为主,使用别的数据库,这个支持的数据库还是挺多的,具体查看官网吧。

// dao-pool.js
let genericPool = require('generic-pool');
let mysql = require('mysql');

let DEFAULT_MIN_POOL_SIZE = 5;     // 最少
let DEFAULT_MAX_POOL_SIZE = 20;    // 最多
let DEFAULT_IDLE_TIMEOUT_IN_MILLIS = 30 * 1000; //毫秒

/*
 * 创建mysql连接池
 */
module.exports = function () {
    return genericPool.createPool({
        name: 'mysql',
        create: function () {
            let client = mysql.createConnection({
                host: '127.0.1',
                port: '3306',
                user: 'root',
                password: '123456',
                database: 'db1',
                charset: 'utf8mb4',
                multipleStatements: true,
            });
            // 测试连接用
            // client.connect();
            return client;
        },
        destroy: function (client) {
            client.destroy();
        }
    },{
        max: DEFAULT_MAX_POOL_SIZE,
        min: DEFAULT_MIN_POOL_SIZE,
        idleTimeoutMillis: DEFAULT_IDLE_TIMEOUT_IN_MILLIS,
        priorityRange: 3,
        log: false
    });
};


MySqlpool的封装使用

  • query回调函数的方式,这是平常使用的一种基础方式
  • promiseQuery 异步Promise 的使用方式,新手可以忽略,使用上面的就可以了。
// mysql.js

let sqlclient = module.exports;

let _pool;

let NND = {};

NND.init = function(){
	_pool = require('./dao-pool')();
};

/**
 * 获取mysql client并执行对应mysql命令
 */
NND.query = function(sql, args, cb){
	_pool.acquire().then(function (client){
		client.query(sql, args, function (err, res) {
			_pool.release(client);
			cb && cb(err, res);
		});
	}).catch(function (err) {
		cb && cb(err);
	});
};

/**
 * promise 异步查询
 */
NND.promiseQuery = function (sql, args) {	
	return new Promise(function (resolve) {
		NND.query(sql, args, function (err, res) {
			if (!!err){
				console.error("promiseQuery err:", err.message);
				resolve(null);
			} else {
				resolve(res);
			}
		});
	});
};


/**
 * 销毁连接池
 */
NND.shutdown = function(){
	_pool.drain().then(function () {
		_pool.clear();
	});
};

// 初始化
sqlclient.init = function() {
	if (!!_pool){
		return sqlclient;
	} else {
		NND.init();
		sqlclient.query = NND.query;
		sqlclient.promiseQuery = NND.promiseQuery;
		return sqlclient;
	}
};

// 关闭连接
sqlclient.shutdown = function() {
	NND.shutdown();
};

结束

大致使用方式,就是这样,做个记录方便自己以后使用,具体使用情况可以根据自己情况修改。

dmhsq-mysql-pool 是一个用于连接和管理 MySQL 数据库连接的资源池。在开发中,我们经常需要与数据库进行交互,执行查询、插入、更新等操作。然而,直接与数据库建立连接的方式会导致性能下降和资源浪费。 dmhsq-mysql-pool 提供了一种解决方案,它通过连接池的方式来管理数据库连接,减少了频繁创建和销毁连接的操作,提高了数据库操作的效率。连接池中维护了一定数量的数据库连接,当需要与数据库进行交互时,从连接池中获取一个空闲的连接,执行完操作后,将连接归还给连接池,而不是直接关闭。 使用 dmhsq-mysql-pool 的好处有以下几点: 1. 提高性能:通过使用连接池,避免了频繁创建和销毁连接的开销,减少了连接的等待时间,提高了数据库操作的性能。 2. 资源控制:连接池可以配置最大连接数量,防止连接线程过多导致数据库崩溃。同时可以配置最小连接数量,避免连接过少导致系统响应变慢。 3. 连接复用:连接池可以重复利用连接,避免了每次操作都重新创建连接的开销,提高了效率。 4. 连接管理:连接池可以对连接进行管理,包括超时时间、连接断开检测等,保证连接的可靠性和稳定性。 5. 简化代码:使用 dmhsq-mysql-pool 可以简化与数据库交互的代码,只需要从连接池获取连接和归还连接即可,不需要手动管理连接。 综上所述,dmhsq-mysql-pool 是一个非常有用的数据库连接管理工具,它可以提高数据库操作的性能和效率,同时简化了代码的编写。在开发中,合理使用连接池可以有效地提升系统的性能和稳定性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值