msyql迁移到mongodb

关系型数据库迁移到mongodb的理由

高并发需求,关系型数据库不容易扩展

快速迭代

灵活的json模式

大数据量需求

应用迁移难度:

关系型到关系

oracle-》mysql oracle -》 postgresql

关系到文档-

oracle -》 mongodb

需要考虑:

总体架构(单体到分布式)

模式设计(关系模式到文档模型)

SQL语句/储存过程/JDBC/ORM

数据迁移(如何处理已有数据?)

模式设计:

针对已有关系模型,考虑如何用文档模型进行设计

方法一:使用mongexport

一次性导入,需要停机

1.数据库导出

mysql添加参数secure-file-priv=/tmp #/tmp为导出的目录

方法一:

mysqldump导出:

-T 参数用于指定导出结果的目录和表文件名前缀,会导出txt格式的数据

mysqldump -uroot -p123456 test -T /tmp/

cat /tmp/testlog.txt

select导出:

select * from test.testlog into outfile '/tmp/testlog.csv';

导出后添加,号 sed -i.bak 's/\t/,/g' testlog.txt

2.导入

mongoexport导入

方法一

bash 复制代码
 --headerline -第一行做为mongodb中的列,要编辑testlog.txt添加列
 mongoimport  -d test -c testlog --headerline --type=csv /tmp/testlog.txt
2023-11-30T00:46:52.430+0800	connected to: mongodb://localhost/
2023-11-30T00:46:52.756+0800	29757 document(s) imported successfully. 0 document(s) failed to import.

方法二

-f指定列(就是mongodb中的列)导入

mongoimport -d test -c testlog -f id,name,salary --type=csv /tmp/testlog.txt

mongodb查看文档信息正常

test> use test

already on db test

test> db.testlog.find()

db.dropDatabase() 删除当前数据库

方法二:批量同步

安装同步工具(如kettle/Talend)

创建输入源(关系型数据库)

创建输入源(mongodb)

编辑数据同步任务

执行

备注:

适用3变量同步,定期更新,特别是每晚跑批

支持基于时间戳的增量同步,需要源表有合适的时间戳支持

对源库有明显的性能影响,不宜频繁查询

不支持实时同步

三 实时同步

安装实时同步工具(如informatica/Tapdata)

创建输入

创建输入源(关系型数据库)

创建输入源(mongodb)

编辑实时数据同步任务

执行

备注:

基于源库的日志文件解析进制,可以实现秒级数据同步

对源库性能影响较少

可以支持应用的无缝迁移

四 应用主导迁移

应用程序写代码

相关推荐
数据智能老司机10 小时前
CockroachDB权威指南——CockroachDB SQL
数据库·分布式·架构
数据智能老司机10 小时前
CockroachDB权威指南——开始使用
数据库·分布式·架构
松果猿10 小时前
空间数据库学习(二)—— PostgreSQL数据库的备份转储和导入恢复
数据库
无名之逆11 小时前
Rust 开发提效神器:lombok-macros 宏库
服务器·开发语言·前端·数据库·后端·python·rust
s91236010111 小时前
rust 同时处理多个异步任务
java·数据库·rust
数据智能老司机11 小时前
CockroachDB权威指南——CockroachDB 架构
数据库·分布式·架构
hzulwy11 小时前
Redis常用的数据结构及其使用场景
数据库·redis
程序猿熊跃晖11 小时前
解决 MyBatis-Plus 中 `update.setProcInsId(null)` 不生效的问题
数据库·tomcat·mybatis
Three~stone13 小时前
MySQL学习集--DDL
数据库·sql·学习
Qi妙代码13 小时前
MYSQL基础
数据库·mysql·oracle