Golang 簡單的讀負責均衡


read-loadbalance

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

使用場景

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

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)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM