bitsCN.com
MySQL Cluster的高可用性 - 1
使用mysql cluster,能达到99.999的高可靠性,在这一章节,主要介绍一些基本概念:
Network Partitioning
在一个mysql集群中,如果几个节点之间网络出问题了,mysql cluster能决定哪些节点应该继续提供服务。比方有两个Node Group共四个节点:SN1, SN2,SN2, SN4。
SN1和SN2在Node Group1, SN3和SN4在Node Group2。如果{SN1, SN3}与{SN2, SN4}失去联系,那么他们中的任何两个都拥有完整数据,都能对外提供服务。为了数据完整性,我们必须隔离一半。根据配置,一个或者几个管理节点能够提供仲裁,帮助我们选择哪一对节点继续存活。假如我们配置了两个管理节点(MGM1, MGM2)都能提供仲裁服务,我们要避免以下这样的配置:
路由器1: MGM1, SN1, SN3
路由器2: MGM2, SN2, SN4
如果你有这样配置,路由器1与路由器2之间出了问题,而MGM1, MGM2都能仲裁,那么有可能两边都在对外提供服务。结果你懂的。
Synchronous Replication: 同步复制。
这比较好理解,在同一个Node Group内部,事务提交为two-phase commit,而且是同步的。每个数据节点内的数据都同步复制到另一个节点上。MySQL Cluster 配置通常至少有 2 个全部数据的副本,存放在不同主机上。为避免整体系统故障,系统会根据可配置的频率在磁盘上定期保存事务日志和检查点文件。如果某个节点发生故障,至少有另一个数据节点存储着相同的信息。
注意:同步复制只是内存的复制,对于mysql cluster来说,他可能还没有写到硬盘(与Checkpoint和Redo, UNDO log相关)。如果同一个Node Group同时下电,那么我们就可能丢数据。Mysql cluster的数据一致性是说我们几乎没有两个节点同时over,所以我们进行部署时最好不要同一个Node Group的data node在同一个机架。
Failure Detection 错误检测。
通常有两种错误,communication loss 和 heartbeat failure。一是通讯丢失,可以通过tcp,共享内存等方式在各存储节点之间通讯来侦测节点是否正常这种方式是最快的故障检测方式,
二是心跳失败,通讯丢失的检测方法在某些特殊情况下无效,例如磁盘故障等问题.所有的存储节点通过组成一个环路,每个节点向下一个节点发送心跳信号,如果下一个节点没有收到心跳信号,则认为上一个存储节点故障,并依次向下下个节点广播此故障信息
Logging:
正常情况下,不管什么类型的数据库,都会有日志,它包含所有的insert/update/delete。在系统出现故障的时候我们用它来辅助恢复数据库。
Local Checkpoints:
Redo log是一个环形日志文件,随着数据库的操作,redo log也在增长,如果不及时清理的话,log空间很快就会用光,我们需要及时地把snapshot image写到disk,然后把redo log的tail指针向前挪。NoOfFragmentLogFiles用来控制redo log的大小,TimeBetweenLocalCheckpoints控制cluster local checkpoint的频率。这儿的Time并不指时间,而是指操作的个数,它是以指数形式增长的,比方20是4M的写操作,但是21就是8M。
Global Checkpoints:
Mysql cluster是一个in-memory数据库,为了性能的关系,事务都是先同步到内存,然后后面写log。GlobalCheckpoints就是每隔一段时间TimeBetweenGlobalCheckpoints,我们把一组提交的事务写到disk。Global Checkpoint就是定时将Redo log写到disk。
Global Checkpoint是写Redo log,Local Checkpoint是截Redo log的尾。
Local check需要时间,为了能够恢复的时候LCP image与LCP开始时间完全一致,mysql cluster引入Undo log。
System Recovery 系统恢复:
当恢复的时候,LCP image是LCP stop点的数据,我们执行undo log使系统回退到LCP start点。然后执行Redo log到Global checkpoint点。
跨地域复制 — 跨地域复制使节点能镜像到远程数据中心以便进行灾难恢复
限制
不支持磁盘上的持续提交。提交将被复制,但不保证在提交时会将日志写入磁盘。
不能在线增加或舍弃节点(此时必须重启簇)

1.选择合适的客户端传输协议ActiveMQ支持多种客户端传输协议,包括STOMP、AMQP和OpenWire。根据您的应用程序需求选择合适的协议,以优化性能和可靠性。2.配置消息持久性持久性消息即使在服务器重新启动后也能持久化,而非持久性消息则不会。对于关键消息,选择持久性以确保可靠传递。演示代码://设置消息持久性MessageProducerproducer=session.createProducer(destination);producer.setDeliveryMode(Deliv

嵌入式系统是指在特定的硬件平台上运行的应用程序,通常用于控制、监控和处理各种设备和系统。C++作为一种功能强大的编程语言,在嵌入式系统开发中广泛应用。本文将介绍C++嵌入式系统开发的基本概念和技术,以及如何打造高可靠性的嵌入式应用。一、嵌入式系统开发概述嵌入式系统开发需要对硬件平台有一定的了解,因为嵌入式应用程序需要直接与硬件交互。除了硬件平台之外,嵌入式系

MySQL和Oracle:对于备份和恢复的速度和可靠性比较导言:MySQL和Oracle是两个常见的关系型数据库管理系统(RDBMS),它们在数据备份和恢复方面有着不同的机制和性能表现。本文将重点比较MySQL和Oracle在备份和恢复方面的速度和可靠性,并附上一些代码示例,以便更好地理解它们之间的差异和优劣势。备份性能比较:在备份方面,MySQL和Orac

随着互联网技术的不断进步和发展,越来越多的Web应用和服务被开发出来。而为了更加高效的管理这些应用和服务,越来越多的开发者开始采用PHP命令行应用来进行管理和操作。但是,开发可靠的PHP命令行应用却是一件非常困难的事情。在本文中,我们将探讨如何开发可靠的PHP命令行应用。1.选择合适的框架选择一个合适的框架是开发可靠的PHP命令行应用的第一步。在

通过Docker容器提高SpringBoot应用的可靠性和资源利用率引言:随着云计算和容器化技术的发展,Docker成为了应用部署和管理的重要工具。在Java开发领域,SpringBoot作为一款轻量级的微服务框架,被广泛应用于各类企业应用开发中。本文将介绍如何通过使用Docker容器来提高SpringBoot应用的可靠性和资源利用率,并提供具体的代码

什么是PHP微服务架构?PHP微服务架构是一种将大型单体应用程序分解为一组较小的、相互独立的服务的体系结构。这些服务称为微服务,每个服务都负责应用程序的特定功能。微服务通常通过轻量级协议(如Http或grpc)进行通信。PHP微服务架构的优点采用php微服务架构为应用程序带来了众多好处,包括:可扩展性:微服务架构允许您根据需要轻松扩展应用程序。只需添加或删除微服务即可。敏捷性:微服务架构使您能够独立开发和部署单个微服务。这可以显着缩短开发周期。可靠性:如果一个微服务发生故障,它不会影响其他微服务

正⽂:Java是一种高级编程语言,它可以用于创建应用程序和软件,并因其易学性、可移植性和可靠性而广受欢迎。Java编程语言由詹姆斯·高斯林(JamesGosling)及其同事在1991年开发,并于1995年正式发布。Java语法与c++语言相似,但功能更强大、表达方式更简洁。此外,Java还具有跨平台性,一个Java应用程序可以在任何装有Java虚拟机(JVM)的设备上运行,而无需重新编译。Java是一种面向对象的编程语言,它将对象作为程序的基本组成部分。每个对象都包含数据和方法,并且可以与其他

Java函数式编程提高了可靠性和可用性,通过不可变性和类型系统提高可靠性,并通过并行性和异步性提高可用性。并行代码利用多核CPU,异步代码允许不阻塞主线程执行操作。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

SublimeText3汉化版
中文版,非常好用

SublimeText3 Linux新版
SublimeText3 Linux最新版

记事本++7.3.1
好用且免费的代码编辑器

Dreamweaver CS6
视觉化网页开发工具