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

Node.js Sequelize如何實(shí)現(xiàn)數(shù)據(jù)庫(kù)的讀寫(xiě)分離

 更新時(shí)間:2016年10月23日 17:13:24   投稿:daisy  
Sequelize是一個(gè)易于使用,支持多SQL方言(dialect)的對(duì)象-關(guān)系映射框架(ORM),這個(gè)庫(kù)完全采用JavaScript開(kāi)發(fā)并且能夠用在Node.JS環(huán)境中。它當(dāng)前支持MySQL, MariaDB, SQLite 和 PostgreSQL 數(shù)據(jù)庫(kù)。在Node.js中,使用 Sequelize操作數(shù)據(jù)庫(kù)時(shí),同樣支持讀寫(xiě)分離。

一、前言

在構(gòu)建高并發(fā)的Web應(yīng)用時(shí),除了應(yīng)用層要采取負(fù)載均衡方案外,數(shù)據(jù)庫(kù)也要支持高可用和高并發(fā)性。使用較多的數(shù)據(jù)庫(kù)優(yōu)化方案是:通過(guò)主從復(fù)制(Master-Slave)的方式來(lái)同步數(shù)據(jù),再通過(guò)讀寫(xiě)分離(MySQL-Proxy)來(lái)提升數(shù)據(jù)庫(kù)的并發(fā)負(fù)載能力。

1. replication選項(xiàng)與讀寫(xiě)分離

Sequelize 支持讀/寫(xiě)分離,要實(shí)現(xiàn)讀/寫(xiě)分離可以分別為讀和寫(xiě)各創(chuàng)建一個(gè)Sequelize實(shí)例,更方便的使用方式是在創(chuàng)建實(shí)例時(shí),通過(guò)replication選項(xiàng)分別指定讀/寫(xiě)數(shù)據(jù)庫(kù)。

要在Sequelize中使用讀/寫(xiě)復(fù)制,可以在初始化Sequelize時(shí)有時(shí)向其replication選項(xiàng)傳遞一個(gè)對(duì)象.這個(gè)對(duì)象read、write兩個(gè)屬性。write是一個(gè)單一的對(duì)象(即:由單臺(tái)服務(wù)器處理寫(xiě)入),而read是一個(gè)包含對(duì)象的數(shù)組(即:由多臺(tái)服務(wù)器處理讀取)。每臺(tái)read、write服務(wù)器都可以包含以下屬性:

     · host - 數(shù)據(jù)庫(kù)服務(wù)器的主機(jī)

     · port - 數(shù)據(jù)庫(kù)服務(wù)器的主機(jī)端口

     · username - 驗(yàn)證用戶(hù)名

     · password - 驗(yàn)證密碼

     · database - 要連接的數(shù)據(jù)庫(kù)

2. Sequelize讀/寫(xiě)分離示例

在使用主從復(fù)制的多臺(tái)數(shù)據(jù)庫(kù)集群中,可以通過(guò)在replication對(duì)象的read屬性中設(shè)置,該屬性是一個(gè)數(shù)組,可以在其中傳入一個(gè)或多個(gè)服務(wù)器連接副本。讀操作相當(dāng)于對(duì)數(shù)據(jù)庫(kù)集群中的從節(jié)點(diǎn)進(jìn)行操作,它會(huì)處理所有SELECT查詢(xún)操作(讀操作)。而replication對(duì)象的write屬性是一個(gè)表示服務(wù)器連接的對(duì)象,寫(xiě)操作相當(dāng)于主節(jié)點(diǎn),它會(huì)處理所有插入、更新、刪除操作(寫(xiě)操作)。

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: { // 如果需要重寫(xiě)鏈接池,請(qǐng)?jiān)?pool 選項(xiàng)中修改
  maxConnections: 20,
  maxIdleTime: 30000
 },
})

所有的整體性設(shè)置,都會(huì)適用于所有節(jié)點(diǎn)副本,所以并不需要為每個(gè)實(shí)例單獨(dú)指定。在上例中,數(shù)據(jù)庫(kù)名和端口號(hào)會(huì)應(yīng)用于所有節(jié)點(diǎn)副本,用戶(hù)名和密碼選項(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ù)庫(kù))完成。而 Sequelize 只負(fù)責(zé)從主從節(jié)點(diǎn)寫(xiě)入或讀取數(shù)據(jù)。

Sequelize 會(huì)使用連接池來(lái)管理節(jié)點(diǎn)副本。

默認(rèn)選項(xiàng)是:

{
 maxConnections: 10,
 minConnections: 0,
 maxIdleTime:1000
}

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。

相關(guān)文章

  • Node.js使用MongoDB的ObjectId作為查詢(xún)條件的方法

    Node.js使用MongoDB的ObjectId作為查詢(xún)條件的方法

    這篇文章主要介紹了Node.js使用MongoDB的ObjectId作為查詢(xún)條件的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • 阿里云OSS實(shí)踐文件直傳基于服務(wù)端

    阿里云OSS實(shí)踐文件直傳基于服務(wù)端

    這篇文章主要為大家介紹了阿里云OSS實(shí)踐文件直傳基于服務(wù)端實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • 基于Node.js + WebSocket打造即時(shí)聊天程序嗨聊

    基于Node.js + WebSocket打造即時(shí)聊天程序嗨聊

    這篇文章主要介紹了基于Node.js + WebSocket打造即時(shí)聊天程序,有興趣的可以了解一下。
    2016-11-11
  • 詳解如何使用Node.js連接數(shù)據(jù)庫(kù)ORM

    詳解如何使用Node.js連接數(shù)據(jù)庫(kù)ORM

    這篇文章主要為大家介紹了詳解如何使用Node.js連接數(shù)據(jù)庫(kù)ORM示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • node.js中的buffer.Buffer.isBuffer方法使用說(shuō)明

    node.js中的buffer.Buffer.isBuffer方法使用說(shuō)明

    這篇文章主要介紹了node.js中的buffer.Buffer.isBuffer方法使用說(shuō)明,本文介紹了buffer.Buffer.isBuffer的方法說(shuō)明、語(yǔ)法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • nodejs開(kāi)發(fā)——express路由與中間件

    nodejs開(kāi)發(fā)——express路由與中間件

    本篇文章主要介紹了nodejs開(kāi)發(fā)——express路由與中間件 ,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-03-03
  • 搭建一個(gè)Koa后端項(xiàng)目腳手架的方法步驟

    搭建一個(gè)Koa后端項(xiàng)目腳手架的方法步驟

    這篇文章主要介紹了搭建一個(gè)Koa后端項(xiàng)目腳手架的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • Node.js包管理器代理工具Verdaccio輕松創(chuàng)建管理本地npm包倉(cāng)庫(kù)

    Node.js包管理器代理工具Verdaccio輕松創(chuàng)建管理本地npm包倉(cāng)庫(kù)

    這篇文章主要為大家介紹了Node.js包管理器代理工具Verdaccio輕松創(chuàng)建管理本地npm包倉(cāng)庫(kù)的使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • NodeJs安裝npm包一直失敗的解決方法

    NodeJs安裝npm包一直失敗的解決方法

    本篇文章主要介紹了NodeJs安裝npm包一直失敗的解決方法。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧
    2017-04-04
  • package.json版本號(hào)符號(hào)^和~前綴的區(qū)別

    package.json版本號(hào)符號(hào)^和~前綴的區(qū)別

    這篇文章介紹了package.json版本號(hào)符號(hào)^和~前綴的區(qū)別,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06

最新評(píng)論