从之前的介绍我们知道gdb
支持基于应用层的主从配置以及读写分离,并且所有的特性仅需要通过简单的配置即可实现,gdb
内部将会对SQL
请求自动地进行主从切换。以下是一个简单的主从配置,包含一主一从:
成都创新互联专业为企业提供月湖网站建设、月湖做网站、月湖网站设计、月湖网站制作等企业网站建设、网页设计与制作、月湖企业网站模板建站服务,10年月湖做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。
database:
default:
- type: "mysql"
link: "root:12345678@tcp(192.168.1.1:3306)/test"
role: "master"
- type: "mysql"
link: "root:12345678@tcp(192.168.1.2:3306)/test"
role: "slave"
在大部分的场景中,我们的写入请求是到Master
主节点,而读取请求是到Slave
从节点,这样的好处是能够对数据库的请求进行压力分摊,并提高数据库的可用性。但在某些场景中,我们期望读取操作在Master
节点上执行,特别是一些对于即时性要求比较高的场景(因为主从节点之间的数据同步是有延迟的)。
开发者可以通过Master
和Slave
方法自定义决定当前链式操作执行在哪个节点上。
我们来一个简单的示例。我们有一个订单系统,每天的流量比较大,因此数据库在主从同步时往往会存在1-500ms
时间的延迟。在业务需求中,创建订单后需要立即展示订单列表页面。可以预料到如果该订单列表页面默认往从节点读取数据的话,很有可能用户在创建订单后在订单列表页面看不到最新创建的订单(因为数据库主从同步延迟)。这个问题,我们可以在订单列表页面设置为往主节点读取数据即可解决。
db.Model("order").Data(g.Map{
"uid" : 1000,
"price" : 99.99,
// ...
}).Insert()
Master
方法指定查询操作是在主节点上进行,以避免读取延迟。 db.Model("order").Master().Where("uid", 1000).All()
标题名称:创新互联GoFrame教程:GoFrame链式操作-主从切换
分享路径:http://www.mswzjz.com/qtweb/news26/185976.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联