tencent cloud

文档反馈

警告项检查

最后更新时间:2024-07-08 19:43:33

    MySQL/TDSQL-C/MariaDB/Percona/TDSQL MySQL 检查详情

    如下参数需要按照要求配置,否则校验时系统会发出警告,警告不影响迁移任务的进行,但是会对业务造成一定的影响,请用户评估后自行决定是否修改。
    建议目标库 max_allowed_packet 的取值大于源库。
    业务影响:目标库的 max_allowed_packet 参数设置小于源库,会导致目标库数据无法写入,从而造成全量迁移失败。
    处理建议:修改目标库的 max_allowed_packet 参数,大于源库取值。
    建议目标库的 max_allowed_packet 设置大于1GB。
    业务影响:max_allowed_packet 设置太大,会使用更多内存导致丢包,无法捕捉异常大事物包SQL;设置太小,可能会导致程序报错,备份失败,也会导致频繁的收发网络报,影响系统性能。
    处理建议:参考如下命令修改 max_allowed_packet 参数。
    set global max_allowed_packet = 1GB
    建议源库和目标库的字符集保持一致。
    业务影响:源库和目标库的字符集不一致可能会导致乱码。
    处理建议:参考如下命令将源库和目标库字符集修改为一致。
    set character_set_server = 'utf8';
    建议使用2CPU,4G Mem以上规格的实例。
    如果仅执行全量数据迁移,请勿在迁移过程中向源实例中写入新的数据,否则会导致源和目标数据不一致。针对有数据写入的场景,为实时保持数据一致性,建议选择全量+增量数据迁移。
    有锁导出时:源实例需要使用 Flush Table With Read Lock 短暂加锁,其中的 MyISAM 表会锁定到全量数据导出完成。当前等待加锁超时时间设置为60秒, 该时间内无法获取锁将导致任务失败。
    无锁导出时:仅对没有主键的表会加读锁,其他不加锁。
    对于既没有主键、也没有非空唯一键的表,有数据重复的风险,建议用户对迁移的表设置主键,或者非空唯一键。
    对于 TDSQL MySQL 的数据迁移,当源数据库实例为分布式数据库时,需要提前在目标库建立分表,否则这些表被迁移后都将是单表。
    目标库为 MySQL/MariaDB/Percona/TDSQL-C MySQL/TDSQL TDStore 时,需要检查源库和目标库 explicit_defaults_for_timestamp 的设置。源库为 OFF,或者源和目标都为 ON 时,任务警告,提醒用户任务运行期间不要随便修改该参数。
    在全量导出库表结构时检查表的 COLUMN_DEFAULTIS_NULLABLE 属性,如果源库表的 COLUMN_DEFAULTNULL, IS_NULLABLE 为 NOT NULL,则该表结构不进行迁移/同步,避免数据同步到目标库后,可能被 MySQL 系统自动添加为 DEFAULT TIMESTAMP 的表。
    
    
    联系我们

    联系我们,为您的业务提供专属服务。

    技术支持

    如果你想寻求进一步的帮助,通过工单与我们进行联络。我们提供7x24的工单服务。

    7x24 电话支持