背景
主从切换是高可用MySQL架构的必要步骤(即使用不发生,也要有备无患)。一般设置为双M(M1、M2),假设当前状态为写M1,而M2只读,切换的大致流程如下:
1、 停止应用写M1,将M1设置为只读
2、 检查M2的slave status直到赶上M1
3、 将M1设置为可写
其中在第2步细化为
a) 在M1上show master status;得到binlog位置P,因为已经设为只读,不会变化
b) 循环检测M2上的执行位置,若未到P,则过几秒再查。循环直到从库追上。
这里介绍一个函数用于简化步骤b.
函数master_pos_wait
语法 select master_pos_wait(file, pos[, timeout]).
这里的file和pos对应主库show master status得到的值,代表执行位置。 函数逻辑是等待当前从库达到这个位置后返回, 返回期间执行的事务个数。
参数timeout可选,若缺省则无限等待,timeout<=0时与缺省的逻辑相同。若为正数,则等待这么多秒,超时函数返回-1.
其他返回值:若当前slave为启动或在等待期间被终止,返回NULL; 若指定的值已经在之前达到,返回0
master_pos_wait的实现逻辑
用户调用该函数后,根据传入参数调用pthread_cond_timedwait或pthread_cond_wait。 SQL_THREAD线程每次apply完一个事件后会触发更新relay info, 并通知上面等待的线程。因为可能有多个用户等待,因此用广播方式。
关于事件个数的计算比较复杂,有兴趣的同学可以看这篇, 不过在本文讨论的这个问题上,正数返回值并不重要。
小结
用master_pos_wait来实现上面的步骤b,则可以简化为:
b’) 在M上执行select master_pos_wait(file, pos),返回后判断一下返回值>=0 则认为主从同步完成。
好处是
1) 简化逻辑,不用在应用脚本判断
2) 在追上的第一时间就能感知,否则可能多等若干秒
分享到:
相关推荐
change master to master_host='192.168.147.133', master_port=3306, master_user='root', master_password='root', master_log_file='mysql-bin.000003', master_log_pos=0; ``` ### 4. 启动同步进程 启动从...
`MASTER_LOG_FILE` 和 `MASTER_LOG_POS` 是从 Master 节点获取的日志文件名和位置信息。 - **检查 Slave 节点状态**:执行 `SHOW SLAVE STATUS\G` 命令查看 Slave 节点的状态,确认 `Slave_IO_Running` 和 `Slave_...
-> master_log_file='mysql-bin.0000010', -> master_log_pos=106; ``` 2.5、启动从服务器slave线程 启动从服务器slave线程,以便进行数据同步。 ```sql start slave; ``` 2.6、查看从服务器状态 在从服务器上,...
MASTER_LOG_POS=主库二进制日志偏移量; ``` - 替换 `主库IP`、`repl`、`password`、`主库二进制日志文件名` 和 `主库二进制日志偏移量` 为实际的值。 - 注意这里的 `MASTER_USER` 和 `MASTER_PASSWORD` 是指主库...
例如:`CHANGE MASTER TO MASTER_HOST='10.3.43.28', MASTER_USER='replication', MASTER_PASSWORD='123456', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=400;` - 启动从服务器的复制进程:`START SLAVE;...
- `MASTER_LOG_FILE`和`MASTER_LOG_POS`为在主服务器上通过`show master status;`命令得到的二进制日志文件名和位置。 3. **启动从机复制** - 输入命令`START SLAVE;` 4. **检查复制状态** - 输入命令`SHOW ...
CHANGE MASTER TO MASTER_HOST='192.168.1.203', MASTER_USER='root', MASTER_PASSWORD='newadmin', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=123; ``` 其中`MASTER_LOG_FILE`和`MASTER_LOG_POS`...
5. 登录 MySQL 服务器,执行以下命令:`CHANGE MASTER TO MASTER_HOST='X.X.X.X', MASTER_USER='user', MASTER_PASSWORD='password', MASTER_PORT=3306, MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=98, ...
在从库设置设置主库状态,配置文档里面有,保证统一,change master to master_host='127.0.0.1',master_port=3306,master_user='新建用户',master_password='密码',master_log_file='主库日志状态',master_log_pos=...
3. 创建mysql状态检测脚本:在目录root下创建脚本keepalived_check_mysql.sh,该脚本用于监控mysql的状态,一旦mysql不可用,keepalived就会自动切换到备用节点上。 keepalived.conf配置文件 keepalived.conf文件...
- `master_log_pos=137150238`:二进制日志中的位置,表示从哪里开始复制。 5. **启动复制**: 在从服务器上执行`START SLAVE;`命令,开始从主服务器拉取并应用变更。 6. **解锁表**: 如果在开始复制前对主...
CHANGE MASTER TO MASTER_HOST='192.168.1.10', MASTER_USER='root', MASTER_PASSWORD='mysqlmaster', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=107; START SLAVE; ``` 验证同步状态。 ```sql SHOW ...
MASTER_LOG_POS=261; ``` - **启动从服务器同步进程**: 使用以下命令启动从服务器的同步进程。 ```sql START SLAVE; ``` ##### 4. 检查主从同步状态 - 使用命令`SHOW SLAVE STATUS \G`来查看从服务器的同步...
### MySQL主从复制搭建知识点详解 #### 一、MySQL主从复制概述 MySQL主从复制是一种数据同步机制,它能够将一个MySQL服务器(主服务器)的数据自动同步到一个或多个MySQL服务器(从服务器)。这种机制不仅可以提高...
MASTER_LOG_POS=73; ``` - **启动 Slave 同步进程**:启动 Slave 的同步进程。 ```sql START SLAVE; ``` - **检查 Slave 状态**:确认 Slave 是否正常运行。 ```sql SHOW SLAVE STATUS \G; ``` #### 五、...