中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

read-loadbalance的使用場景

發布時間:2020-05-28 10:23:58 來源:億速云 閱讀:232 作者:Leah 欄目:編程語言

今天小編給大家分享的是read-loadbalance的使用場景介紹,相信大部分人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,話不多說,一起往下看吧。

read-loadbalance

master-slave(n) 讀庫集群負載均衡器(簡單輪詢)+時間間隔錯峰。
github 地址:https://github.com/Plen-wang/read-loadbalance

使用場景

1.一般我們會有多個從庫,需要在從庫的讀取上做負載均衡。  
2.在數倉拉取數據的時候經常對產線DB造成影響,所以會獨立一個從庫專門用來拉取,但是這個從庫的利用率非常低。
數倉拉取數據一般在業務低峰期進行,iops峰值較高,但是持續時間很短。我們可以錯開這個時間段,讓這臺從庫的利用率最大化。  
read-loadbalance的使用場景

package main

import (
    "database/sql"
    "fmt"
    _ "github.com/go-sql-driver/mysql"
    "github.com/gocraft/dbr"
    "github.com/read-loadbalance/lb"
    "log"
)

var slaveLB *lb.SlaveLoadBalancer

func main() {
    //構造數據源
    creator := func() *sql.DB {
        dsn := fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?charset=%s&autocommit=1", "root", 123456, "localhost", 3306, "test", "utf8mb4")
        conn, er := sql.Open("mysql", dsn)
        if er != nil {
            log.Fatalf("create db conn error:%v", er.Error())
        }
        return conn
    }

    slave1 := creator()
    slave2 := creator()

    //構造slave-lb
    slaveLB = lb.BuildSlaveLoadBalancer(1, 2, 1, slave1, slave2)

    //獲取數據源
    _, _, conn := slaveLB.GetPollingNode()

    //放入任意orm中,這里舉例dbr
    orm := &dbr.Connection{DB: conn}
    orm.NewSession(nil).SelectBySql("select id from tb_orders limit 1")

}

以上就是read-loadbalance的使用場景的詳細內容了,看完之后是否有所收獲呢?如果想了解更多相關內容,歡迎關注億速云行業資訊!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

微博| 阿拉善右旗| 南安市| 巴里| 兴隆县| 安徽省| 彩票| 浦城县| 怀仁县| 郧西县| 岢岚县| 望奎县| 梧州市| 南木林县| 保定市| 宁陵县| 韶山市| 阆中市| 堆龙德庆县| 宁武县| 托克逊县| 通州区| 延寿县| 白城市| 雷州市| 闸北区| 洪洞县| 德江县| 德安县| 恭城| 西峡县| 集贤县| 汉源县| 莆田市| 亚东县| 沂源县| 英超| 大冶市| 陇西县| 万全县| 扎赉特旗|