网站首页 > 开源技术 正文
清晨,曙光温柔地洒落在福尔摩斯·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,则继续穿梭在嘈杂的街道中,寻找下一个挑战与真相。
猜你喜欢
- 2024-10-26 如何在Rails应用程序中使用Kafka?
- 2024-10-26 Kafka 的 API 该怎么选?(kafka的ack)
- 2024-10-26 Kafka SQL查询Topic中消息内容(kafka查看topic中的数据java)
- 2024-10-26 为什么 Kafka 这么快?它是如何工作的?
- 2024-10-26 使用Apache Kafka、Kafka Connect,Debezium和ksqlDB的实时流ETL
- 2024-10-26 信创改造--人大金仓(Kingbase)数据库安装、备份恢复的问题纪要
- 2024-10-26 Kafka不只是个消息系统(kafka消息机制)
- 2024-10-26 SQL 是用于访问和处理数据库的标准的计算机语言,你知多少?
- 2024-10-26 流式数据库 KSQL 概念详解 (三)(流式数据处理技术)
- 2024-07-19 Go爱好者周刊:第 64 期—goup这个工具了解下
你 发表评论:
欢迎- 05-28AIMP播放器这样设置,显示歌词更加完美
- 05-28回放增益可存储:音频播放器AIMP 3.60.1483下载
- 05-28【推荐】俄罗斯顶级音乐播放软件AIMP
- 05-28找到一款汉EV的本地音乐播放神器,叫AIMP(不是广告)
- 05-28文档没有保存电脑就关机了怎么办?
- 05-28微软office加入OpenAI
- 05-28吉林大学“开放交流时间”(Open Office Hour)来了!
- 05-28全新 Office 2024 正式发布
- 最近发表
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)