欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Node.js如何實現(xiàn)MySQL數(shù)據(jù)庫連接池

 更新時間:2024年11月25日 14:34:44   作者:橘貓吃不胖~  
文章介紹了Node.js中實現(xiàn)MySQL數(shù)據(jù)庫連接池的方法,通過預(yù)先建立和管理數(shù)據(jù)庫連接對象,優(yōu)化數(shù)據(jù)庫連接的使用效率

什么是數(shù)據(jù)庫連接池

數(shù)據(jù)庫連接池是程序啟動時建立足夠數(shù)量的數(shù)據(jù)庫連接對象,并將這些連接對象組成一個池,由程序動態(tài)地對池中的連接對象進行申請、使用和釋放。

原理及優(yōu)點

數(shù)據(jù)庫連接池在初始化時將會創(chuàng)建一定數(shù)量的數(shù)據(jù)庫連接對象放到連接池中,連接池都將一直保證至少擁有這么多的連接數(shù)量,當有數(shù)據(jù)庫需要被連接的時候,它會向數(shù)據(jù)庫連接池申請資源和使用,使用完成后會釋放到數(shù)據(jù)庫連接池中。當然數(shù)據(jù)庫連接池中擁有最小連接數(shù)量和最大連接數(shù)量,當數(shù)據(jù)庫的連接超過連接池中最大的數(shù)量的時候,這些請求將被加入到等待隊列中。

用服裝店招聘導(dǎo)購來說明數(shù)據(jù)庫連接池。當只有顧客A時,服裝店招聘一個導(dǎo)購A,如果之后顧客B、C、D、E、F…也來了,那么就需要不斷招聘導(dǎo)購B、C、D、E、F…,這樣會帶來大量的人力成本。

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

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

數(shù)據(jù)庫的鏈接池也是這個意思,當網(wǎng)站某一天有很大的流量的時候,數(shù)據(jù)庫服務(wù)器需要為每次鏈接創(chuàng)建一次數(shù)據(jù)庫鏈接。

這樣就很浪費數(shù)據(jù)庫的資源,并且頻繁的創(chuàng)建和關(guān)閉數(shù)據(jù)庫的鏈接,很容易導(dǎo)致服務(wù)器內(nèi)存溢出等情況發(fā)生。

連接池的作用

數(shù)據(jù)庫的連接池負責分配、管理和釋放數(shù)據(jù)庫連接對象的。

它允許應(yīng)用程序重復(fù)使用一個現(xiàn)有的數(shù)據(jù)庫的連接對象。而不是重新創(chuàng)建一個。

實現(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ù),默認是10",
    queueLimit: "指定允許掛起的最大連接數(shù),如果掛起的連接數(shù)超過該數(shù)值,就會立刻拋出錯誤,默認屬性值為0,代表不允許被掛起的最大連接數(shù)",
    multipleStatements: "是否運行執(zhí)行多條sql語句,默認值為false"
})

示例:創(chuàng)建數(shù)據(jù)庫連接池

const mysql = require("mysql");
const pool = mysql.createPool({
    host: "127.0.0.1", // 主機地址
    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.從連接池中獲取一個連接

語法:

pool.getConnection(function (err, connection) {
    // 代碼
});
  • err:該參數(shù)是指操作失敗時的錯誤對象。
  • connection:該值為一個對象,代表獲取到的連接對象。當連接失敗時,該值為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)建實例
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é)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Express的HTTP重定向到HTTPS的方法

    Express的HTTP重定向到HTTPS的方法

    本篇文章主要介紹了Express的HTTP重定向到HTTPS的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • 在Node.js應(yīng)用中使用Redis的方法簡介

    在Node.js應(yīng)用中使用Redis的方法簡介

    這篇文章主要介紹了在Node.js應(yīng)用中使用Redis的方法,最簡單的數(shù)據(jù)讀寫操作相關(guān),需要的朋友可以參考下
    2015-06-06
  • node實現(xiàn)分片下載的示例代碼

    node實現(xiàn)分片下載的示例代碼

    這篇文章主要介紹了node實現(xiàn)分片下載的示例代碼,使用場景包括基于瀏覽器的流文件片段傳輸、基于客戶端的分片下載等。感興趣的小伙伴們可以參考一下
    2018-10-10
  • NodeJS使用文件流解決大文件處理的內(nèi)存與時間效率問題

    NodeJS使用文件流解決大文件處理的內(nèi)存與時間效率問題

    在 NodeJS 中,文件操作是常見的任務(wù)之一,然而,當處理大文件時,直接將整個文件加載到內(nèi)存中可能會導(dǎo)致內(nèi)存溢出或性能瓶頸,為了解決這一問題,NodeJS 提供了文件流(Stream)機制,本文將詳細介紹文件流的優(yōu)點、使用方法、應(yīng)用場景,并探討背壓(Backpressure)的概念
    2025-01-01
  • node.js適合游戲后臺開發(fā)嗎?

    node.js適合游戲后臺開發(fā)嗎?

    這篇文章主要介紹了node.js適合游戲后臺開發(fā)嗎?node.js是不是能代替C++開發(fā)游戲后臺呢?看完本文我想你會有一定的了解了,需要的朋友可以參考下
    2014-09-09
  • Mongoose經(jīng)常返回e11000 error的原因分析

    Mongoose經(jīng)常返回e11000 error的原因分析

    這篇文章主要給大家分析了Mongoose經(jīng)常返回e11000 error的原因,文中介紹的非常詳細,對大家具有一定的參考價值,需要的朋友可以們下面來一起看看吧。
    2017-03-03
  • koa2實現(xiàn)登錄注冊功能的示例代碼

    koa2實現(xiàn)登錄注冊功能的示例代碼

    這篇文章主要介紹了koa2實現(xiàn)登錄注冊功能的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • node腳本實現(xiàn)自動化簽到和抽獎功能

    node腳本實現(xiàn)自動化簽到和抽獎功能

    本文主要介紹了node腳本實現(xiàn)自動化簽到和抽獎功能,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • node+express+ejs使用模版引擎做的一個示例demo

    node+express+ejs使用模版引擎做的一個示例demo

    本篇文章主要介紹了node+express+ejs使用模版引擎做的一個示例demo,具有一定參考價值,有興趣的小伙伴可以了解一下
    2017-09-09
  • npm install -g 遇到權(quán)限問題解析

    npm install -g 遇到權(quán)限問題解析

    這篇文章主要為大家介紹了npm install -g 遇到權(quán)限問題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06

最新評論