OneProxy自动剔除延迟节点
在多种情况下,MySQL主从节点之间可能存在延迟。比如,主库的写入能力强于从库的写入能力、从库单线程复制、从库复制出错导致相关进程停止。为了保证数据的时效性,OneProxy提供了复制时效性检查,用于自动剔除延迟节点。
OneProxy提供两种时效性检查方式
A)运行show slave status\G,获得Seconds_Behind_Master值,即为延迟大小。
该方法好处是直接使用了MySQL自身提供的功能,只需查询从节点即可知道延迟。缺点在于该值在某些情况下不准确。
B) 针对第一个方法的缺点,Percona公司提供了pt-heart-beat,可以准确的检测主从延迟。OneProxy吸收了pt-heart-beat的设计原理。
假设主(192.168.15.128:3319)
从1(192.168.15.128:3318)
从2(192.168.15.128:3316)
针对A)方案,在proxy.conf中增加如下配置项,其中用户名和密码的设置请参考http://www.cnblogs.com/youge-OneSQL/p/4579881.html
[oneproxy]
keepalive = 1
event-threads = 4
log-file = log/oneproxy.log
pid-file = log/oneproxy.pid
lck-file = log/oneproxy.lck
mysql-version = 5.7.12
proxy-address = :3307
proxy-master-addresses.1 = 192.168.15.128:3319@server1
proxy-slave-addresses.2 = 192.168.15.128:3318@server1
proxy-slave-addresses.3 = 192.168.15.128:3316@server1
proxy-user-list = test/1378F6CC3A8E8A43CA388193FBED5405982FBBD3@test
proxy-charset = gbk_chinese_ci
proxy-group-policy = server1:read-slave
proxy-secure-client = 127.0.0.1
proxy-sequence.1 = default
proxy-httpserver =:8080
repadmin-username =test
repadmin-password =1378F6CC3A8E8A43CA388193FBED5405982FBBD3
proxy-group-slavedelay=server1:2
proxy-license = 9244B81320619F1C
针对B)方案,即是在A方案的基础上增加proxy-replication-check = 1
keepalive = 1
event-threads = 4
log-file = log/oneproxy.log
pid-file = log/oneproxy.pid
lck-file = log/oneproxy.lck
mysql-version = 5.7.12
proxy-address = :3307
proxy-master-addresses.1 = 192.168.15.128:3319@server1
#如果是两个master的话,比如双机房可以把下面的注释去掉
#proxy-master-addresses.2 = 192.168.15.128:3320@server1
proxy-slave-addresses.2 = 192.168.15.128:3318@server1
proxy-slave-addresses.3 = 192.168.15.128:3316@server1
proxy-user-list = test/1378F6CC3A8E8A43CA388193FBED5405982FBBD3@test
proxy-charset = gbk_chinese_ci
proxy-group-policy = server1:read-slave
proxy-secure-client = 127.0.0.1
proxy-sequence.1 = default
proxy-httpserver =:8080
repadmin-username =test
repadmin-password =1378F6CC3A8E8A43CA388193FBED5405982FBBD3
proxy-group-slavedelay=server1:2
proxy-license = 9244B81320619F1C
proxy-replication-check = 1
该方案会在默认的数据库test中创建一个表oneproxy_replication_check
select * from oneproxy_replication_check;
+----+------------+
| id | col2 |
+----+------------+
| 1 | 1475049446 |
+----+------------+
1 row in set (0.00 sec)
通过比较主从节点间的时间戳大小,即可计算出延迟。
OneProxy自动剔除延迟节点的更多相关文章
- Redis 哨兵节点之间相互自动发现机制(自动重写哨兵节点的配置文件)
Redis的哨兵机制中,如果是多哨兵模式,哨兵节点之间也是可以相互感知的,各种搜索之后出来的是千篇一律的一个基础配置文件,在配置当前哨兵节点的配置文件中,并没有配置其他哨兵节点的任何信息.如下是一个哨 ...
- linux驱动开发(四) 字符设备驱动框架(自动创建设备节点)
代码如下 #include <linux/init.h> #include <linux/module.h> #include <linux/kernel.h> # ...
- I.MX6 linux eGalaxTouch 自动获取设备节点
I.MX6 linux eGalaxTouch 自动获取设备节点 \\\\\\\\\\\\\\-*- 目录 -*-///////////// | 一. 需求: | 二. /proc/bus/input ...
- platform型设备在/dev目录下自动创建设备节点的分析【转】
转自:http://blog.csdn.net/rockrockwu/article/details/7357648 系统启动过程中platform设备.驱动注册完毕,为什么在/dev目录下就自动创建 ...
- ceph脚本-自动部署计算机节点
依然还在加班中,最近确实忙的脚打后脑勺! 又花了些时间丰富ceph脚本,可以连带着自动部署计算机节点了. 这一部分内容是后加的.可以关注我的公众号获取更多的项目代码和讲解!波神与你同行哦,加油!!!
- easyui Tree模拟级联勾选cascadeCheck,节点选择,父节点自动选中,节点取消,父节点自动取消选择,节点选择,所有子节点全部选择,节点取消,所有子节点全部取消勾选
最近项目中用到easyui tree,发现tree控件的cascadeCheck有些坑,不像miniui 的tree控件,级联勾选符合业务需求,所以就自己重新改写了onCheck事件,符合业务需求.网 ...
- Spring Cloud Config 自动刷新所有节点
全局刷新 详细参考:<Sprin Cloud 与 Docker 微服务架构实战>p160-9.9.2节 1.使用Spring Cloud Config 客户端时,可以使用 /refresh ...
- cassandra集群缩容与剔除问题节点
今天在操作cassandra集群数据迁移时发生了一些意料之外的事情,服务器迁移前与迁移后同样为5台,但是不知道是什么原因导致的,迁移过后的节点居然多出了一台cassandra节点,个人瞬间感觉莫名其妙 ...
- [Elixir002]节点启动后自动连接其它节点
问题: 如何指定一个节点在启动后自动连接到别的节点上? 这个我们要使用到sys.config,这是erlang的配置文件,这个文件一般都是$ROOT/releases/Vsn下 1. 首先我们要先启动 ...
随机推荐
- WebIM 聊天 Demo
最近 2 个月用业余时间写了一个 IM ,动手之前想了很多,包括前期设计.语言.数据库等,经过了一番思想斗争,最终前台用 Vue.js 展示,Server 使用 node ,数据库使用 MongoDB ...
- Struts2相关面试题
Struts2面试题 1.struts2工作流程 Struts 2框架本身大致可以分为3个部分: 核心控制器FilterDispatcher.业务控制器Action和用户实现的企业业务逻辑组件. 核心 ...
- iis7 64位 操作excel的一系列问题(未完待续)
查了半天发现是IIS跑在64位环境下引起的.而64位下,是木有Access数据库的驱动的(包括Excel也不行). 解决办法是:在目标网站的应用程序池中选择高级设置,然后将启用32位应用程序设置为tr ...
- linux环境下学习使用pro*c/c++工具
1.proc是oracle用来预编译嵌入SQL语句的c程序. 2.如何使用proc工具 在Linux环境下,首先确保gcc编译器正常使用,安装oracle数据库或者客户端,一般就会默认安装pro*c/ ...
- iOS 收起键盘的几种方式
iOS 收起键盘的几种方式 1.一般的view上收起键盘 // 手势 - (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event{ ...
- jQuery属性操作
jQuery 的属性操作的核心部分其实就是对底层 getAttribute().setAttributes()等方法的一系列兼容性处理 ...if ( notxml ) { name = name.t ...
- Volley全方位解析,带你从源码的角度彻底理解
Volley 是 Google 推出的轻量级 Android 异步网络请求框架和图片加载框架.在 Google I/O 2013 大会上发布.其适用场景是数据量小,通信频繁的网络操作. 主要特点: ( ...
- File相关的读取和写入以及复制
import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.File;import java.io.FileI ...
- bootstrop框架
bootstrop基本的基础了解有如上图.. 下载源码 从GitHub可以直接下载到Bootstrap最新版本的LESS和JavaScript源码. Clone or fork via GitHub ...
- [转]vb socket通信(TCP/UDP)一对一、多对一
VB Socket编程(Winsock控件创建TCP/IP客户机/服务器程序) Winsock控件建立在TCP.UDP协议的基础上,完成与远程计算机的通信.即使对TCP/IP不太熟悉的用户,使用 ...