本小节以MySQL->RDS for MySQL的实时同步为示例,介绍如何使用数据库复制服务创建两个数据库实例之间的实时同步任务,其他存储引擎的配置流程类似。
前提条件
- 已登录数据库复制服务控制台。
- 账户余额大于等于100元。
- 满足实时同步支持的数据库类型,详情请参见实时同步。
- 满足实时同步的使用限制,详情请参见概述。
操作步骤
1、 在“实时同步管理”页面,单击“创建同步任务”。
2、 在“同步实例”页面,填选区域、任务名称、任务异常通知设置、时延阈值、任务异常自动结束时间、描述、同步实例信息,单击“下一步”。
图 同步任务信息
表 任务与描述
参数
描述
任务名称
任务名称在4-50位之间,必须以字母开头,不区分大小写,可以包含字母、数字、中划线或下划线,不能包含其他的特殊字符。
任务异常通知设置
该项为可选参数,开启之后,需要填写手机号码或者邮箱作为指定收件人。当同步任务状态异常时,系统将发送通知给指定收件人。
说明收到确认短信或邮件之后,需要在48小时内处理,否则该订阅无效,将无法收到异常通知。
时延阈值
在增量同步阶段,源数据库和目标数据库之间的同步有时会存在一个时间差,称为时延,单位为秒。
时延阈值设置是指时延超过一定的值后(时延阈值范围为1—3600s),DRS可以发送告警通知给指定收件人。告警通知将在时延稳定超过设定的阈值6min后发送,避免出现由于时延波动反复发送告警通知的情况。
说明首次进入增量同步阶段,会有较多数据等待同步,存在较大的时延,属于正常情况,不在此功能的监控范围之内。
设置时延阈值之前,需要设置任务异常通知。
描述
描述不能超过256位,且不能包含! = < > & ' " \ 特殊字符。
图 同步实例信息
表 同步实例信息
参数
描述
数据流动方向
选择“入云”,即目标端数据库为本云数据库。
源数据库引擎
选择MySQL。
目标数据库引擎
选择MySQL。
网络类型
此处以公网网络为示例。
可根据业务场景选择公网网络、VPC网络和VPN、专线网络。
目标数据库实例
用户所创建的关系型数据库实例。
说明目标数据库实例不支持选择只读实例。
目标数据库实例可以和源数据库选择同一个实例。
同步类型
此处以“全量+增量”为示例。
“全量+增量”:
该模式为数据持续性实时同步,通过全量过程完成目标端数据库的初始化后,增量同步阶段通过解析日志等技术,将源端和目标端数据保持数据持续一致。
说明选择“全量+增量”同步模式,增量同步可以在全量同步完成的基础上实现数据的持续同步,无需中断业务,实现同步过程中源业务和数据库继续对外提供访问。
“增量”:
增量同步通过解析日志等技术,将源端产生的增量实时同步至目标端。
3、同步实例创建成功后,在“源库及目标库”页面,填选源库信息和目标库信息后,单击“源库和目标库”处的“测试连接”,分别测试并确定与源库和目标库连通后,勾选协议,单击“下一步”。
入云和出云场景中源库和目标库需要填选的信息不同,具体以界面为准。
入云场景:
图 源库信息
表 源库信息
参数
描述
IP地址或域名
源数据库的IP地址或域名。
端口
源数据库服务端口,可输入范围为1~65535间的整数。
数据库用户名
源数据库的用户名。
数据库密码
源数据库用户名所对应的密码。支持在任务创建后修改密码。
任务为启动中、全量同步、增量同步、增量同步失败状态时,可在“基本信息”页面的“同步信息”区域,单击“源库密码”后的“替换密码”,在弹出的对话框中修改密码。
SSL安全连接
通过该功能,用户可以选择是否开启对迁移链路的加密。如果开启该功能,需要用户上传SSL CA根证书。
说明最大支持上传500KB的证书文件。如果不使用SSL证书,请自行承担数据安全风险。
说明源数据库IP地址、端口、用户名和密码将在同步过程中被加密暂存到数据库和同步实例主机上,待该任务删除后会永久清除。
图 目标库信息
表 目标库信息
参数 | 描述 |
---|---|
数据库实例名称 | 默认为创建迁移任务时选择的关系型数据库实例,不可进行修改。 |
数据库用户名 | 目标数据库对应的用户名。 |
数据库密码 | 目标数据库用户名对应的密码。支持在任务创建后修改密码。任务为启动中、全量同步、增量同步、增量同步失败状态时,可在“基本信息”页面的“同步信息”区域,单击“目标库密码”后的“替换密码”,在弹出的对话框中修改密码。 |
说明目标数据库用户名和密码将在同步过程中被加密暂存到数据库和同步实例主机上,待该任务删除后会永久清除。
出云场景:
图 源库信息
表 源库信息
参数 | 描述 |
---|---|
数据库实例名称 | 默认为创建任务时选择的云数据库实例,不可进行修改。 |
数据库用户名 | 源数据库对应的用户名。 |
数据库密码 | 源数据库用户名对应的密码。任务为启动中、全量同步、增量同步、增量同步失败状态时,可在“基本信息”页面的“同步信息”区域,单击“源库密码”后的“替换密码”,在弹出的对话框中修改密码 |
说明源数据库的用户名和密码将在同步过程中被加密暂存到数据库和同步实例主机上,待该任务删除后会永久清除。
图 目标库信息
表 目标库信息
参数
描述
IP地址或域名
目标数据库的IP地址或域名。
端口
目标数据库服务端口,可输入范围为1~65535间的整数。
数据库用户名
目标数据库的用户名。
数据库密码
目标数据库的用户名所对应的密码。支持在任务创建后修改密码。
任务为启动中、全量同步、增量同步、增量同步失败状态时,可在“基本信息”页面的“同步信息”区域,单击“目标库密码”后的“替换密码”,在弹出的对话框中修改密码。
SSL安全连接
通过该功能,用户可以选择是否开启对迁移链路的加密。如果开启该功能,需要用户上传SSL CA根证书。
说明最大支持上传500KB的证书文件。
说明目标数据库的IP地址、端口、用户名和密码将在同步过程中被加密暂存到数据库和同步实例主机上,待该任务删除后会永久清除。
4、在“设置同步”页面,选择数据冲突策略和同步对象,单击“下一步”
图 同步模式
表 同步模式和对象
参数
描述
冲突策略
数据库复制服务提供的实时同步功能使用了主键或唯一键冲突策略,这些策略可以由您自主选择,尽可能保证源数据库中有主键约束或唯一键约束的表同步到目标数据库是符合预期的。
冲突策略目前支持如下三种形式:
忽略
当同步数据与目标数据库已有数据冲突时(主键/唯一键存在重复等),将跳过冲突数据,继续进行后续同步。
报错
当同步数据与目标数据库已有数据冲突时(主键/唯一键存在重复等),同步任务将失败并立即中止。
覆盖
当同步数据与目标数据库已有数据冲突时(主键/唯一键存在重复等),将覆盖原来的冲突数据。
说明目前仅MySQL->RDS for MySQL的同步场景支持设置“覆盖”冲突策略。
当数据发生冲突时,针对如下情况,建议选“忽略”或者“覆盖”,否则建议选“报错”:
目标数据库存在数据
多对一同步场景
目标数据库手动更新数据
是否过滤DROP DATABASE
实时同步过程中,源数据库端执行的DDL操作在一定程度上会影响数据的同步能力,为了降低同步数据的风险,数据库复制服务提供了过滤DDL操作的功能。
目前支持默认过滤删除数据库的操作。
是,表示实时同步过程中不会同步用户在源数据库端执行的删除数据库操作。
否,则表示实时同步过程中将相关操作同步到目标库。
说明目前仅以下链路的数据同步场景支持过滤DDL操作。
MySQL数据库->RDS for MySQL实例
RDS for MySQL实例->MySQL数据库
对象同步范围
对象同步范围支持普通索引和增量DDL同步。可根据业务需求选择是否进行同步。
同步对象
同步对象支持库级和表级同步,您可以根据业务场景选择对应的数据进行同步。部分链路还支持文件导入对象。
图 导入对象文件
如果有切换源数据库的操作或源库同步对象变化的情况,请务必在选择同步对象前单击右上角,以确保待选择的对象为最新源数据库对象。说明选择对象的时候支持搜索,以便您快速选择需要的数据库对象。
MySQL->RDS for MySQL实时同步支持表级和库级同步。
实时同步功能可以支持源数据库和目标数据库中的同步对象(包括数据库、schema、表)的名称不同。如果同步的数据库对象在源数据库和目标数据库中的命名不同,那么可以使用数据库复制服务提供的对象名映射功能进行映射。其中包括:库映射、schema映射、表映射。
对象名映射的具体操作请参考《数据库复制服务用户指南》中“对象名映射”章节。
导入对象文件的具体操作如下:
1. 单击“下载模板”。
2. 在下载的Excel模板中,填写需要导入的对象信息。
3. 单击“添加文件”,在对话框中选择编辑完成的模板。
4. 单击“上传文件”。
说明
文件导入仅支持导入Windows Microsoft Excel 97-2003版本(*.xls),2007及以上版本(*.xlsx)的文件,下载的压缩包提供上述两个版本模板
文件名支持的有效字符:大小写字母,数字,“-”,“_”,“(”,“)”
模板中的对象信息需按照SchemaName.TableName的格式进行填写,不支持“<”,“>”,"."和“"”,且不支持以空格开头或结尾的对象。
文件导入成功后,必须保留本次上传的文件,以便需要再编辑该任务的数据库对象范围时,可直接基于此文件修改,然后再次上传。
用文件导入功能所创建的任务,任务启动之后再编辑时,不支持切换到“表级同步”和“库级同步”功能。
配置中的任务,可使用“表级同步”,“库级同步”或“文件导入”三种方式,每次切换新的方式后,当前选择或者导入的数据库对象被清空,需重新选择或导入。
5、在“数据加工”页面,根据需要设置数据加工的过滤规则。
如果不需要设置数据加工规则,选择“不加工”,单击“下一步”。
如果需要设置数据加工规则,选择“数据过滤”,参考数据加工,设置相关过滤规则
数据加工
6、在“预检查”页面,进行同步任务预校验,校验是否可进行实时同步。
查看检查结果,如有不通过的检查项,需要修复不通过项后,单击“重新校验”按钮重新进行任务预校验。
预检查不通过项处理建议请参见《数据库复制服务用户指南》中的“预检查不通过项修复方法”。
预检查完成后,且所有检查项结果均通过时,单击“下一步”。
图 预检查
说明所有检查项结果均通过时,若存在请确认项,需要阅读并确认详情后才可以继续执行下一步操作。
7、在“任务确认”页面,设置同步任务的启动时间,并确认同步任务信息无误后,勾选协议,单击“启动任务”,提交同步任务。
说明同步任务的启动时间可以根据业务需求,设置为“立即启动”或“稍后启动”。
预计同步任务启动后,会对源数据库和目标数据库的性能产生影响,建议选择业务低峰期,合理设置同步任务的启动时间。
8、同步任务提交后,您可在“实时同步管理”页面,查看并管理自己的任务。
您可查看任务提交后的状态,状态请参见参考:任务状态含义。
在任务列表的右上角,单击刷新列表,可查看到最新的任务状态。