MySQL 8.0.17推出了一个重量级的功能:clone plugin。允许用户将当前实例进行本地或者远程的clone。这在某些场景,尤其是快速搭建复制备份或者在group replication里加入新成员时非常有用。
示例
本地clone
(*左右滑动阅览)
CLONE LOCAL DATA DIRECTORY [=] 'clone_dir';
root@test 03:49:43>SELECT STAGE, STATE, END_TIME FROM performance_schema.clone_progress;
+-----------+-------------+----------------------------+
| STAGE | STATE | END_TIME |
+-----------+-------------+----------------------------+
| DROP DATA | Completed | 2019-07-26 12:07:12.285611 |
| FILE COPY | Completed | 2019-07-26 12:07:18.270998 |
| PAGE COPY | Completed | 2019-07-26 12:07:18.472560 |
| REDO COPY | Completed | 2019-07-26 12:07:18.673061 |
| FILE SYNC | Completed | 2019-07-26 12:07:32.090219 |
| RESTART | Not Started | NULL |
| RECOVERY | Not Started | NULL |
+-----------+-------------+----------------------------+
7 rows in set (0.00 sec)
需要BACKUP_ADMIN权限
远程clone:
CLONE INSTANCE FROM USER@HOST:PORT
IDENTIFIED BY 'password'
[DATA DIRECTORY [=] 'clone_dir']
[REQUIRE [NO] SSL];
clone_valid_donor_list ='example.donor.host.com:3306';
mysql> CLONE INSTANCE FROM
clone_user@example.donor.host.com:3306
IDENTIFIED BY 'password';
mysql> CLONE INSTANCE FROM
user_name@example.donor.host.com:3306
IDENTIFIED BY 'password'
DATA DIRECTORY = '/path/to/clone_dir';
🔸需要指定绝对路径,并且路径目录必须不存在
🔸必须有相同的字符集设置
官方文档列出的一些限制:
主要流程
主要流程包含如下几个过程:
[INIT] ---> [FILE COPY] ---> [PAGE COPY] ---> [REDO COPY] -> [Done]
INIT阶段
需要持有backup lock, 阻止ddl进行
FILE COPY
按照文件进行拷贝,同时开启page tracking功能,记录在拷贝过程中修改的page, 此时会设置buf_pool->track_page_lsn为当前lsn,track_page_lsn在flush page阶段用到:
(*左右滑动阅览)
buf_flush_page:
if (!fsp_is_system_temporary(bpage->id.space()) &&
buf_pool->track_page_lsn != LSN_MAX) {
page_t *frame;
lsn_t frame_lsn;
frame = bpage->zip.data;
if (!frame) {
frame = ((buf_block_t *)bpage)->frame;
}
frame_lsn = mach_read_from_8(frame + FIL_PAGE_LSN); //对于在track_page_lsn之后的page, 如果frame_Lsn大于track_page_lsn, 表示已经记录下page id了,无需重复记录
arch_page_sys->track_page(bpage, buf_pool->track_page_lsn, frame_lsn,
false); // 将page id记录下来,表示在track_page_lsn后修改过的page
}
会创建一个后套线程page_archiver_thread(),将内存记录的page id flush到disk上
PAGE COPY
这里有两个动作:
🔻开启redo archiving功能,从当前点开始存储新增的redo log,这样从当前点开始所有的增量修改都不会丢失
🔻同时上一步在page track的page被发送到目标端。确保当前点之前所做的变更一定发送到目标端
关于redo archiving,实际上这是官方早就存在的功能,主要用于官方的企业级备份工具,但这里clone利用了该特性来维持增量修改产生的redo。
(notify_about_advanced_write_lsn)也会通知他去archive。
Redo Copy
停止Redo Archiving", 所有归档的日志被发送到目标端,这些日志包含了从page copy阶段开始到现在的所有日志,另外可能还需要记下当前的复制点,例如最后一个事务提交时的binlog位点或者gtid信息,在系统页中可以找到
Done
目标端重启实例,通过crash recovery将redo log应用上去。
参考文档
▪️官方博客:Clone: Create MySQL instance replica:https://mysqlserverteam.com/clone-create-mysql-instance-replica/
▪️The Clone Plugin:https://dev.mysql.com/doc/refman/8.0/en/clone-plugin.html
▪️WL#9209: InnoDB: Clone local replica:https://dev.mysql.com/worklog/task/?id=9209
▪️WL#9210: InnoDB: Clone remote replica:https://dev.mysql.com/worklog/task/?id=9210
▪️WL#9682: InnoDB: Support cloning encrypted and compressed database:https://dev.mysql.com/worklog/task/?id=9682
▪️WL#9211: InnoDB: Clone Replication Coordinates:https://dev.mysql.com/worklog/task/?id=9211
▪️WL#11636: InnoDB: Clone Remote provisioning:https://dev.mysql.com/worklog/task/?id=11636
阿里巴巴数据库技术
微信:alibabadba
分享数据库前沿
解构实战干货
长按二维码关注