一、前言
在構(gòu)建高并發(fā)的Web應(yīng)用時(shí),除了應(yīng)用層要采取負(fù)載均衡方案外,數(shù)據(jù)庫也要支持高可用和高并發(fā)性。使用較多的數(shù)據(jù)庫優(yōu)化方案是:通過主從復(fù)制(Master-Slave)的方式來同步數(shù)據(jù),再通過讀寫分離(MySQL-Proxy)來提升數(shù)據(jù)庫的并發(fā)負(fù)載能力。
1. replication選項(xiàng)與讀寫分離
Sequelize 支持讀/寫分離,要實(shí)現(xiàn)讀/寫分離可以分別為讀和寫各創(chuàng)建一個(gè)Sequelize實(shí)例,更方便的使用方式是在創(chuàng)建實(shí)例時(shí),通過replication選項(xiàng)分別指定讀/寫數(shù)據(jù)庫。
要在Sequelize中使用讀/寫復(fù)制,可以在初始化Sequelize時(shí)有時(shí)向其replication選項(xiàng)傳遞一個(gè)對象.這個(gè)對象read、write兩個(gè)屬性。write是一個(gè)單一的對象(即:由單臺(tái)服務(wù)器處理寫入),而read是一個(gè)包含對象的數(shù)組(即:由多臺(tái)服務(wù)器處理讀取)。每臺(tái)read、write服務(wù)器都可以包含以下屬性:
? host - 數(shù)據(jù)庫服務(wù)器的主機(jī)
? port - 數(shù)據(jù)庫服務(wù)器的主機(jī)端口
? username - 驗(yàn)證用戶名
? password - 驗(yàn)證密碼
? database - 要連接的數(shù)據(jù)庫
2. Sequelize讀/寫分離示例
在使用主從復(fù)制的多臺(tái)數(shù)據(jù)庫集群中,可以通過在replication對象的read屬性中設(shè)置,該屬性是一個(gè)數(shù)組,可以在其中傳入一個(gè)或多個(gè)服務(wù)器連接副本。讀操作相當(dāng)于對數(shù)據(jù)庫集群中的從節(jié)點(diǎn)進(jìn)行操作,它會(huì)處理所有SELECT查詢操作(讀操作)。而replication對象的write屬性是一個(gè)表示服務(wù)器連接的對象,寫操作相當(dāng)于主節(jié)點(diǎn),它會(huì)處理所有插入、更新、刪除操作(寫操作)。
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: { // 如果需要重寫鏈接池,請?jiān)?pool 選項(xiàng)中修改 maxConnections: 20, maxIdleTime: 30000 },})所有的整體性設(shè)置,都會(huì)適用于所有節(jié)點(diǎn)副本,所以并不需要為每個(gè)實(shí)例單獨(dú)指定。在上例中,數(shù)據(jù)庫名和端口號(hào)會(huì)應(yīng)用于所有節(jié)點(diǎn)副本,用戶名和密碼選項(xiàng)也同樣適用。如果某一節(jié)點(diǎn)副本不使用全局設(shè)置,則需要在replication選項(xiàng)中單獨(dú)指定。
注意:Sequelize 并不會(huì)設(shè)置主從復(fù)制節(jié)點(diǎn)及節(jié)點(diǎn)間的數(shù)據(jù)同步(復(fù)制),這些操作實(shí)際由MySQL(或你所使用的數(shù)據(jù)庫)完成。而 Sequelize 只負(fù)責(zé)從主從節(jié)點(diǎn)寫入或讀取數(shù)據(jù)。
Sequelize 會(huì)使用連接池來管理節(jié)點(diǎn)副本。
默認(rèn)選項(xiàng)是:
{ maxConnections: 10, minConnections: 0, maxIdleTime:1000}總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
新聞熱點(diǎn)
疑難解答
網(wǎng)友關(guān)注