0
点赞
收藏
分享

微信扫一扫

连接池 generic-pool之MySQL

若如初梘 2022-03-21 阅读 54

前言

安装方式

// 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: 'host',
                port: '3306',
                user: 'root',
                password: '123456',
                database: 'db1',
                charset: 'utf8mb4',
                multipleStatements: true,
            });
            // 测试连接用
            // client.connect();
            return client;
        },
        destroy: function (client) {
            client.destroy();
        }
    },{
        max: mysqlConfig.pool.max || DEFAULT_MAX_POOL_SIZE,
        min: mysqlConfig.pool.min || DEFAULT_MIN_POOL_SIZE,
        idleTimeoutMillis: mysqlConfig.pool.idleTimeoutMillis || DEFAULT_IDLE_TIMEOUT_IN_MILLIS,
        priorityRange: 3,
        log: false
    });
};


// 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();
};

结束

举报

相关推荐

0 条评论