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)

编辑实时数据同步任务

执行

备注:

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

对源库性能影响较少

可以支持应用的无缝迁移

四 应用主导迁移

应用程序写代码

相关推荐
ClouGence9 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
葫芦和十三13 小时前
图解 MongoDB 25|分片架构三件套:mongos、config server 和 shard
后端·mongodb·agent
葫芦和十三19 小时前
图解 MongoDB 26|片键设计:决定集群命运的一个决定
后端·mongodb·agent
先吃饱再说1 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils1 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend1 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶1 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung1 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql
parade岁月1 天前
MySQL JOIN解析:朴实无华但食之有味
数据库·后端
用户3169353811831 天前
MySQL服务无法启动问题解决全记录
数据库