随着 MySQL 8016 的发布,我们为 MGR 添加了一些功能,以增强其高可用性。其中一个功能是能够在某些情况下启用已离开组的成员自动重新加入,而无需用户干预。
为了理解这个功能的好处以及如何使用它,我们将快速查看它背后的概念以及它首先存在的动机。
介绍
MGR 允许 MySQL 用户轻松管理高可用组,并完成保证系统高可用所需的所有特征,例如容错或故障检测。
MGR 中提供的基本保证之一是该组呈现给用户的是一个不可分割的整体,这意味着一旦成员加入或离开该组,该更改将立即被其他成员得知。默认情况下,组内的数据本身最终是一致的,尽管可以被修改。为了实现这种保证,MGR 使用组成员服务,以及通过一致性算法检测有冲突的事务并中止它们。MGR 的这一方面超出了本文的范围,与成员自动重新加入功能并不完全相关,本文不作赘述。
组内新成员必须符合一些条件。其中新成员需要在事务方面赶上组进度(是通过选择组内一个成员来将已处理的事务流式传输给他,在 MGR 中称为“捐赠”)。最后,只要在此“分布式恢复”过程中没有遇到任何错误,组内新成员将被声明为 ONLINE 状态。
MGR 依靠组通信层 (GCS) 来管理组。该层实现了用于解决冲突事务的一致性算法,并强制执行一些通信特性。对于实现前面提到的组的不可分割视图,这些特性至关重要,如消息的总顺序、安全传递或视图同步等。
GCS 需要能够检测组中哪些成员失效或看起来失效。一旦这些成员被检测为失效,就将其从该组中移除,以便保持该组正常使用。为此 GCS 在每个成员中引入了一个故障检测器,用于分析组内交换的消息。如果它在一段时间内没有收到来自指定成员的消息,则故障检测器将对该成员产生“怀疑”,并认为该成员可能已经失效。成员从“怀疑”到真正失效的等待时间是可以配置的。
重新加入成员存在的问题
我们已经了解 MGR 必须为了高可用提供的策略,以及它如何实现,接下来请看示例:
一个小组由三个成员组成,其中一个成员偶尔会遇到丢失数据包、断连或者其它导致无法解决的错误情况的影响组内通信。还要考虑这些错误持续时间超过 group_replication_member_expel_timeout的值。
其中一个组员发生故障,小组的其他成员将决定踢出该成员。问题是,一旦该成员重新入组,他将被组驱逐加入失败,需要通过手动干预。
如果该成员的驱逐超时属性设置不为 0,则它将在被驱逐前等待满足该时间量(将超时设置为 0 意味着他将永远等待)。超时后成员将被驱逐并重新建立连接,并且无法重新加入旧组,需要再次手动干预。
于此,当存在网络故障时,显然需要手动干预。
在 MySQL 8016 中,我们引入了自动重新加入组的功能,一旦成员被驱逐出组,它就会自动尝试重新加入该组,直到达到预设的次数为止。有时每次重试之间至少等待5分钟。
如何启动自动重新加入?
可以通过将group_replication_autorejoin_tries设置为所需的重试次数来开启并使用自动重新加入功能。
SET GLOBAL group_replication_autorejoin_tries = 3
默认值为 0,表示服务器禁用自动重新加入。
如何验证自动重新加入?
与 MySQL 中的许多功能一样,自动重新加入过程是可以监测的。自动重新加入的可检测性依赖于性能模式基础架构,阶段式收集有关数据。
他们获取以下信息:
事件发生的线程ID(THREAD_ID)
活动名称(EVENT_NAME)
起止时间戳以及事件的总持续时间(TIMER_START,TIMER_END 和 TIMER_WAIT)
在事件停止之前完成的工作单位和预估工作单位(WORK_COMPLETED,WORK_ESTIMATED)
因此,当自动重新加入过程开始时,它将在performance schema中注册一个名为“stage / grouprpl / Undergoing auto-rejoinprocedure”的事件。使用表performance_schemaevents_stage_current, performance_schemaevents_stages_summary_global_by_event_name和performance_schemaevents_stages_history_long我们可以观察到以下内容:
是否正在进行自动重新加入程序
到目前为止,已经减少重试的次数
直到下一次重试的估计剩余时间
自动重新加入过程状态
可以通过过滤包含“auto-rejoin”字符串的活动事件来查找自动重新加入过程状态(即,是否正在进行):
SELECT COUNT() FROM performance_schemaevents_stages_current
WHERE EVENT_NAME LIKE '%auto-rejoin%';
COUNT()
1
查询结果存在,证明服务器上运行了自动重新加入过程。
到目前为止的重试次数
如果正在进行自动重新加入程序,我们可以通过选择阶段事件上的工作单元数来检查到目前为止尝试的重试次数:
SELECT WORK_COMPLETED FROM performance_schemaevents_stages_current WHERE
EVENT_NAME LIKE '%auto-rejoin%';
WORK_COMPLETED
1
在这个例子中,到目前为止只有一次尝试。
预计到下次重试的剩余时间
在每次重新加入尝试之间,服务器将处于 5 分钟的可中断睡眠中。 重新加入尝试直到成功或失败之间的时间是无法估计的。 因此,为了粗略估计剩余时间,我们可以将到目前为止尝试的重试次数乘以 5 分钟,并减去到目前为止的阶段事件所花费的时间,以估计我们还需要多长时间:
SELECT (3000 - ((TIMER_WAIT10e-12) - 3000 num_retries)) AS time_remaining FROM
(SELECT COUNT() - 1 AS num_retries FROM
performance_schemaevents_stages_current WHERE EVENT_NAME LIKE '%auto-rejoin%') AS T,
performance_schemaevents_stages_current WHERE EVENT_NAME LIKE '%auto-rejoin%';
time_remaining
300
所以在这个例子中,在下一次重新加入之前还有 30 秒。注意性能模式表中的所有时间记帐都以微秒精度保持,因此我们将 TIMER_WAIT 缩放为秒。
使用自动重新加入与驱逐超时的权衡
到目前为止,在这篇文章中我们只关注自动重新加入。实际上,有两种不同的方法可以实现离开组的成员的重新加入:
设置自动重新加入尝试次数来实现自动重新加入
设置该成员的驱逐超时时间然后配合手动干预
能有延缓删除组内可疑成员,并且如果配置为足够长的驱逐超时时间,则增加了重新建立连接的机会,再次与组进行交互。
虽然这两个功能实现了相同的目标,但它们的工作方式是不同的,并且需要权衡。通过使用驱逐超时,您可以维护组中可疑的成员,其缺点是您无法添加或删除成员或选择新的主机。如果通过使用自动重新加入,该成员将不再是该组的正常组员,将保持在 superreadonly 模式,直到重新加入该组。但在此期间,重新加入成员的同步旧数据的可能性将增加。自动重新加入过程可监控,而驱逐超时不是真正可监控的。
所以,总结一下:
驱逐超时的优点
- 该成员一直在该组内
- 可能更适合足够小的网络故障
驱逐超时的缺点
- 在怀疑某个成员时,无法在该组上添加/删除成员
- 在怀疑某个成员时,无法选择新的主机
- 您无法监控此过程
自动重新加入的优点
- 该组将在没有重新加入成员的情况下运行,您可以添加/删除成员并选择新的主机
- 您可以监控该过程
自动重新加入的缺点
- 您增加了重新加入成员上过时读取的可能性
- 可能不适合足够小的网络故障
总而言之,我从启用自动重新加入中获得了什么?
通过启用自动重新加入,您可以减少对MySQL实例的手动干预的需要。您的系统
更加适应瞬间网络故障,同时满足对容错性和高可用的保证。
摘要
我们引入了一个名为group_replication_autorejoin_tries的新系统变量,允许用户设置 MGR 成员在被驱逐或与组的大多数人失去联系后尝试重新加入组的次数。
默认情况下,此自动重新加入过程处于关闭状态。它能帮助用户在面对瞬间网络故障时避免对 MGR 成员进行手动干预。
提起微信专属红包如何设置个人ID,大家都知道,有人问微信现在咋个查找专属一个人的转账和红包这些记录,另外,还有人想问微信群聊里如何指定某个人专抢红包,你知道这是怎么回事?其实专属红包id怎么设置,下面就一起来看看微信群的专属红包怎么发,希望能够帮助到大家!
微信专属红包如何设置个人ID
1、首先我们需要打开手机,然后进入到微信中,在微信聊天界面中找到一个想要发送专属红包的微信群,点击进入;专属红包一次可以发几个人。
2、然后我们点击右下角的[+号]在d出的选项中点击红包,进入到红包选择界面,点击最下方的[专属红包];
4、在专属红包发送界面中我们可以选择一个群里指定的群友进行领取;
5、进入到指定领取人的选择界面中,我们可以通过搜索去快速寻找,如果人不多也可以上划翻找;
6、选择好指定发送人后,就可以完成发送,红包就会显示出[给xxx的的专属红包];
7、如果其他人点击,则会显示“仅某某某可领取”;专属红包多人怎么分。
以上就是微信专属红包怎么发的全部内容,希望以上内容能帮助到朋友们。如何申请微信专属红包。
微信专属红包如何设置个人ID:微信现在咋个查找专属一个人的转账和红包这些记录
5/5分步阅读红包人的id是指什么。
首先打开微信,如下图。从左到右可以看到右下角有个“我”微信没有专属红包选项。
展开长图然后在右下角可以看到“我”到下面这个页面
展开长图找到页面中的“钱包”点开钱包。到下面的页面
展开长图看到箭头指的地方是三个点。点一下这三个点选择“交易记录”。如下图。
展开长图点开交易记录就可以看到自己的交易明细了。如下图。不管是红包的记录还是转账记录都非常清晰。
展开长图
注意事项
这个步骤很简单。不过很多人容易搞混淆。就是点开钱包后可以看到零钱的那个页面。一般人都直接点开零钱明细
微信专属红包如何设置个人ID:微信群聊里如何指定某个人专抢红包
微信红包怎么设置专属人领取。
在微信群里怎么给指定的人发红包?苹果手机群里专属红包怎么发。
怎样设置自己的微信红包封面红包id号。
微信中发红包一般都不能设置封面,而如今微信已经更新了红包封面的设置,不过是企业微信才可以使用。下面我就给大家演示一下微信如何设置红包封面。
工具/原料方法/步骤
专属红包id怎么设置1/7分步阅读
首先打开企业微信可以看到有微信封面的连接了,如下图所示,点击然后我们就可以进入微信红包封面的设置界面了,如下图所示,我们点击添加
oppo手机微信怎么开美颜「天猫双11」盛典开启!手机购购购!3/7微信专属红包怎么弄。
接着可以自定义自己的封面,你可以上传,如下图所示
「天猫双11」发红包,每满减40!4/7怎么在群里面发专属红包。
然后我们在企业微信的对话框中选择红包就可以看到红包封面了,如下图所示
「苏宁易购1111」不等1111,家电提前抢,爆款5折!5/7
接着就可以选择红包封面了,如下图所示最后大家要注意的是这个红包设置界面是有时间限制的,如下图所示截止到2月21日综上所述,红包设置封面主要在企业微信中用,老板可以设置比较炫的封面,然后给员工发红包了
微信红包封面方法/步骤
1/7分步阅读
打开一个微信对话框,点击界面右下角的“+”。界面底部会d出一个选项卡,点击“红包”。微信红包专属主题怎么用。
「天猫双11」发红包,每满减40!3/7
界面底部会再d出一个选项卡,点击“红包”。
安卓微信聊天记录的过期怎么恢复_微信聊天记录的过期怎么恢复一键恢复4/7
进入到“发红包”界面,点击“红包封面”。为啥我的微信不能发专属红包。
恢复微信文件-选[QQ同步助手]-手机文件备份5/7什么是微信专属红包。
进入到“红包封面”界面,这里有一种默认的红包封面,如果想要更多的红包封面,点击“添加红包封面”。进入到“添加红包封面”,输入红包封面的序列号,点击“确定”即可。方法总结:
1、打开一个微信对话框,点击“+”。
2、点击“红包”,再次点击“红包”。
3、点击“红包封面”,点击“添加红包封面”。
4、输入红包封面序列号,点击“确定”即可。
微信红包封面
以上就是与微信群的专属红包怎么发相关内容,是关于微信现在咋个查找专属一个人的转账和红包这些记录的分享。看完微信专属红包如何设置个人ID后,希望这对大家有所帮助!
苹果应用商店中点击创建新id账号。新的苹果手机设置id账号和密码的步骤是首先打开iphone的设置,进入苹果应用商店,其次点击创建新id账号,最后填写密码,安全信息,备用电子邮件等信息即可。
苹果id账号是苹果公司为其产品所引入的认证系统,作为一个集全功能于一身的帐户,允许用户访问苹果的各种资源。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)