记一次mysql迁移至OceanBase操作记录

前言

mysqldump 是 MySQL 数据库系统中的一个命令行工具,用于创建 MySQL 数据库的逻辑备份。它能够导出数据库的结构和数据为 SQL 语句文件,这个文件可以用于恢复数据库或在其他服务器上重建数据库。

PS:本次迁移使用了最基本的mysqldump导出进行后续迁移操作。

源库导出前的配置及导出脚本

本次源数据版本:mysql 8.0.31

导出之前的操作---数据库设置参数:

复制代码
set persist default_collation_for_utf8mb4=utf8mb4_general_ci;

导出操作:

复制代码
/mysql/bin//mysqldump -h 192.168.40.129  -uroot -p'mysqlpasswd' -P3306 --single-transaction --master-data=2 --set-gtid-purged=OFF --hex-blob --default-character-set=utf8mb4  --databases shanjiadb > shanjiadb_to_ob.sql

--single-transaction:确保一致性导出。

--master-data=2:记录 binlog 位置,可用于后续搭建增量同步(如果需要)。

--set-gtid-purged=OFF:如果 MySQL 未开启 GTID,可忽略此选项。

处理导出后的SQL文件

检查 SQL 文件,可能需要手动修改一些 OceanBase不兼容的DDL或语法(例如,将LOCK语句注释掉).

如果前面没做字符集设置就导出了,可以用下列脚本批量替换:

复制代码
sed -i 's utf8mb3_general_ci utf8mb4_general_ci g' *.sql
sed -i 's utf8mb4_0900_ai_ci utf8mb4_general_ci g' *.sql
sed -i 'CHARSET=utf8mb3 CHARSET=utf8mb4' *.sql

目标OceanBase准备及导入操作

前面已经将前期准备做好了,接下来可以在目标端ob数据库进行后续操作了。

在备份的表结构语句里,可能包含外键。在导入 OceanBase MySQL 里时,如果外键依赖的表没有创建,导入脚本会报错,因此在导入之前需要禁用外键检查约束。

使用 source 命令或 mysql 客户端导入。

复制代码
mysql> use shanjiaobdb;

mysql> source /data/backup/shanjiadb_to_ob.sql;

导入大量数据时,建议先禁用外键检查以提高速度:

SET FOREIGN_KEY_CHECKS=0;

-- 导入操作

SET FOREIGN_KEY_CHECKS=1;

本次的迁移操作,因某方便原因,其他一些细节点,并没有放上去,姑且当个笔记记录吧。

文参考文档:

https://www.oceanbase.com/docs/common-oceanbase-database-standalone-1000000003577510

相关推荐
陌上丨9 小时前
Redis的Key和Value的设计原则有哪些?
数据库·redis·缓存
AI_56789 小时前
AWS EC2新手入门:6步带你从零启动实例
大数据·数据库·人工智能·机器学习·aws
ccecw9 小时前
Mysql ONLY_FULL_GROUP_BY模式详解、group by非查询字段报错
数据库·mysql
JH30739 小时前
达梦数据库与MySQL的核心差异解析:从特性到实践
数据库·mysql
数据知道9 小时前
PostgreSQL 核心原理:如何利用多核 CPU 加速大数据量扫描(并行查询)
数据库·postgresql
麦聪聊数据11 小时前
Web 原生架构如何重塑企业级数据库协作流?
数据库·sql·低代码·架构
未来之窗软件服务11 小时前
数据库优化提速(四)新加坡房产系统开发数据库表结构—仙盟创梦IDE
数据库·数据库优化·计算机软考
Goat恶霸詹姆斯12 小时前
mysql常用语句
数据库·mysql·oracle
大模型玩家七七12 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
曾经的三心草13 小时前
redis-9-哨兵
数据库·redis·bootstrap