dbswitch:一款免费开源、功能强大的异构数据库迁移同步工具

dbswitch 是一款免费开源、功能强大的异构数据库迁移同步工具,能够提供源端数据库向目的端数据库的离线批量迁移同步功能,支持数据的全量、增量、变化量方式同步。

dbswitch 项目由开源组织 Dromara 进行维护,主要基于 Java 和 Javascript 开发,遵循 BSD 开源协议,代码托管在 Gitee:

https://gitee.com/dromara/dbswitch

功能特性

  • 跨平台:支持 Linux、Windows、macOS 以及 Docker 等部署。
  • 数据源:包括 MySQL、MariaDB、Oracle、SQL Server、PostgreSQL、达梦、金仓、瀚高、神州通用、南大通用、openGuass、Db2、Dybase、Apache Hive、SQLite、Greenplum、Clickhouse、Starrocks、Doris 、Oceanbase、Mongodb、Elasticsearch,同时支持自定义扩展数据源。
  • Web 操作界面:提供了一个基于 Web 浏览器的管理界面,用户可以方便地进行数据源配置、任务管理和监控调度。
  • 命令操作方式:对于习惯命令行操作的用户,可以通过编辑配置文件直接执行迁移任务,适合迁移表或字段等数量较多的情况。

  • 数据查询:提供表结构查看功能以及一个在线的 SQL 查询页面。

  • 结构迁移:自动将源数据库的表结构(包括字段类型、主键信息等)转换为目标数据库所支持的格式,并且生成相应的 SQL 建表语句;支持基于正则表达式的表名和字段名映射转换,方便在迁移过程中进行规范化处理。
  • 数据同步:基于 JDBC 分批次读取源端数据,并且通过 INSERT 或 COPY 等高效方式将数据批量写入目标数据库。
  • 增量同步:支持对有主键标识的表进行增量数据同步,可以捕获并同步数据的插入、更新和删除操作。
  • 变化量同步:支持有主键表的变化量同步(基于变化数据计算 CDC)功能。注意:千万级以上数据量的性能尚需在生产环境验证。
  • 审计日志:提供用户登录和各种操作的日志记录。
  • 集成开发:支持用户在自己的项目中集成 dbswitch,进行二次开发。

下载安装

多种安装方式,使用 Docker 进行部署的命令如下:

复制代码
docker run -d --name dbswitch  -e DBTYPE=h2  -v /tmp:/tmp  -p 9088:9088 \
  registry.cn-hangzhou.aliyuncs.com/inrgihc/dbswitch:2.0.0

以上命令使用 H2 作为配置库,也可以使用 MySQL 或者 PostgreSQL 作为配置库进行部署。

启动服务之后,通过以下地址访问 Web 管理界面:

http://localhost:9088

初始用户名和密码分别为 admin/123456。

总结

dbswitch 是一款由社区驱动、功能全面的异构数据库迁移同步工具。强大的多数据库支持能力和提供 Web 界面与命令行两种操作模式的特点,使得它可以用于数据搬迁、数据库升级、数据湖仓构建等场景。

相关推荐
ldmd28419 小时前
Go语言实战:入门篇-4:与数据库、redis、消息队列、API
数据库·redis·缓存
是Dream呀19 小时前
工业级时序数据库选型指南:技术架构与场景化实践
数据库·架构·时序数据库
骑士99911119 小时前
时序数据库TDengine用法
数据库·时序数据库·tdengine
Pluchon19 小时前
硅基计划5.0 MySQL 叁 E-R关系图&联合/多表查询&三大连接&子查询&合并查询
开发语言·数据库·学习·mysql
Gold Steps.19 小时前
MySQL 8+ 日志管理与数据备份恢复实战指南
数据库·mysql·数据安全
程序员鱼皮19 小时前
老弟第一次学 Redis,被坑惨了!小白可懂的保姆级 Redis 教程
数据库·redis·程序员
oak隔壁找我20 小时前
Druid 数据库连接池源码详细解析
java·数据库·后端
不剪发的Tony老师20 小时前
Yearning:一个免费开源的SQL审核平台
数据库·sql·mysql
Gauss松鼠会20 小时前
GaussDB慢sql信息收集和执行计划查看
数据库·sql·gaussdb