创建实时迁移任务
实时迁移是指在数据复制服务能够同时连通源数据库和目标数据库的情况下,只需要配置迁移的源、目标数据库实例及迁移对象即可完成整个数据迁移过程,再通过多项指标和数据的对比分析,帮助确定合适的业务割接时机,实现最小化业务中断的数据库迁移。
本文以本地MySQL迁移到云上RDS for MySQL为例,帮助您使用DRS实时迁移功能,通过创建公网网络类型的全量+增量迁移任务,快速完成迁移上云。更多实时迁移场景的使用指导请参考迁移方案概览。
操作视频
操作流程
操作步骤 |
说明 |
---|---|
注册华为账号并开通华为云,实名认证,准备待迁移数据库、数据库连接账号、网络等。 |
|
选择源和目标数据库,创建并启动迁移任务。 |
|
迁移过程中,可以通过查看迁移进度了解数据迁移完成情况。 |
|
使用DRS提供的对比功能,来确认源和目标数据库的数据是否一致性。 |
|
确定数据一致后,切换业务,结束DRS任务。 |
准备华为账号,创建用户并赋权使用DRS。
- 打开华为云网站。
- 单击“注册”,根据提示信息完成注册。
- 勾选服务条款, 单击“开通”。
系统提示开通成功。
- 实名认证,请参考:
- 注册华为云账号后,如果需要对华为云上的资源进行精细管理,请使用统一身份认证服务(Identity and Access Management,简称IAM)创建IAM用户及用户组,并授权,以使得IAM用户获得具体的操作权限,更多操作,请参见创建用户组、用户并授予DRS权限。
在进行实时迁移前,用户需要提前准备好源和目标数据库。
- 源数据库:为用户本地自建的MySQL数据库,可参考如下信息进行准备:
类别
示例
备注
数据库版本
MySQL 5.7
-
IP地址
10.154.217.42
仅作为示例。
端口
3306
-
- 目标数据库:为云上的RDS for MySQL数据库,用户可参考RDS for MySQL快速入门内容准备如下信息:
类别
示例
备注
区域
华北-北京四
选择和自己业务区最近的Region,减少网络时延。
RDS实例名称
rds-mysql
自定义,易理解可识别。
数据库版本
MySQL 5.7
-
实例类型
单机
本示例中为单机。
实际使用时,为提升业务可靠性,推荐选择主备RDS实例。
存储类型
SSD云盘
-
可用区
可用区一
本示例中为可用区一。
实际业务场景推荐选择主备RDS实例,此时建议将两个实例创建在不同的可用区,提升业务可靠性。
性能规格
通用型 2 vCPUs | 8GB
-
为了保证迁移任务顺利进行,在使用DRS进行迁移前,建议单独创建用于DRS任务连接的数据库账号进行迁移,并需要满足一定的权限要求,才能启动实时迁移任务。
- 源数据库连接账号:
- 目标数据库连接账号:
- 通过DAS连接RDS for MySQL实例。
- 参考通过DAS创建账号章节,执行以下语句,创建用于连接的数据库用户usertar:
CREATE USER 'usertar'@'%' IDENTIFIED BY 'password';
- 执行以下语句,授予数据库用户usertar权限:
GRANT SELECT, CREATE, ALTER, DROP, DELETE, INSERT, UPDATE, INDEX, EVENT, CREATE VIEW, CREATE ROUTINE, TRIGGER ON *.* TO 'usertar' WITH GRANT OPTION;
步骤一:创建迁移任务
本步骤是针对准备工作中所举示例进行参数设置及介绍,如果需要了解更多实时迁移的使用指导,请参考迁移方案概览。
- 进入创建DRS迁移任务页面。
- 填写基本信息。
图1 基本信息
参数
示例
参数说明
区域
华北-北京四
当前任务所在的区域。
项目
华北-北京四
当前区域下可以选择的项目。
任务名称
DRS-Migration
迁移任务的名称。
描述
暂不填写
任务描述。
- 填写迁移实例信息。
图2 迁移实例信息
参数
示例
参数说明
数据流动方向
入云
创建任务的数据流动方向,以华为云数据库为中心进行选择,分为入云和出云。
- 入云:指目标数据库为华为云数据库实例且需将数据传入的场景。
- 出云:指源数据库为华为云数据库实例且需将数据传出的场景。
源数据库引擎
MySQL
源数据库的引擎类型。
目标数据库引擎
MySQL
目标数据库的引擎类型。
网络类型
公网网络
DRS任务进行数据迁移的网络类型。
- VPC网络:适合云上同账号同Region同VPC场景下数据库之间的迁移。
- 公网网络:适合通过公网网络把其他云下或其他平台的数据库迁移到目标数据库。
- VPN、专线网络:适合VPN、专线、CC、VPCEP、或者用户已打通VPC对等连接的网络场景,实现其他云下自建数据库与云上数据库迁移、或云上跨Region的数据库之间的迁移。
目标数据库实例
rds-mysql
选择目标数据库实例。
目标数据库实例名称为数据库准备中的rds-mysql。
迁移实例所在子网
默认的子网
迁移任务所在的子网。
迁移模式
全量+增量
DRS的实时迁移任务模式,分为全量、全量+增量两种模式。
- 全量:该模式为数据库一次性迁移,适用于可中断业务的数据库迁移场景。如果用户只进行全量迁移时,建议停止对源数据库的操作,否则迁移过程中源数据库产生的新数据不会同步到目标数据库。
- 全量+增量:该模式为数据库持续性迁移,适用于对业务中断敏感的场景。
目标库实例读写设置
只读
迁移过程中,将目标数据库实例设置为“只读”或者“读写”状态。
- 只读:迁移中,目标数据库整个实例将转化为只读、不可写入的状态,迁移任务结束后恢复可读写状态,此选项可有效的确保数据迁移的完整性和成功率,推荐此选项。
- 读写:迁移中,目标数据库可以读写。
是否开启Binlog快速清理
否
DRS任务运行期间,是否开启目标数据库实例的Binlog快速清理。
指定公网IP
-
选择DRS实例的公网IP,网络准备中创建的公网IP
- 选择可用区和企业项目。
图3 选择可用区和企业项目
参数
示例
参数说明
可用区
可用区1
选择DRS任务创建的可用区。
企业项目
default
对于已成功关联企业项目的用户,仅需在“企业项目”下拉框中选择目标项目。
更多关于企业项目的信息,请参见《企业管理用户指南》。
标签
暂不添加
对DRS任务的标识。使用标签可方便管理您的任务。
- 单击“开始创建”。
等待5~10分钟后,页面显示“迁移实例创建成功”表示DRS任务已创建成功。
- 在“测试连接”页面,分别测试DRS实例与源库和目标库的连通性。
- 在“迁移设置”页面,设置迁移模式和迁移对象后,单击“下一步”。
图4 迁移模式
参数
示例
参数说明
流速模式
不限速
选择是否对DRS迁移任务限速,默认为不限速。限速模式只对全量阶段生效,增量阶段不生效。
迁移增量账号及权限
否
选择数据库迁移过程中,是否迁移增量账号。
迁移用户
否
选择是否迁移源数据库中的用户。
过滤DROP DATABASE
否
为了降低迁移数据的风险,DRS提供了过滤删除数据库操作的功能。
迁移对象
全部迁移
选择迁移对象,可根据用户用户需求选择全部对象迁移、表级迁移或者库级迁移。
- 在“预检查”页面,进行迁移任务预校验,校验是否可进行迁移。
- 如果存在待确认项,需要阅读并确认详情后才可以继续执行。
- 如果有不通过的检查项,可参考表中内容修复不通过项后,单击“重新校验”按钮重新进行迁移任务预校验。
预检查通过率为100%时表示预检查通过。
- 单击“下一步”。
- 在“参数对比”页面,进行常规参数和性能参数的对比和修改。
- 如果用户选择不进行参数对比,或者源库和目标库参数对比一致,可跳过该步骤。
- 如果源库和目标库参数对比不一致,用户可选择手动修改目标数据库参数,或者单击“一键对齐”按钮系统将帮您自动填充目标数据库的参数。
- 单击“下一步”。
- 在“任务确认”页面,设置迁移任务的启动时间。
图5 任务启动设置
参数
示例
参数说明
启动时间
立即启动
迁移任务的启动时间可以根据业务需求,设置为“立即启动”或“稍后启动”,优选“稍后启动”。
任务异常通知设置
关闭
该项为可选参数,开启之后,选择对应的SMN主题。当入云迁移任务即将开始计费或者迁移任务状态、时延指标、数据等异常时,系统将发送通知。
任务异常自动结束时间
14
设置任务异常自动结束天数。设置任务异常自动结束天数后,异常且超时的任务将会自动结束。
- 确认迁移任务信息无误后,单击“启动任务”,提交迁移任务。
- 迁移任务提交后,您可在“实时迁移管理”页面,查看任务状态。
- 任务状态为“启动中”时,表示任务已正常启动。
- 对于未启动、状态为配置中的任务,DRS默认保留3天,超过3天DRS会自动删除后台资源,当前任务状态不变。当用户再次配置时,DRS会重新申请资源。
步骤三:对比迁移项
对于全量+增量迁移任务,当任务全量迁移完成进入增量阶段,并且增量时延为0时,用户可使用数据迁移提供的对比功能,确认源和目标数据库的数据是否一致性。
- 对象级对比:对数据库、索引、表、视图、存储过程和函数、表的排序规则等对象进行对比。
- 数据级对比:对迁移的表的行数或者表内数据进行一致性检查。
通过对象对比,可以对数据库对象完整性进行检查。
- 在“实时迁移管理”界面,选中指定迁移任务,单击任务名称。
进入“基本信息”页签。
- 单击“迁移对比”页签。
进入“迁移对比”信息页面。
- 单击“对象级对比”。
进入“对象级对比”页签。
- 单击“开始对比”。
- 等待5~10分钟,单击,查看各个对比项的对比结果。
当“对比结果”为“一致”时,表示该对象100%迁移完成。图8 对象级对比
数据库对象检查完成后,通过数据级对比,对迁移数据的详细行数或者内容进行对比检查。
- 在“实时迁移管理”界面,选中指定迁移任务,单击任务名称。
进入“基本信息”页签。
- 单击“迁移对比”页签。
进入“迁移对比”信息页面。
- 单击迁移对比须知处的“全面检查”。
进入“创建对比任务”页面。
- 选择对比策略,单击“是”,提交对比任务。
图9 创建对比任务
参数
示例
参数说明
对比类型
行对比
分为行数对比和内容对比。
- 行对比:对比迁移的表的行数是否一致。
- 内容对比:对比迁移的表内数据是否一致。
对比时间
立即启动
设置对比任务启动时间,可设置为“立即启动”和“稍后启动”。
进行数据过滤
关闭
选择是否设置对象比对的过滤条件。开启后,可根据配置的过滤条件进行对象比对。
对象选择
全部
可根据具体的业务场景选择需要进行对比的对象。
- 对比任务提交成功后,返回“数据级对比”页签。
- 单击刷新列表,等待对比任务完成后,可以查看对比结果。
当“对比结果”为“一致”时,表示该对象在源库和目标库数据一致。图10 行对比结果