当前位置: 首页 > news >正文

医院网站建设意义顺昌网站建设

医院网站建设意义,顺昌网站建设,青海省住房和城乡建设厅门户网站,百度收录查询工具官网近日#xff0c;Facebook 官博公布了他们的数据库版本从 MySQL 5.6 升级到了 MySQL 8.0#xff0c;并且在官博记录了复盘详细的升级过程。Facebook 称#xff0c;他们最近的一次大版本升级到 MySQL 5.6 花了一年多时间才完成#xff0c;还在 5.6 版上开发 LSM 树存储引擎Facebook 官博公布了他们的数据库版本从 MySQL 5.6 升级到了 MySQL 8.0并且在官博记录了复盘详细的升级过程。Facebook 称他们最近的一次大版本升级到 MySQL 5.6 花了一年多时间才完成还在 5.6 版上开发 LSM 树存储引擎MyRocks。在升级到 5.7 的同时构建一个新的存储引擎会大大减慢 MyRocks 的进度因此我们选择继续使用 5.6直到 MyRocks 完成MySQL 5.6 的寿命也即将结束决定升级到 MySQL 8.0 。官博介绍说此次过程比之前的升级更具挑战。MySQL 是由 Oracle 公司开发的一个开源数据库它为 Facebook 的一些最重要的工作负载提供了动力。我们积极开发 MySQL 中的新特性以支持不断演化的需求。这些特性对MySQL的许多方面进行了修改包括客户机连接器、存储引擎、优化器以及复制。为了迁移工作负载对于每个新的 MySQL 主版本我们都需要投入大量的时间和精力。其中的挑战包括将自定义功能移植到新版本确保主要版本之间的复制兼容最小化现有应用程序查询所需的更改对阻碍服务器支持我们工作负载的性能退化进行修复。我们最近一次的主版本升级是到 MySQL 5.6它花了一年多的时间才推出。当5.7 版发布时我们还在 5.6 版上开发 LSM 树存储引擎和 MyRocks。在升级到 5.7 的同时构建一个新的存储引擎会大大减慢 MyRocks 的进度因此我们选择继续使用 5.6直到 MyRocks 完成。MySQL 8.0 发布之际我们正在做 MyRocks 向用户数据库UDB服务层推出的收尾。该版本包括一些引人注目的特性如基于写集的并行复制和提供原子 DDL 支持的事务数据字典等。对我们来说迁移到 8.0 还将带来包括文档存储在内的我们已经错过的 5.7 特性。版本 5.6 的使命即将结束我们希望在 MySQL 社区中保持活跃尤其是在 MyRocks 存储引擎上的工作。8.0 中的增强功能比如即时 DDL可以加快 MyRocks 的模式更改但是我们需要在 8.0 的代码库中使用它。考虑到更新代码的好处我们决定迁移到 8.0。下面将分享我们如何解决 8.0 迁移项目的难题以及在这个过程中发现的一些惊喜。当最初确定项目范围时可以明确的是迁移到 8.0 会比迁移到 5.6 或 MyRocks 更困难。当时我们定制的 5.6 分支有 1700 多个代码补丁需要移植到 8.0。在我们移植这些更改时新的 Facebook 的 MySQL 特性和修复已被添加到5.6 的代码库中从而使目标变得更加遥不可及。我们有许多 MySQL 服务器在生产环境中运行为大量截然不同的应用程序提供服务。我们还有众多管理 MySQL 实例的软件架构。这些应用执行诸如收集统计数据或管理服务器备份之类的操作。从 5.6 升级到 8.0 完全跳过了 5.7。在 5.6 中处于活动状态的 API 在 5.7中可能被弃用而在 8.0 中可能会被移除这要求我们必须更新所有使用了现已删除API的应用程序。许多 Facebook 功能与 8.0 中的类似功能并不向前兼容需要一种弃用或迁移途径。MyRocks 的增强功能需要在 8.0 中运行包括本地化分区和崩溃恢复。1、代码补丁首先我们建立了 8.0 分支用于在开发环境中进行构建和测试。然后我们开始从 5.6 分支移植补丁的漫长过程。开始的时候有 1700 多个补丁但我们能将其组织成几个主要类别。我们的大多数自定义代码都有很好的注释和描述因此可以很容易地确定应用程序是否仍然需要它或者是否可以将它删除。通过特殊关键字或唯一变量名所启用的功能也使得确定关联变得很容易因为我们可以搜索应用程序代码库来找到它们的用例。有些补丁非常晦涩难懂需要做调查工作 — 挖掘旧的设计文档、邮件或代码评审注释以了解它们的历史。我们将每个补丁分入四类之一Drop不再使用或在8.0中具有同等功能的特性不需要移植。Build/Client支持我们构建环境的非服务器特性修改过的 MySQL 工具比如 mysqlbinlog或者增加的功能如异步客户端 API 等需要移植。非 MyRocks 服务器mysqld 服务器中与 MyRocks 存储引擎无关的特性需要移植。MyRocks 服务器支持 MyRocks 存储引擎的特性需要移植。我们使用电子表格跟踪每个补丁的状态和相关历史信息并且在删除补丁时记录理由。更新相同特性的多个补丁被组在一起进行移植。移植并提交到 8.0 分支的补丁用 5.6 提交信息进行了注释。由于我们需要筛选大量的补丁将不可避免地出现移植状态上的差异这些注释帮助我们解决了此类问题。客户端和服务器类别中的每个补丁都自然而然地成为一个软件发布里程碑。随着所有与客户端相关的更改的移植我们能够将客户端工具和连接器代码更新到8.0。一旦所有非 MyRocks 服务器特性都被移植我们就可以为 InnoDB 服务器部署8.0 mysqld了。完成 MyRocks 服务器特性移植使我们能够更新 MyRocks 安装。有些复杂特性需要对 8.0 进行重大更改一些方面存在很大的兼容性问题。例如上游 8.0 binlog 事件格式与我们一些对 5.6 的定制修改不兼容。Facebook 5.6 特性使用的错误代码与上游 8.0 分配给新特性的错误代码冲突。我们最终需要修补 5.6 服务器以使其与 8.0 向前兼容。完成所有这些特性的移植花了几年时间。到最终结束时我们已经评估了 2300 多个补丁并将其中 1500 个移植到了 8.0 版本。2、迁移途径我们将多个 mysqld 实例组合到一个 MySQL 副本集中。副本集中的每个实例都包含相同的数据但在地理上分布到不同的数据中心以提供数据可用性和故障切换支持。每个副本集都有一个主实例。其余的实例都是从实例。主实例处理所有写流量并将数据异步复制到所有从实例。由 5.6 主/5.6 从所组成的副本集开始最终目标是包含 8.0 主/ 8.0 从的副本集。我们遵循一个类似于 UDB MyRocks migration plan 的迁移规划。对于每个副本集通过一个使用 mysqldump 生成的逻辑备份创建并添加到 8.0 的从实例。这些从实例不提供任何应用程序读取流量在 8.0 从实例上开启读取流量允许将 8.0 从实例升级为主实例禁用 5.6 实例的读取流量移除所有 5.6 实例。每个副本集可以独立地通过上述步骤进行迁移并可根据需要停留在一个步骤上。我们将副本集分成更小的组在组中进行每一次迁移。如果发现问题我们可以回滚到上一步。在某些情况下副本集能够在其它副本集开始之前到达最后一步。为了自动化迁移大量副本集我们需要构建新的软件架构。可以通过简单地更改配置文件中的一行将副本集组合并在每个阶段中移动它们。任何遇到问题的副本集都能单独回滚。3、基于行的复制作为 8.0 迁移工作的一部分我们决定将使用基于行的复制row-based replicationRBR作为标准。一些 8.0 特性需要 RBR并且它简化了 MyRocks 的移植工作。我们的大多数 MySQL 副本集已经在使用 RBR而那些仍然运行基于语句的复制statement-based replicationSBR的副本集不容易迁移。这些副本集通常有不含任何高基数键的表。完全转向 RBR 是一个目标但添加主键所需的长尾工作的优先级往往低于其它项目。因此我们将 RBR 作为 8.0 的要求。在评估并向每个表添加主键之后我们今年切换了最后一个 SBR 副本集。使用 RBR 还为我们提供了一个解决应用程序问题的替代解决方案我们在将一些副本集移动到 8.0 主实例时遇到了这个问题将在后面讨论。4、自动化验证大多数 8.0 迁移过程都涉及使用我们的自动化架构和应用查询来测试和验证 mysqld 服务器。我们用来管理服务器的自动化基础架构在随着 MySQL 服务器的增长而增长。为了确保所有 MySQL 自动化组件都与 8.0 版本兼容我们投资构建了一个测试环境该环境利用虚拟机上的测试副本集来验证行为。我们为 canary 编写了在 5.6 版本和 8.0 版本上运行的每个自动化组件的集成测试并验证了它们的正确性。在进行此演练时我们发现了几个错误和行为差异。当 MySQL 架构的每一部分都在我们的 8.0 服务器上进行验证时我们发现并修复了或解决了一些有趣的问题解析错误日志、mysqldump 输出或服务器 show 命令的文本输出的软件很容易损坏。服务器输出的细微变化常常会暴露出工具解析逻辑中的错误。8.0 的默认 utf8mb4 排序规则设置导致 5.6 和 8.0 实例之间的排序规则不匹配。8.0 表可能会使用新的 utf8mb4_0900 排序规则即使对于由 5.6 的show create table生成的create语句也是如此因为使用utf8mb4_general_ci 的 5.6 模式没有显式指定排序规则。这些表差异通常会导致复制和模式验证工具出现问题某些复制失败的错误代码发生了变化我们必须修复我们的自动化程序来正确处理它们8.0 版本的数据字典废弃了 table.frm 文件但是我们的一些自动化系统使用它们来检测表模式的修改我们必须更新自动化系统以支持 8.0 中引入的动态权限。5、应用程序验证我们希望迁移对应用程序尽可能透明但是有些应用程序的查询会出现性能退化或者在8.0 上会失败。对于 MyRocks 迁移我们构建了一个 MySQL 影子测试框架该框架捕获生产流量并将其重放到测试实例中。对于每个应用程序工作负载我们在 8.0 上创建了测试实例并向它们回放影子流量的查询。我们捕获并记录了从 8.0 服务器返回的错误并发现了一些有趣的问题。不幸的是并非所有这些问题都是在测试过程中发现的。例如事务死锁是应用程序在迁移过程中发现的。在研究不同的解决方案时我们可以暂时将这些应用程序回滚到 5.6 版本。8.0 引入了新的保留关键字其中一些关键字如 groups 和 rank与应用程序查询中常用的表列名或别名相冲突。这些查询没有通过反引号转义名称导致解析错误。使用了自动转义查询中列名的软件库的应用程序没有遇到这些问题但并非所有应用程序都使用这些软件库。解决这个问题很简单但是需要时间来跟踪生成这些查询的应用程序属主和代码库。在 5.6 和 8.0 之间还发现了有些 REGEXP 不兼容。一些包含在 InnoDB 上的 insert ... on duplicate key 查询的应用程序遇到了 repeatable-read 事务死锁。5.6 有一个 bug在 8.0 中得到了修复但是修复增加了事务死锁的可能性。在分析了查询之后我们能够通过降低隔离级别来解决该问题。这个选项对我们来说是可用的因为我们已经切换到基于行的复制。我们自定义的 5.6 文档存储和 JSON 函数与 8.0 不兼容。使用文档存储的应用程序需要将文档类型转换为文本以进行迁移。对于 JSON 函数我们向 8.0 服务器中添加了兼容 5.6 的版本以便应用程序以后可以迁移到 8.0 API。我们对 8.0 服务器的查询和性能测试发现了一些需要立即解决的问题。我们发现在 ACL 缓存部分出现了新的互斥争用热点。当大量连接同时打开时它们都会阻塞 ACL 检查当存在大量 binlog 文件并且 binlog 的高速写入导致频繁轮换文件时binlog 索引访问也发现了类似的争用几个涉及临时表的查询被中断。这些查询会返回意外错误或者运行时间太长以致超时。内存使用量与 5.6 相比有所增加特别是对于 MyRocks 实例因为必须加载 8.0 中的 InnoDB 。默认的 performance_schema 设置启用了所有工具集并消耗了大量内存。我们限制了内存使用只启用了少量的工具并对代码进行了更改以禁用无法手动关闭的表。然而并不是所有增加的内存都是分配给 performance_schema 的。我们需要检查和修改各种 InnoDB 内部数据结构以进一步减少内存占用。这一努力使 8.0 的内存使用率降到了可以接受的水平。6、接下来的工作到目前为止8.0 的移植已经花了几年时间。我们已将许多 InnoDB 副本集转换为完全在 8.0 上运行。剩下的大部分都处于迁移途径的不同阶段。现在我们的大多数定制功能都已移植到 8.0更新到 Oracle 的次版本相对容易些我们计划跟上最新版本的步伐。跳过 5.7 这样的主版本会带来一些问题我们的迁移需要解决这些问题。首先我们无法就地升级服务器需要使用逻辑转储和还原来构建新服务器。但是对于非常大的 mysqld 实例这可能需要在活跃生产服务器上运行很多天而且这个脆弱的过程可能会在完成之前被中断。对于这些大型实例我们必须修改备份和恢复系统来应对重建。其次检测 API 更改要困难得多因为 5.7 可能会向我们的应用程序客户端发出不推荐警告以提示修复潜在的问题。而我们需要在迁移生产工作负载之前运行额外的影子测试来查找失败。使用自动转义模式对象名称的 mysql 客户端软件有助于减少兼容性问题的数量。在一个副本集中支持两个主版本非常困难。一旦副本集将其主实例升级为 8.0最好尽快禁用并移除 5.6 实例。应用程序用户往往会发现只有 8.0 支持的新特性比如 utf8mb4_0900 排序规则使用这些排序规则可能中断 8.0 和 5.6 实例之间的复制流。尽管我们在迁移过程中遇到了种种障碍但我们已经看到了运行 8.0 带来的好处。一些应用程序选择了提早迁移到 8.0以利用诸如文档存储和改进的日期时间支持等功能。我们一直在考虑如何在 MyRocks 上支持像即时DDL这样的存储引擎特性。总的来说新版本大大扩展了 MySQLFacebook 的功能。作者 | Herman LeePradeep Nayak 原文https://engineering.fb.com/2021/07/22/data-infrastructure/mysql/ 译者 | 王雪迎  责编 | 晋兆雨 出品 | CSDNIDCSDNnews END 往期精选再见收费的Navicat操作数据库靠它就够了MyBatis原生批量插入的坑与解决方案MyBatis 批量插入数据的 3 种方法更多精彩点击关注公众号
http://www.pierceye.com/news/470354/

相关文章:

  • 建设网站需要几级安全等保深圳网站开发招聘
  • 无锡网站建设制作公司甘肃省建设工程网站
  • 广州微信网站建设哪家好公司网站排名优化手段
  • 深圳市路桥建设集团有限公司招标采购网站crntos wordpress
  • 广告网站制作报价深圳建筑设计平台网站
  • 网站ns记录南宁企业建站模板
  • 网站服务建设目前做哪些网站能致富
  • 专业网站定制公司深圳网页制作服务
  • 白云网站(建设信科网络)网页工具在哪里
  • 食品网站策划网站建设送企业邮箱吗
  • 天津自贸区建设局网站手机网站导航设计
  • 企业网站建设制作大连网站建设吗
  • 做网页兼职网站有哪些建设网站需要花费
  • 如何快速写一个网站黄页网络的推广软件下载
  • 网站建设公司注册enfold wordpress
  • 上海网站建设百度推广公司哪家好模具厂咋做网站
  • 网站背景自动切换织梦网站模板使用教程
  • 网站建设的成果怎么写找人做淘宝网站需要多少钱
  • 网站制作 企业网站建设哪家好tiktok海外运营推广
  • 南昌做网站哪个公司好玉溪市住房和城乡建设局网站
  • 男女做暖网站是什么样子的wordpress 时间轴 主题
  • 国外建设网站jsp网站开发工具
  • 网站流量怎么赚钱wordpress 08影院模板
  • win网站建设网站哪个公司做的好
  • 温州网站运营微信公众号服务号网站开发流程
  • 网站宣传的好处山西房地产网站建设
  • 网站seo工作内容大学做视频网站
  • 台州网站建设企业网站 微信开发
  • 安徽省水利厅网站 基本建设营销策划公司名称
  • 网页设计师培训学院开封做网站优化