Node.js Sequelize如何實現(xiàn)數(shù)據(jù)庫的讀寫分離
一、前言
在構(gòu)建高并發(fā)的Web應用時,除了應用層要采取負載均衡方案外,數(shù)據(jù)庫也要支持高可用和高并發(fā)性。使用較多的數(shù)據(jù)庫優(yōu)化方案是:通過主從復制(Master-Slave)的方式來同步數(shù)據(jù),再通過讀寫分離(MySQL-Proxy)來提升數(shù)據(jù)庫的并發(fā)負載能力。
1. replication選項與讀寫分離
Sequelize 支持讀/寫分離,要實現(xiàn)讀/寫分離可以分別為讀和寫各創(chuàng)建一個Sequelize實例,更方便的使用方式是在創(chuàng)建實例時,通過replication選項分別指定讀/寫數(shù)據(jù)庫。
要在Sequelize中使用讀/寫復制,可以在初始化Sequelize時有時向其replication選項傳遞一個對象.這個對象read、write兩個屬性。write是一個單一的對象(即:由單臺服務器處理寫入),而read是一個包含對象的數(shù)組(即:由多臺服務器處理讀取)。每臺read、write服務器都可以包含以下屬性:
· host - 數(shù)據(jù)庫服務器的主機
· port - 數(shù)據(jù)庫服務器的主機端口
· username - 驗證用戶名
· password - 驗證密碼
· database - 要連接的數(shù)據(jù)庫
2. Sequelize讀/寫分離示例
在使用主從復制的多臺數(shù)據(jù)庫集群中,可以通過在replication對象的read屬性中設置,該屬性是一個數(shù)組,可以在其中傳入一個或多個服務器連接副本。讀操作相當于對數(shù)據(jù)庫集群中的從節(jié)點進行操作,它會處理所有SELECT查詢操作(讀操作)。而replication對象的write屬性是一個表示服務器連接的對象,寫操作相當于主節(jié)點,它會處理所有插入、更新、刪除操作(寫操作)。
var sequelize = new Sequelize('database', null, null, {
dialect: 'mysql',
port: 3306
replication: {
read: [
{ host: '192.168.1.33', username: 'itbilu.com', password: 'pwd' },
{ host: 'localhost', username: 'root', password: null }
],
write: { host: 'localhost', username: 'root', password: null }
},
pool: { // 如果需要重寫鏈接池,請在 pool 選項中修改
maxConnections: 20,
maxIdleTime: 30000
},
})
所有的整體性設置,都會適用于所有節(jié)點副本,所以并不需要為每個實例單獨指定。在上例中,數(shù)據(jù)庫名和端口號會應用于所有節(jié)點副本,用戶名和密碼選項也同樣適用。如果某一節(jié)點副本不使用全局設置,則需要在replication選項中單獨指定。
注意:Sequelize 并不會設置主從復制節(jié)點及節(jié)點間的數(shù)據(jù)同步(復制),這些操作實際由MySQL(或你所使用的數(shù)據(jù)庫)完成。而 Sequelize 只負責從主從節(jié)點寫入或讀取數(shù)據(jù)。
Sequelize 會使用連接池來管理節(jié)點副本。
默認選項是:
{
maxConnections: 10,
minConnections: 0,
maxIdleTime:1000
}
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關文章
Node.js使用MongoDB的ObjectId作為查詢條件的方法
這篇文章主要介紹了Node.js使用MongoDB的ObjectId作為查詢條件的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-09-09
基于Node.js + WebSocket打造即時聊天程序嗨聊
這篇文章主要介紹了基于Node.js + WebSocket打造即時聊天程序,有興趣的可以了解一下。2016-11-11
詳解如何使用Node.js連接數(shù)據(jù)庫ORM
這篇文章主要為大家介紹了詳解如何使用Node.js連接數(shù)據(jù)庫ORM示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12
node.js中的buffer.Buffer.isBuffer方法使用說明
這篇文章主要介紹了node.js中的buffer.Buffer.isBuffer方法使用說明,本文介紹了buffer.Buffer.isBuffer的方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下2014-12-12
Node.js包管理器代理工具Verdaccio輕松創(chuàng)建管理本地npm包倉庫
這篇文章主要為大家介紹了Node.js包管理器代理工具Verdaccio輕松創(chuàng)建管理本地npm包倉庫的使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10

