热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

数据库无缝迁移方案设计

本篇来聊一聊数据库无缝迁移的方案,为什么要聊数据库无缝迁移方案呢?因为在企业的发展过程中,随着数据

本篇来聊一聊数据库无缝迁移的方案,为什么要聊数据库无缝迁移方案呢?因为在企业的发展过程中,随着数据量的增长,我们肯定会遇到需要迁移数据的场景。比如,单机型数据库到NoSQL,然后在到NewSQL,当我们的系统已经上线了,我们不可能停机来迁移数据,所以数据库无缝迁移方案值得好好说一说。

数据类型

我们存储在数据库中的数据大致可以分为两类:

  • 时效性数据
  • 永久性数据

什么是时效性数据?例如,饿了么的优惠券,滴滴出行的免费骑车券。对应的永久性数据就是一些日常数据,例如,订单信息,用户信息等等。


时效性数据迁移

时效性数据的迁移方案比较简单,直接双写就可以了。我们以滴滴出行的7天免费骑车券为例:

假设我们的数据要从MySQL迁移到MongoDB,那么我们直接双写MySQL和MongoDB即可,写多久呢?时效性多久我们就写多久。双写完成后,原数据库中的数据就已经过期了,我们直接干掉,然后读写新数据库就行了。示意图如下:

时效性数据的迁移相对比较简单。接下来我们看看永久性数据的迁移,毕竟这一块数据是大头。


永久性数据迁移

永久性数据的迁移稍微复杂点,我们需要引进一个中间存储(消息队列)。示意图如下:

首先我们把从库摘下来,然后将从库中的数据导入到MongoDB,同时数据双写到MySQL和消息队列。从库中的数据导入完成后,停止写入到MySQL,然后把消息队列中数据写入到MongoDB。示意图如下:

当将消息队列中的数据同步完成后就可以直接读写MongoDB了。


好的,那么关于数据库数据无缝迁移方案就讨论到这里。



推荐阅读
  • Redis:缓存与内存数据库详解
    本文介绍了数据库的基本分类,重点探讨了关系型与非关系型数据库的区别,并详细解析了Redis作为非关系型数据库的特点、工作模式、优点及持久化机制。 ... [详细]
  • 本文探讨了MariaDB在当前数据库市场中的地位和挑战,分析其可能面临的困境,并提出了对未来发展的几点看法。 ... [详细]
  • 在CentOS 7环境中安装配置Redis及使用Redis Desktop Manager连接时的注意事项与技巧
    在 CentOS 7 环境中安装和配置 Redis 时,需要注意一些关键步骤和最佳实践。本文详细介绍了从安装 Redis 到配置其基本参数的全过程,并提供了使用 Redis Desktop Manager 连接 Redis 服务器的技巧和注意事项。此外,还探讨了如何优化性能和确保数据安全,帮助用户在生产环境中高效地管理和使用 Redis。 ... [详细]
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文介绍了数据库体系的基础知识,涵盖关系型数据库(如MySQL)和非关系型数据库(如MongoDB)的基本操作及高级功能。通过三个阶段的学习路径——基础、优化和部署,帮助读者全面掌握数据库的使用和管理。 ... [详细]
  • 迎接云数据库新时代:程序员如何应对变革?
    在数据无处不在的时代,数据库成为了管理和处理数据的核心工具。从早期的信息记录方式到现代的云数据库,数据库技术经历了巨大的变革。本文将探讨云数据库的特点及其对程序员的影响。 ... [详细]
  • 构建高性能Feed流系统的设计指南
    随着移动互联网的发展,Feed流系统成为了众多社交应用的核心组成部分。本文将深入探讨如何设计一个高效、稳定的Feed流系统,涵盖从基础架构到高级特性的各个方面。 ... [详细]
  • MongoDB核心概念详解
    本文介绍了NoSQL数据库的概念及其应用场景,重点解析了MongoDB的基本特性、数据结构以及常用操作。MongoDB是一个高性能、高可用且易于扩展的文档数据库系统。 ... [详细]
  • 本文旨在探讨机器学习与数据分析之间的差异,不仅在于它们处理的数据类型,还包括技术背景、业务应用场景以及参与者的不同。通过深入分析,希望能为读者提供清晰的理解。 ... [详细]
  • 本文深入探讨了分布式文件系统的核心概念及其在现代数据存储解决方案中的应用,特别是针对大规模数据处理的需求。文章不仅介绍了多种流行的分布式文件系统和NoSQL数据库,还提供了选择合适系统的指导原则。 ... [详细]
  • 时序数据是指按时间顺序排列的数据集。通过时间轴上的数据点连接,可以构建多维度报表,揭示数据的趋势、规律及异常情况。 ... [详细]
  • MySQL 8.0 新特性详解:免费视频教程上线
    本文介绍了一套在慕课网上发布的免费视频教程,深入解析 MySQL 8.0 的核心新功能,包括增强的安全性、用户管理、新的索引类型、CTE 和窗口函数等。 ... [详细]
  • 本文档旨在为初学者提供MongoDB的基础知识介绍,包括其作为文档型数据库的特点、基本概念以及如何通过命令行界面(CLI)执行基本的操作。 ... [详细]
  • 本文回顾了作者在求职阿里和腾讯实习生过程中,从最初的迷茫到最后成功获得Offer的心路历程。文中不仅分享了个人的面试经历,还提供了宝贵的面试准备建议和技巧。 ... [详细]
author-avatar
v木易杨_920
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有