天天看點

golang 簡單的讀負責均衡read-loadbalance使用場景

read-loadbalance

master-slave(n) 讀庫叢集負載均衡器(簡單輪詢)+時間間隔錯峰。

github 位址:https://github.com/Plen-wang/read-loadbalance

使用場景

1.一般我們會有多個從庫,需要在從庫的讀取上做負載均衡。

2.在數倉拉取資料的時候經常對産線DB造成影響,是以會獨立一個從庫專門用來拉取,但是這個從庫的使用率非常低。

數倉拉取資料一般在業務低峰期進行,iops峰值較高,但是持續時間很短。我們可以錯開這個時間段,讓這台從庫的使用率最大化。

golang 簡單的讀負責均衡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")

}
           
作者:王清培(趣頭條 Tech Leader)