新聞中心
今天小編給大家分享的是read-loadbalance的使用場景介紹,相信大部分人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,話不多說,一起往下看吧。
成都創(chuàng)新互聯(lián)公司主營烈山網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,app軟件定制開發(fā),烈山h5微信小程序定制開發(fā)搭建,烈山網(wǎng)站營銷推廣歡迎烈山等地區(qū)企業(yè)咨詢
read-loadbalance
master-slave(n) 讀庫集群負載均衡器(簡單輪詢)+時間間隔錯峰。
github 地址:https://github.com/Plen-wang/read-loadbalance
使用場景
1.一般我們會有多個從庫,需要在從庫的讀取上做負載均衡。
2.在數(shù)倉拉取數(shù)據(jù)的時候經(jīng)常對產(chǎn)線DB造成影響,所以會獨立一個從庫專門用來拉取,但是這個從庫的利用率非常低。
數(shù)倉拉取數(shù)據(jù)一般在業(yè)務(wù)低峰期進行,iops峰值較高,但是持續(xù)時間很短。我們可以錯開這個時間段,讓這臺從庫的利用率最大化。
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() {
//構(gòu)造數(shù)據(jù)源
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()
//構(gòu)造slave-lb
slaveLB = lb.BuildSlaveLoadBalancer(1, 2, 1, slave1, slave2)
//獲取數(shù)據(jù)源
_, _, conn := slaveLB.GetPollingNode()
//放入任意orm中,這里舉例dbr
orm := &dbr.Connection{DB: conn}
orm.NewSession(nil).SelectBySql("select id from tb_orders limit 1")
}
以上就是read-loadbalance的使用場景的詳細內(nèi)容了,看完之后是否有所收獲呢?如果想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊!
文章標(biāo)題:read-loadbalance的使用場景
文章出自:http://fisionsoft.com.cn/article/pgscgh.html