金仓数据库 KingbaseES 在线打补丁,运维更轻松

清晨,曙光温柔地洒落在福尔摩斯·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,则继续穿梭在嘈杂的街道中,寻找下一个挑战与真相。
版权声明: 本文为 InfoQ 作者【金仓技术】的原创文章。
原文链接:【http://xie.infoq.cn/article/aa03d5a6af7a68ec43ab773fa】。
本文遵守【CC-BY 4.0】协议,转载请保留原文出处及本版权声明。
评论