MySQL集群读写分离的自定义实现
作者: / 2019-08-07 / 浏览次数:

这里用过服务器的一个优先级,将写请求指向最高优先级的master服务器,读请求随机指向非最高优先级的slave,
对于更新请求,都在master上执行,slave复制了master的数据,每次读到的数据都不一样,并且每次都请求的执行,基本上都随机地指向了两台slave服务器
通过查询返回一个端口号,来判断读请求是否平均分散到了不通的slave端。



与 my凯发agsql router拿来当玩具玩玩就好 相比,这里的实现一样low,因为对数据的请求需要请求明确指定是读还是写。

不过,对于自动读写分离,无非是一个sql语句执行的是的读或写判断问题,并非难事,这个需要解析请求的sql是读的还是写的问题。
某些数据库中间件可以实现自动的读写分离,但是要明白,对于那些支持自动读写分离的中间件,往往是要受到一定的约束的,比如不能用存储过程什么的,为什么呢?
还是上面提到的sql解析的问题,因为一旦使用了存储过程,无法解析出来这个sql到底是执行的是读还是写,最起码不是太直接。
对于sql读写的判断,也就是维护一个读或者写的枚举正则表达式,非读即写,只是要格外关注这个读写的判断的效率问题。




 

【某某业务】网站建设、网站设计、服务器空间租售、网站维护、网站托管、网站优化、百度推广、自媒体营销、微信公众号
如有意向---联系我们
热门栏目
热门资讯

网站建设 网站托管 成功案例 新闻动态 关于我们 联系我们 服务器空间 加盟合作 网站优化

备案号: 

公司地址:江苏省南京市玄武区玄武湖 咨询QQ:9490489 手机: 电话: