编程开源技术交流,分享技术与知识

网站首页 > 开源技术 正文

探案录 | 在线打补丁,运维更轻松

wxchong 2024-10-26 16:06:45 开源技术 58 ℃ 0 评论

清晨,曙光温柔地洒落在福尔摩斯·K那标志性的书房内,福尔摩斯·K坐在他那张熟悉的扶手椅上,眼神锐利如鹰,正沉浸在思考的海洋中。门突然被推开,华生·K带着一丝急切步入室内。

“福尔摩斯·K,这次案件非同小可,关乎一家重要企业的数据库升级,他们正面临前所未有的挑战。”华生·K边说边递上一份文件。

福尔摩斯·K接过文件,边翻阅文件边说道,“随着业务需求增长,数据库升级势在必行,但传统方法需停止服务,这对企业而言无疑是一步险棋。”他嘴角微扬,似乎对这个技术案件充满了浓厚兴趣。

数据库升级遇停机难题

福尔摩斯·K决定亲自前往企业现场,一探究竟。他首先研究了该企业当前采用的数据库集群架构,三个节点的数据库集群的布局清晰地展现在他眼前。接着,他详细询问了企业技术负责人老林关于现有升级方案的细节。

老林叹了一口气说道:“我们需要升级一个数据库补丁,来解决某个安全风险的问题,这是目前的升级方案,我们害怕按这样的方式升级系统会面临巨大的风险。”


“确实如此,你看,”福尔摩斯·K指着屏幕上的升级流程图,眉头紧锁。

“在整个升级过程中,不仅需要停止业务系统,而且每一步,都需要小心翼翼的手动去操作,每一个环节都需要保证万无一失。如果没有操作正确,缺少某一步,或一不小心操作错了可能引发连锁反应,会给系统带来各种风险。”


数据库平滑升级秘籍:Kpatch

福尔摩斯·K站起身来,来回踱步,思考着破解这一难题的线索。

“如果想不影响业务系统,又想快捷自动化的操作,那么...华生·K,你记得Kpatch吗?”他突然停下脚步,转头问向华生·K。

华生·K突然眼前一亮:“对!人大金仓KingbaseES数据库Kpatch工具就能够实现。

老林惊讶地看着福尔摩斯·K:“Kpatch?它是怎那么做到的?”

华生·K微笑着解释道:“Kpatch将复杂操作集成化为一个命令,减少人工操作。它对集群中多个节点,实行逐步滚动的升级。当停止一个节点进行升级时,其他节点仍就对外提供服务,从而最大限度地减少对业务的影响。”

随即,华生·K展示了一张流程图:

福尔摩斯·K接着说:“Kpatch在升级过程中将滚动停止数据库,不停止整个集群。业务程序可能会在升级过程中失去某个节点数据库的连接,但是只需要重试当前语句,就可以在其他未执行升级的节点执行成功。在最后升级主节点时,会将其他备节点提升为主节点,因此,两个节点的集群影响时间为一个故障转移的时间,大概在60s以内。三个以上节点的集群,只会影响业务“写”,时间为一个故障转移的时间,能最大化地降低影响与风险。”

老林惊叹不已,说道:“这也太轻松了,能大大减少人工操作,请福尔摩斯·K先生务必教我使用KingbaseES数据库的Kpatch!”


在线打补丁,运维更轻松

福尔摩斯·K打开了数据库,“先选择一个节点,将Kpatch拷贝到集群安装目录下的Kpatch目录。”


“再将数据库补丁,拷贝到Kptach下的patch_packages目录。”

福尔摩斯·K突然转过头:“对了,如果没有Kpatch目录和patch_packages目录,则需要创建。”

“接下来就是执行升级了,在此节点上执行升级,-t指定版本号,会到`Kpatch/patch_packages`目录查询补丁包,也可以用-p直接指定补丁包路径”福尔摩斯·K接着说。

“在升级前,我们可以写一个脚本来验证升级对业务的影响,比如这样。”

“这个脚本每隔一秒使用ksql向vip指向的集群主节点进行一次查询当前时间并显示。这样我们可以通过这个脚本来从侧面观察升级对业务是否有影响。”

“那开始执行升级吧~”

“执行升级时,会自动拷贝解压补丁包到每个节点,检测当前版本号,检测集群状态,然后再逐步滚动进行升级。”

“升级成功了,数据库从V008R006C006B0021PS007版本升级到V008R006C006B0021PS012版本了。现在可查看升级状态,通过kpatch能查看当前集群升级补丁的情况。”

“接下来再看看刚刚那个脚本执行的效果吧:”

华生·K开心地说“升级很顺利啊!整个升级过程中,大部分都是预期的1秒停滞,只有一个地方有大概2.6秒的停滞,比正常的1s多了1.6秒,但是没有失败,且总体都没有对业务访问造成什么影响!”

福尔摩斯·K会心一笑,回道:“是啊,若通过kpatch升级过程中出现异常,导致升级失败,或者升级后,功能不满足,可以回滚操作,华生·K,剩下的交给你了。”

“没问题。”

华生·K在电脑上模拟演示:

“如同升级,会自动进行逐步滚动回退,像这样。”

到这里,数据已经回滚到之前的版本了。

老林赞叹不已,激动地说道“通过Kpatch来升级数据库补丁,只用了一个命令,就完成繁琐的数据库升级,而且还不用停止整个集群,将对业务的影响降到最低。Kpatch真是太厉害了,我这就去给我们公司的数据库用上这个功能。”

福尔摩斯·K微微一笑:“在这个数字化时代,任何难题都有其解开的钥匙。”

外面,街头依旧喧闹而美好,而福尔摩斯·K与华生·K,则继续穿梭在嘈杂的街道中,寻找下一个挑战与真相。

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表