日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
創(chuàng)新互聯(lián)GoFrame教程:GoFrame鏈?zhǔn)讲僮?主從切換

從之前的介紹我們知道?gdb?支持基于應(yīng)用層的主從配置以及讀寫分離,并且所有的特性僅需要通過簡單的配置即可實(shí)現(xiàn),?gdb?內(nèi)部將會(huì)對?SQL?請求自動(dòng)地進(jìn)行主從切換。以下是一個(gè)簡單的主從配置,包含一主一從:

成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供月湖網(wǎng)站建設(shè)、月湖做網(wǎng)站、月湖網(wǎng)站設(shè)計(jì)、月湖網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)與制作、月湖企業(yè)網(wǎng)站模板建站服務(wù),10年月湖做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

database:
  default:
  - type: "mysql"
    link: "root:12345678@tcp(192.168.1.1:3306)/test"
    role: "master"
  - type: "mysql"
    link: "root:12345678@tcp(192.168.1.2:3306)/test"
    role: "slave"

在大部分的場景中,我們的寫入請求是到?Master?主節(jié)點(diǎn),而讀取請求是到?Slave?從節(jié)點(diǎn),這樣的好處是能夠?qū)?shù)據(jù)庫的請求進(jìn)行壓力分?jǐn)?,并提高?shù)據(jù)庫的可用性。但在某些場景中,我們期望讀取操作在?Master?節(jié)點(diǎn)上執(zhí)行,特別是一些對于即時(shí)性要求比較高的場景(因?yàn)橹鲝墓?jié)點(diǎn)之間的數(shù)據(jù)同步是有延遲的)。

開發(fā)者可以通過?Master?和?Slave?方法自定義決定當(dāng)前鏈?zhǔn)讲僮鲌?zhí)行在哪個(gè)節(jié)點(diǎn)上。

我們來一個(gè)簡單的示例。我們有一個(gè)訂單系統(tǒng),每天的流量比較大,因此數(shù)據(jù)庫在主從同步時(shí)往往會(huì)存在?1-500ms?時(shí)間的延遲。在業(yè)務(wù)需求中,創(chuàng)建訂單后需要立即展示訂單列表頁面。可以預(yù)料到如果該訂單列表頁面默認(rèn)往從節(jié)點(diǎn)讀取數(shù)據(jù)的話,很有可能用戶在創(chuàng)建訂單后在訂單列表頁面看不到最新創(chuàng)建的訂單(因?yàn)閿?shù)據(jù)庫主從同步延遲)。這個(gè)問題,我們可以在訂單列表頁面設(shè)置為往主節(jié)點(diǎn)讀取數(shù)據(jù)即可解決。

  • 在訂單創(chuàng)建的時(shí)候,沒有必要指定操作的節(jié)點(diǎn),因?yàn)閷懭氩僮髂J(rèn)是在主節(jié)點(diǎn)上執(zhí)行的。為簡化示例,我們這里僅展示關(guān)鍵的代碼:
 db.Model("order").Data(g.Map{
     "uid"   : 1000,
     "price" : 99.99,
     // ...
 }).Insert()

  • 在訂單列表頁面查詢時(shí),我們需要使用?Master?方法指定查詢操作是在主節(jié)點(diǎn)上進(jìn)行,以避免讀取延遲。
 db.Model("order").Master().Where("uid", 1000).All()

本文名稱:創(chuàng)新互聯(lián)GoFrame教程:GoFrame鏈?zhǔn)讲僮?主從切換
文章網(wǎng)址:http://www.dlmjj.cn/article/dpdosos.html