Node.js如何實(shí)現(xiàn)MySQL數(shù)據(jù)庫連接池
什么是數(shù)據(jù)庫連接池
數(shù)據(jù)庫連接池是程序啟動時(shí)建立足夠數(shù)量的數(shù)據(jù)庫連接對象,并將這些連接對象組成一個(gè)池,由程序動態(tài)地對池中的連接對象進(jìn)行申請、使用和釋放。
原理及優(yōu)點(diǎn)
數(shù)據(jù)庫連接池在初始化時(shí)將會創(chuàng)建一定數(shù)量的數(shù)據(jù)庫連接對象放到連接池中,連接池都將一直保證至少擁有這么多的連接數(shù)量,當(dāng)有數(shù)據(jù)庫需要被連接的時(shí)候,它會向數(shù)據(jù)庫連接池申請資源和使用,使用完成后會釋放到數(shù)據(jù)庫連接池中。當(dāng)然數(shù)據(jù)庫連接池中擁有最小連接數(shù)量和最大連接數(shù)量,當(dāng)數(shù)據(jù)庫的連接超過連接池中最大的數(shù)量的時(shí)候,這些請求將被加入到等待隊(duì)列中。
用服裝店招聘導(dǎo)購來說明數(shù)據(jù)庫連接池。當(dāng)只有顧客A時(shí),服裝店招聘一個(gè)導(dǎo)購A,如果之后顧客B、C、D、E、F…也來了,那么就需要不斷招聘導(dǎo)購B、C、D、E、F…,這樣會帶來大量的人力成本。

如果讓一個(gè)主管去管理一定數(shù)量(以5為例)的導(dǎo)購,當(dāng)顧客A、B、C、D、E來了,主管依次分配了導(dǎo)購A、B、C、D、E,但如果顧客F來了,由于已經(jīng)沒有空閑的導(dǎo)購了,因此顧客F需要排隊(duì)等待。

等A、B、C、D、E導(dǎo)購其中任何一個(gè)服務(wù)完成后(比如說導(dǎo)購D),他又重新回到了導(dǎo)購組中,這時(shí)主管會將他分配給顧客F。

數(shù)據(jù)庫的鏈接池也是這個(gè)意思,當(dāng)網(wǎng)站某一天有很大的流量的時(shí)候,數(shù)據(jù)庫服務(wù)器需要為每次鏈接創(chuàng)建一次數(shù)據(jù)庫鏈接。
這樣就很浪費(fèi)數(shù)據(jù)庫的資源,并且頻繁的創(chuàng)建和關(guān)閉數(shù)據(jù)庫的鏈接,很容易導(dǎo)致服務(wù)器內(nèi)存溢出等情況發(fā)生。
連接池的作用
數(shù)據(jù)庫的連接池負(fù)責(zé)分配、管理和釋放數(shù)據(jù)庫連接對象的。
它允許應(yīng)用程序重復(fù)使用一個(gè)現(xiàn)有的數(shù)據(jù)庫的連接對象。而不是重新創(chuàng)建一個(gè)。
實(shí)現(xiàn)連接池
1.導(dǎo)入mysql模塊
首先安裝mysql模塊:
npm install mysql
導(dǎo)入mysql模塊:
const mysql = require("mysql");2.創(chuàng)建數(shù)據(jù)庫連接池
創(chuàng)建數(shù)據(jù)庫連接池語法如下:
const pool = mysql.createPool({
host: "數(shù)據(jù)庫服務(wù)器地址",
port: 3306, // MySQL數(shù)據(jù)庫端口號
database: "數(shù)據(jù)庫名",
user: "連接數(shù)據(jù)庫的用戶名",
password: "連接數(shù)據(jù)庫的密碼",
connectionLimit: "指定連接池中最大的鏈接數(shù),默認(rèn)是10",
queueLimit: "指定允許掛起的最大連接數(shù),如果掛起的連接數(shù)超過該數(shù)值,就會立刻拋出錯(cuò)誤,默認(rèn)屬性值為0,代表不允許被掛起的最大連接數(shù)",
multipleStatements: "是否運(yùn)行執(zhí)行多條sql語句,默認(rèn)值為false"
})示例:創(chuàng)建數(shù)據(jù)庫連接池
const mysql = require("mysql");
const pool = mysql.createPool({
host: "127.0.0.1", // 主機(jī)地址
port: 3306,
database: "info", // 數(shù)據(jù)庫名字
user: "root", // 連接數(shù)據(jù)庫的用戶名
password: "123456", // 連接數(shù)據(jù)庫密碼
connectionLimit: 20, // 連接池最大連接數(shù)
multipleStatements: true // 允許執(zhí)行多條sql語句
})
module.exports = pool;3.從連接池中獲取一個(gè)連接
語法:
pool.getConnection(function (err, connection) {
// 代碼
});err:該參數(shù)是指操作失敗時(shí)的錯(cuò)誤對象。connection:該值為一個(gè)對象,代表獲取到的連接對象。當(dāng)連接失敗時(shí),該值為undefined。
4.釋放連接對象(放回連接池)
connection.release();
5.從連接池中移除連接對象
connection.destory();
6.關(guān)閉該連接池
pool.end();
案例
使用連接池連接MySQL數(shù)據(jù)庫,查詢info數(shù)據(jù)庫中stu表中的所有信息,
stu表具體如下:

創(chuàng)建mydb.js,創(chuàng)建數(shù)據(jù)庫連接池,代碼如下:
const mysql = require("mysql");
// 創(chuàng)建數(shù)據(jù)庫連接池
const pool = mysql.createPool({
host: "localhost",
port: 3306,
user: "root",
password: "123456",
database: "info",
connectionLimit: 20,
});
// 將數(shù)據(jù)庫連接池對象導(dǎo)出
module.exports = pool;創(chuàng)建test.js文件,使用連接池查詢數(shù)據(jù)庫,代碼如下:
const express = require("express"); // 導(dǎo)入express
const app = express(); // 創(chuàng)建實(shí)例
const pool = require("./mydb"); // 導(dǎo)入連接池
// http://localhost:3000/test
app.get("/test", ((req, res) => {
// 從連接池中獲取數(shù)據(jù)庫的連接對象
pool.getConnection(function (err, conn) {
if (err) {
console.log("數(shù)據(jù)庫連接失敗");
} else {
console.log("數(shù)據(jù)庫連接成功");
// 定義sql查詢語句
let sql = "select * from stu";
// 查詢操作
conn.query(sql, function (err, result) {
if (err) {
console.log("數(shù)據(jù)庫查詢失敗");
} else {
res.send(result);
conn.release();
}
})
}
})
}))
// 監(jiān)聽3000端口
app.listen(3000);啟動服務(wù)器,在瀏覽器中打開http://localhost:3000/test,會看到成功查詢到了表stu中的數(shù)據(jù)。

總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
NodeJS使用文件流解決大文件處理的內(nèi)存與時(shí)間效率問題
在 NodeJS 中,文件操作是常見的任務(wù)之一,然而,當(dāng)處理大文件時(shí),直接將整個(gè)文件加載到內(nèi)存中可能會導(dǎo)致內(nèi)存溢出或性能瓶頸,為了解決這一問題,NodeJS 提供了文件流(Stream)機(jī)制,本文將詳細(xì)介紹文件流的優(yōu)點(diǎn)、使用方法、應(yīng)用場景,并探討背壓(Backpressure)的概念2025-01-01
Mongoose經(jīng)常返回e11000 error的原因分析
這篇文章主要給大家分析了Mongoose經(jīng)常返回e11000 error的原因,文中介紹的非常詳細(xì),對大家具有一定的參考價(jià)值,需要的朋友可以們下面來一起看看吧。2017-03-03
node腳本實(shí)現(xiàn)自動化簽到和抽獎(jiǎng)功能
本文主要介紹了node腳本實(shí)現(xiàn)自動化簽到和抽獎(jiǎng)功能,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
node+express+ejs使用模版引擎做的一個(gè)示例demo
本篇文章主要介紹了node+express+ejs使用模版引擎做的一個(gè)示例demo,具有一定參考價(jià)值,有興趣的小伙伴可以了解一下2017-09-09

