分享
  1. 首页
  2. 文章

Golang 简单的读负责均衡

王清培 · · 2748 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

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)


有疑问加站长微信联系(非本文作者)

本文来自:51CTO博客

感谢作者:王清培

查看原文:Golang 简单的读负责均衡

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
2748 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏