CN114172808A - Kubernetes集群升级方法、系统、设备及存储介质 - Google Patents
Kubernetes集群升级方法、系统、设备及存储介质 Download PDFInfo
- Publication number
- CN114172808A CN114172808A CN202111484252.2A CN202111484252A CN114172808A CN 114172808 A CN114172808 A CN 114172808A CN 202111484252 A CN202111484252 A CN 202111484252A CN 114172808 A CN114172808 A CN 114172808A
- Authority
- CN
- China
- Prior art keywords
- version
- component
- cluster
- new version
- old
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 43
- 238000005096 rolling process Methods 0.000 claims abstract description 48
- 230000001360 synchronised effect Effects 0.000 claims description 6
- 238000007726 management method Methods 0.000 description 14
- 230000008569 process Effects 0.000 description 9
- 238000010586 diagram Methods 0.000 description 7
- 238000013499 data model Methods 0.000 description 4
- 230000003287 optical effect Effects 0.000 description 3
- 238000006243 chemical reaction Methods 0.000 description 2
- 230000007246 mechanism Effects 0.000 description 2
- 239000013307 optical fiber Substances 0.000 description 2
- 230000000644 propagated effect Effects 0.000 description 2
- 238000003491 array Methods 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 238000004138 cluster model Methods 0.000 description 1
- 238000004891 communication Methods 0.000 description 1
- 238000005111 flow chemistry technique Methods 0.000 description 1
- 230000006870 function Effects 0.000 description 1
- 230000005012 migration Effects 0.000 description 1
- 238000013508 migration Methods 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 230000003252 repetitive effect Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 230000001131 transforming effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/08—Configuration management of networks or network elements
- H04L41/0803—Configuration setting
- H04L41/0813—Configuration setting characterised by the conditions triggering a change of settings
- H04L41/082—Configuration setting characterised by the conditions triggering a change of settings the condition being updates or upgrades of network functionality
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/70—Software maintenance or management
- G06F8/71—Version control; Configuration management
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Stored Programmes (AREA)
Abstract
本发明提供Kubernetes集群升级方法、系统、设备及存储介质,其中,方法包括:从版本管理仓库中获取新版本Kubernetes集群组件镜像;利用所述新版本Kubernetes集群组件镜像对旧版本Kubernetes集群组件进行滚动升级,升级到新版的Kubernetes集群组件;在所述Kubernetes集群中的接口服务器组件从旧版本升级到新版本情况下,还保留旧版本接口服务器组件;所述旧版本接口服务器组件用于提供对旧版本工作负载资源模型的调度服务。这样对于无法适配新版本接口服务器组件的旧版本工作负载,可以继续适配旧版本接口服务器组件提供对外服务,减少Kubernetes集群组件不能对外提供服务或对外提供服务中断的问题。
Description
技术领域
本发明涉及计算机技术领域,具体地说,涉及Kubernetes集群升级方法、系统、设备及存储介质。
背景技术
Kubernetes(简称K8S)集群是一个开源的,用于管理云平台中多个主机上容器化应用的容器编排管理平台,提供了应用部署规划、更新、维护的一种机制。
传统Kubernetes集群升级办法是采取蓝绿发布,先在另一套资源上部署新版本K8S集群以及工作负载,再停机整体迁移外部流量访问到新版本集群,再对旧版本集群资源进行组件升级后纳管到新版本集群。
发明内容
针对现有技术中的问题,本发明的目的在于提供Kubernetes集群升级方法、系统、设备及存储介质,克服了现有技术的困难,对于无法适配新版本接口服务器组件的旧版本工作负载,能够继续适配旧版本接口服务器组件提供对外服务,减少Kubernetes集群组件不能对外提供服务或对外提供服务中断的问题。
本发明实施例提供一种Kubernetes集群升级方法,该方法包括:
从版本管理仓库中获取新版本Kubernetes集群组件镜像;
利用新版本Kubernetes集群组件镜像对旧版本Kubernetes集群组件进行滚动升级,升级到新版的Kubernetes集群组件;
在Kubernetes集群中的接口服务器组件从旧版本升级到新版本情况下,还保留旧版本接口服务器组件;
旧版本接口服务器组件用于提供对旧版本工作负载资源模型的调度服务。
可选地,在Kubernetes集群中部署键值存储器,则利用新版本 Kubernetes集群组件镜像对旧版本Kubernetes集群组件进行滚动升级,包括:
同步旧版本键值存储器中的数据到新版本键值存储器。
可选地,在Kubernetes集群中部署索引库和资源模型转换器,索引库存储工作负载资源模型的各版本关键字的索引信息,则方法还包括:
在旧版本接口服务器组件发出资源调度请求的情况下,利用资源模型转换器截获资源调度请求,从资源调度请求得到工作负载资源模型的旧版本关键字;
利用旧版本关键字在索引库中查找旧版本关键字所对应的新版本关键字;
在资源模型转换器查找到新版本关键字的情况下,资源模型转换器将新版本关键字写入新版本键值存储器中;
在未查找到新版本关键字的情况下,资源模型转换器在资源调度请求中添加为工作负载与其宿主机节点打上旧版本标签的字段,并将旧版本关键字写入新版本键值存储器中。
可选地,利用新版本Kubernetes集群组件镜像对旧版本Kubernetes 集群组件进行滚动升级,包括:
利用新版本Kubernetes集群组件镜像,以容器化方式对旧版本 Kubernetes集群组件进行滚动升级。
可选地,从版本管理仓库中获取新版本Kubernetes集群组件镜像,包括:
从版本管理仓库中获取新版本控制面组件镜像和新版本工作面组件镜像;
利用新版本Kubernetes集群组件镜像,以容器化方式对旧版本 Kubernetes集群组件进行滚动升级,包括:
利用新版本控制面组件镜像,以容器化方式对旧版本控制面组件进行滚动升级,升级到新版本控制面组件;
利用新版本工作面组件镜像,以容器化方式对旧版本工作面组件进行滚动升级,升级到新版本工作面组件。
本发明实施例还提供一种Kubernetes集群升级系统,该系统包括:
获取模块,从Kubernetes集群的版本管理仓库中获取新版本 Kubernetes集群组件镜像;
升级模块,利用集群组件镜像对旧版本Kubernetes集群组件进行滚动升级,Kubernetes集群从旧版本升级到新版本;
保留模块,在Kubernetes集群中的接口服务器组件从旧版本升级到新版本情况下,还保留旧版本接口服务器组件;
旧版本接口服务器组件用于提供对旧版本工作负载资源模型的调度服务。
可选地,在Kubernetes集群中部署键值存储器,则升级模块具体用于:
同步旧版本键值存储器中的数据到新版本键值存储器。
可选地,在Kubernetes集群中部署索引库和资源模型转换器,索引库存储工作负载资源模型的各版本关键字的索引信息,系统还包括:
截获模块,在旧版本接口服务器组件发出资源调度请求的情况下,利用资源模型转换器截获资源调度请求,从资源调度请求得到工作负载资源模型的旧版本关键字;
查找模块,利用旧版本关键字在索引库中查找旧版本关键字所对应的新版本关键字;
写入模块,具体用于:
在资源模型转换器查找到新版本关键字的情况下,资源模型转换器将新版本关键字写入新版本键值存储器中;
在未查找到新版本关键字的情况下,资源模型转换器在资源调度请求中添加为工作负载与其宿主机节点打上旧版本标签的字段,并将旧版本关键字写入新版本键值存储器中。
可选地,升级模块具体用于:
利用集群组件镜像,以容器化方式对旧版本Kubernetes集群组件进行滚动升级。
可选地,获取模块具体用于:
从版本管理仓库中获取新版本控制面组件镜像和新版本工作面组件镜像;
升级模块具体用于:
利用新版本控制面组件镜像,以容器化方式对旧版本控制面组件进行滚动升级,升级到新版本控制面组件;
利用新版本工作面组件镜像,以容器化方式对旧版本工作面组件进行滚动升级,升级到新版本工作面组件。
本发明实施例还提供一种电子设备,包括:
处理器;
存储器,其中存储有处理器的可执行指令;
其中,处理器配置为经由执行可执行指令来执行上述Kubernetes集群升级方法的步骤。
本发明的实施例还提供一种计算机可读存储介质,用于存储程序,程序被执行时实现上述Kubernetes集群升级方法的步骤。
本发明的目的在于提供Kubernetes集群升级方法、系统、设备及存储介质,通过对Kubernetes集群中的组件进行滚动升级,滚动升级避免 Kubernetes集群整体停机,除了当时升级的集群组件,其他组件都能对外提供服务。也是在这种情况下,在将接口服务器组件升级的情况下,保留旧版本接口服务器组件,这样对于无法适配新版本接口服务器组件的旧版本工作负载,可以继续适配旧版本接口服务器组件提供对外服务,减少 Kubernetes集群组件不能对外提供服务或对外提供服务中断的问题。
附图说明
通过阅读参照以下附图对非限制性实施例所作的详细描述,本发明的其它特征、目的和优点将会变得更明显。
图1是本发明实施例的Kubernetes集群升级方法的流程图之一;
图2是本发明实施例的Kubernetes集群升级方法的流程图之二;
图3是本发明实施例的Kubernetes集群的模型示意图;
图4是本发明实施例的Kubernetes集群升级方法的流程图之三;
图5是本发明实施例的Kubernetes集群中工作负载资源模型转换过程流程图;
图6是本发明实施例的Kubernetes集群中无法转换资源模型的工作负载工作模式示意图;
图7是本发明实施例的Kubernetes集群升级系统的结构图之一;
图8是本发明实施例的Kubernetes集群升级系统的结构图之二;
图9是本发明实施例的Kubernetes集群升级系统运行的示意图。
具体实施方式
现在将参考附图更全面地描述示例实施方式。然而,示例实施方式能够以多种形式实施,且不应被理解为限于在此阐述的实施方式。相反,提供这些实施方式使本发明全面和完整,并将示例实施方式的构思全面地传达给本领域的技术人员。
附图仅为本发明的示意性图解,并非一定是按比例绘制。图中相同的附图标记表示相同或类似的部分,因而将省略对它们的重复描述。附图中所示的一些方框图是功能实体,不一定必须与物理或逻辑上独立的实体相对应。可以采用软件形式来实现这些功能实体,或在一个或多个硬件转发模块或集成电路中实现这些功能实体,或在不同网络和/或处理器装置和/ 或微控制器装置中实现这些功能实体。
此外,附图中所示的流程仅是示例性说明,不是必须包括所有的步骤。例如,有的步骤可以分解,有的步骤可以合并或部分合并,且实际执行的顺序有可能根据实际情况改变。具体描述时使用的“第一”、“第二”以及类似的词语并不表示任何顺序、数量或者重要性,而只是用来区分不同的组成部分。需要说明的是,在不冲突的情况下,本发明的实施例及不同实施例中的特征可以相互组合。
在实际应用中,现有技术的Kubernetes集群升级方案带来如下问题:
1、该方案需要2套物理资源,升级过程中的集群资源无法对外提供服务;
2、工作负载迁移成本高,由于K8S集群版本变更通常涉及接口服务器API-Server组件升级,导致旧版本工作负载可能无法适配新版本集群的API,使得旧版本工作负载不能对外提供服务器;
3、服务中断,升级过程中无论是新版本K8S集群还是旧版本集群在部署新版本集群组件的过程中,都无法对外服务,导致在线用户面临服务中断。
可见,上述K8S集群升级方案存在K8S集群对外提供服务可靠性下降的问题,给用户带来较差的用户体验。
本发明实施例通过对Kubernetes集群中的组件进行滚动升级,滚动升级避免Kubernetes集群整体停机,除了当时升级的集群组件,其他组件都能对外提供服务。也是在这种情况下,在将接口服务器组件升级的情况下,保留旧版本接口服务器组件,这样对于无法适配新版本接口服务器组件的旧版本工作负载,可以继续适配旧版本接口服务器组件提供对外服务,减少Kubernetes集群组件不能对外提供服务或对外提供服务中断的问题。
参考图1,图1为本发明实施例提供的Kubernetes集群升级方法的流程图,本方法具体包括如下步骤:
步骤110:从版本管理仓库中获取新版本Kubernetes集群组件镜像;
步骤120:利用新版本Kubernetes集群组件镜像对旧版本 Kubernetes集群组件进行滚动升级,升级到新版本Kubernetes集群组件;
步骤130:在Kubernetes集群中的接口服务器组件从旧版本升级到新版本情况下,还保留旧版本接口服务器组件;
旧版本接口服务器组件用于提供对旧版本工作负载资源模型的调度服务。
在本发明实施例中,滚动升级是一种平滑的升级方式,通过对 Kubernetes集群组件采用逐步替换的策略实现组件升级,保证整体系统的稳定,在初始化升级的时候就可以及时发现和解决问题,
本发明实施例通过对Kubernetes集群中的组件进行滚动升级,滚动升级避免Kubernetes集群整体停机,除了当时升级的集群组件,其他组件都能对外提供服务。也是在这种情况下,在将接口服务器组件升级的情况下,保留旧版本接口服务器组件,这样对于无法适配新版本接口服务器组件的旧版本工作负载,能够继续适配旧版本接口服务器组件提供对外服务,减少Kubernetes集群组件不能对外提供服务或对外提供服务中断的问题。
在本发明实施例中,利用新版本Kubernetes集群组件镜像对旧版本 Kubernetes集群组件进行滚动升级,具体包括如下步骤:
利用新版本Kubernetes集群组件镜像,以容器化方式对旧版本 Kubernetes集群组件进行滚动升级。
在本实施例中,Kubernetes集群中的各组件以容器方式部署,从而能够实现以容器化方式进行滚动升级。采用容器方式部署,能够降低资源损耗,可扩展性也更强。
在本发明实施例中,参考图2,滚动升级的具体步骤包括:
步骤210:从版本管理仓库中获取新版本控制面组件镜像;
步骤220:利用新版本控制面组件镜像,以容器化方式对旧版本控制面组件进行滚动升级,升级到新版本控制面组件;
步骤230:从版本管理仓库中获取新版本工作面组件镜像;
步骤240:利用新版本工作面组件镜像,以容器化方式对旧版本工作面组件进行滚动升级,升级到新版本工作面组件。
控制面组件和工作面组件属于Kubernetes集群中的组件。
控制面组件是通过管理一组基本调度单元pod来实现将实际集群状态转移到所需集群状态的对帐循环机制,其包括Daemon Set控制器和复制控制器等,可与API服务器进行通信以在需要時创建,更新和删除它们管理的资源。
工作面组件提供基于Pod的容器实例的部署运行能力。
其中,接口服务器组件属于控制面组件,并在控制面组件升级过程中,进行升级,同时保留旧版本接口服务器组件。
在本发明实施例中,可以先进行控制面组件升级,再进行工作面组件升级。在控制面组件升级过程中,由于保留了旧版本接口服务器组件,因此旧版本工作面组件及工作负载可以利用旧版本接口服务器组件提供对外服务,进而减少Kubernetes集群服务中断的问题。
在本发明实施例中,在Kubernetes集群中部署键值存储器,则利用新版本Kubernetes集群组件镜像对旧版本Kubernetes集群组件进行滚动升级,还可以包括:
同步旧版本键值存储器中的数据到新版本键值存储器。
键值存储器etcd(读作et-see-dee),实现旧版本工作负载正常调度,etcd是一种开源的使用一致性哈希算法(Raft)的分布式统一键值 key/value存储系统,用于分布式系统或计算机集群的共享配置、服务发现和的调度协调,etcd会在集群的各个节点中复制这些数据并保证这些数据始终正确。
参考图3,本发明实施例还提供一种Kubernetes集群的模型,具体部署如下模块:
版本管理仓库31、索引库32和资源模型转换器33。
其中,版本管理仓库31用于统一管理Kubernetes集群的多版本组件的容器镜像,集群组件升级版本均从该模块下载。
索引库32用于维护Kubernetes集群各集群版本资源模型关键字全集极其对应的Kubernetes集群版本信息,版本信息包括但不限于接口服务器组件提供的接口API关键字名称、对应数据模型版本、新版本关键字索引等,作为工作负载资源模型转换的索引信息。
资源模型转换器33用于对接旧版本接口服务器组件,使其适配新版本键值存储器etcd。
具体地,索引库32和资源模型转换器33部署在控制面组件中。
索引库32存储工作负载资源模型的各版本关键字的索引信息,参考图4,本发明实施例提供Kubernetes集群升级方法包括如下步骤:
步骤410:从版本管理仓库中获取新版本Kubernetes集群组件镜像;
步骤420:利用新版本Kubernetes集群组件镜像对旧版本Kubernetes集群组件进行滚动升级,升级到新版本Kubernetes集群组件;
步骤430:在Kubernetes集群中的接口服务器组件从旧版本升级到新版本情况下,还保留旧版本接口服务器组件;
步骤440:在旧版本接口服务器组件发出资源调度请求的情况下,利用资源模型转换器截获该资源调度请求,从资源调度请求得到工作负载资源模型的旧版本关键字;
步骤450:利用旧版本关键字,在索引库中查找旧版本关键字所对应的新版本关键字;
步骤460:在查找到新版本关键字的情况下,资源模型转换器将新版本关键字写入新版本键值存储器中;
步骤470:在未查找到新版本关键字的情况下,资源模型转换器在资源调度请求中添加为工作负载与其宿主机节点打上旧版本标签的字段,并将旧版本关键字写入新版本键值存储器中。
在这种情况下,资源模型转换器用于对工作负载资源模型的旧版本关键字转换成新版本关键字,使其能适配新版本数据模型存储到键值存储器中,实现新版本键值存储器组件兼容旧版本工作负载,保证相应 Kubernetes集群平滑滚动升级,又不会影响集群上的工作负载运行。
具体地,工作负载资源模型旧版本关键字转换过程如下:
1)初始化索引库。在索引库中导入旧版本与新版本资源模型关键字全集,并写入对应版本号字段,对在旧版本中已存在字段但在新版本中变更了关键字名称的关键字建立新版本关键字索引值。
2)对于新版本保留关键字,也就是资源模型转换器查找到新版本关键字与旧版本关键字一致,则对关键字的键值对不做转换,以新版本数据结构存入etcd。
3)对于新版本中已更名关键字,也就是资源模型转换器查找到索引库中对旧版本关键字变更名称并建立新版本索引值,则根据索引值变更旧版本关键字名称为新版本关键字名称,并以新版本数据结构存储到etcd。
4)对于新版本已废弃关键字,也即是模型转换器在索引库中无法查找到新版本关键字,则在旧版本关键字资源调度请求中新增tag字段,为工作负载与其宿主机节点自动打上低版本标签,使该工作负载及其横向拓展实例能调度到相应版本工作节点上(这些工作节点会保留旧版本 kubelet以对接旧版本API Server),并以旧版本数据结构存入etcd。
在本发明实施例中,在获取到新版本接口服务器组件发出的资源调度请求的情况下,资源模型转换器对该资源调度请求进行放行。
具体地,参考图5,v1表示旧版本,v2表示新版本;
在Kubernetes集群升级过程中,旧版本etcd中的数据同步迁移到新版本etcd;
接口服务器API Server v1向上发送对工作负载v1的资源调度请求,资源模型转换器截获API Server v1的资源调度请求,并根据在索引库中的查询结果进行资源模型关键字转换,存储到新版本v2的etcd中;
API Server v2向上发起对工作负载v2的资源调度请求,资源模型转换器截获该资源调度请求并直接放行,API Server v2与etcd v2直接交互。
同时应该注意到,旧版本接口服务器直接对接基于旧版本关键字的资源调度请求,因此资源调度请求中所传关键字为旧版本工作负载资源模型关键字,但这跟新版本etcd所定义数据模型不兼容,不能直接被集群所发现与调度。使用本发明实施例,资源模型转换器将旧版本关键字转换成新版本关键字,能够适配新版本数据模型存储到新版本etcd中。而且,由于旧版本工作负载被赋予新版本关键字,因此Kubernetes集群组件能够凭借新版本关键字在etcd中查询到旧版本工作负载,使得该旧版本工作负载被发现和调度。
在本发明实施例中,对于无法转换的旧版本关键字,可以在资源调度请求中新增字段,为工作负载与其宿主机打上低版本标签。这样,参考图 6,被打上旧版本标签的宿主机会保留旧版本Kubelet组件(Kubelet v1),用于继续为打了该版本标识的工作负载(现存的或日后水平扩展的,如工作负载A)对接旧版本API Server v1提供服务,继续将无法转换新版本容器工作负载实例亲和性调度到相应版本工作节点上,保证工作负载不中断。
图7为本发明实施例提供给的一种Kubernetes集群升级系统,该系统可以包括:
获取模块710,从Kubernetes集群的版本管理仓库中获取新版本 Kubernetes集群组件镜像;
升级模块720,利用集群组件镜像对旧版本Kubernetes集群组件进行滚动升级,Kubernetes集群从旧版本升级到新版本;
保留模块730,在将Kubernetes集群中的接口服务器组件从旧版本升级到新版本情况下,还保留旧版本接口服务器组件;
旧版本接口服务器组件用于提供对旧版本工作负载资源模型的调度服务。
利用本发明实施例通过对Kubernetes集群中的组件进行滚动升级,滚动升级避免Kubernetes集群整体停机,除了当时升级的集群组件,其他组件都能对外提供服务。也是在这种情况下,在将接口服务器组件升级的情况下,保留旧版本接口服务器组件,这样对于无法适配新版本接口服务器组件的旧版本工作负载,可以继续适配旧版本接口服务器组件提供对外服务,减少Kubernetes集群组件不能对外提供服务或对外提供服务中断的问题。
可选地,升级模块720具体用于:
利用集群组件镜像,以容器化方式对旧版本Kubernetes集群组件进行滚动升级。
可选地,获取模块710具体用于:
从版本管理仓库中获取新版本控制面组件镜像和新版本工作面组件镜像;
升级模块720具体用于:
利用新版本控制面组件镜像,以容器化方式对旧版本控制面组件进行滚动升级,升级到新版本控制面组件;
利用新版本工作面组件镜像,以容器化方式对旧版本工作面组件进行滚动升级,升级到新版本工作面组件。
可选地,在Kubernetes集群中部署键值存储器,则升级模块620具体用于:
同步旧版本键值存储器中的数据到新版本键值存储器。
可选地,参考图8,与图7相比,图8所示Kubernetes集群升级系统还包括:
截获模块810,在旧版本接口服务器组件发出资源调度请求的情况下,利用资源模型转换器截获资源调度请求,获取工作负载资源模型的旧版本关键字;
查找模块820,利用旧版本关键字在索引库中查找旧版本关键字所对应的新版本关键字;
写入模块830,具体用于:
在资源模型转换器查找到新版本关键字的情况下,资源模型转换器将新版本关键字写入新版本键值存储器中;
在未查找到新版本关键字的情况下,资源模型转换器在资源调度请求中添加为工作负载与其宿主机节点打上旧版本标签的字段,并将旧版本关键字写入新版本键值存储器中。
上述模块的实现原理参见Kubernetes集群升级方法中的相关介绍,此处不再赘述。
图9是本发明的Kubernetes集群升级设备的结构示意图。下面参照图9来描述根据本发明的这种实施方式的电子设备900。图9显示的电子设备900仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图9所示,电子设备900以通用计算设备的形式表现。电子设备 900的组件可以包括但不限于:至少一个处理单元910、至少一个存储单元920、连接不同平台组件(包括存储单元920和处理单元910)的总线 930、显示单元940等。
其中,存储单元存储有程序代码,程序代码可以被处理单元910执行,使得处理单元910执行本说明书上述电子处方流转处理方法部分中描述的根据本发明各种示例性实施方式的步骤。例如,处理单元910可以执行1图2-图4任一实施例中所示的步骤。
存储单元920可以包括易失性存储单元形式的可读介质,例如随机存取存储单元(RAM)921和/或高速缓存存储单元922,还可以进一步包括只读存储单元(ROM)923。
存储单元920还可以包括具有一组(至少一个)程序模块925的程序/实用工具924,这样的程序模块925包括但不限于:处理系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。
总线930可以为表示几类总线结构中的一种或多种,包括存储单元总线或者存储单元控制器、外围总线、图形加速端口、处理单元或者使用多种总线结构中的任意总线结构的局域总线。
电子设备900也可以与一个或多个外部设备950(例如键盘、指向设备、蓝牙设备等)通信,还可与一个或者多个使得用户能与该电子设备 900交互的设备通信,和/或与使得该电子设备900能与一个或多个其它计算设备进行通信的任何设备(例如路由器、调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口960进行。并且,电子设备900还可以通过网络适配器970与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。网络适配器970可以通过总线930与电子设备900的其它模块通信。应当明白,尽管图中未示出,可以结合电子设备900使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储平台等。
本发明实施例还提供一种计算机可读存储介质,用于存储程序,程序被执行时实现的Kubernetes集群升级方法的步骤。在一些可能的实施方式中,本发明的各个方面还可以实现为一种程序产品的形式,其包括程序代码,当程序产品在终端设备上运行时,程序代码用于使终端设备执行本说明书上述Kubernetes集群升级方法部分中描述的根据本发明各种示例性实施方式的步骤。
根据本发明的实施方式的用于实现上述方法的程序产品,其可以采用便携式紧凑盘只读存储器(CD-ROM)并包括程序代码,并可以在终端设备,例如个人电脑上运行。然而,本发明的程序产品不限于此,在本文件中,可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
程序产品可以采用一个或多个可读介质的任意组合。可读介质可以是可读信号介质或者可读存储介质。可读存储介质例如可以为但不限于电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。
计算机可读存储介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了可读程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。可读存储介质还可以是可读存储介质以外的任何可读介质,该可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。可读存储介质上包含的程序代码可以用任何适当的介质传输,包括但不限于无线、有线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言的任意组合来编写用于执行本发明处理的程序代码,程序设计语言包括面向对象的程序设计语言—诸如 Java、C++等,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、作为一个独立的软件包执行、部分在用户计算设备上部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。在涉及远程计算设备的情形中,远程计算设备可以通过任意种类的网络,包括局域网(LAN)或广域网(WAN),连接到用户计算设备,或者,可以连接到外部计算设备(例如利用因特网服务提供商来通过因特网连接)。
综上,本发明的目的在于提供Kubernetes集群升级方法、系统、设备及存储介质,通过对Kubernetes集群中的组件进行滚动升级,滚动升级避免Kubernetes集群整体停机,除了当时升级的集群组件,其他组件都能对外提供服务。也是在这种情况下,在将接口服务器组件升级的情况下,保留旧版本接口服务器组件,这样对于无法适配新版本接口服务器组件的旧版本工作负载,可以继续适配旧版本接口服务器组件提供对外服务,减少Kubernetes集群组件不能对外提供服务或对外提供服务中断的问题。
以上内容是结合具体的优选实施方式对本发明所作的进一步详细说明,不能认定本发明的具体实施只局限于这些说明。对于本发明所属技术领域的普通技术人员来说,在不脱离本发明构思的前提下,还可以做出若干简单推演或替换,都应当视为属于本发明的保护范围。
Claims (12)
1.一种Kubernetes集群升级方法,其特征在于,包括:
从版本管理仓库中获取新版本Kubernetes集群组件镜像;
利用所述新版本Kubernetes集群组件镜像对旧版本Kubernetes集群组件进行滚动升级,升级到新版的Kubernetes集群组件;
在所述Kubernetes集群中的接口服务器组件从旧版本升级到新版本情况下,还保留旧版本接口服务器组件;
所述旧版本接口服务器组件用于提供对旧版本工作负载资源模型的调度服务。
2.根据权利要求1所述的Kubernetes集群升级方法,其特征在于,在所述Kubernetes集群中部署键值存储器,则利用所述新版本Kubernetes集群组件镜像对旧版本Kubernetes集群组件进行滚动升级,包括:
同步旧版本键值存储器中的数据到新版本键值存储器。
3.根据权利要求2所述的Kubernetes集群升级方法,其特征在于,在所述Kubernetes集群中部署索引库和资源模型转换器,所述索引库存储工作负载资源模型的各版本关键字的索引信息,则所述方法还包括:
在所述旧版本接口服务器组件发出资源调度请求的情况下,利用所述资源模型转换器截获所述资源调度请求,从所述资源调度请求得到所述工作负载资源模型的旧版本关键字;
利用所述旧版本关键字在所述索引库中查找所述旧版本关键字所对应的新版本关键字;
在所述资源模型转换器查找到所述新版本关键字的情况下,所述资源模型转换器将所述新版本关键字写入所述新版本键值存储器中;
在未查找到所述新版本关键字的情况下,所述资源模型转换器在所述资源调度请求中添加为工作负载与其宿主机节点打上旧版本标签的字段,并将所述旧版本关键字写入所述新版本键值存储器中。
4.根据权利要求1所述的Kubernetes集群升级方法,其特征在于,利用所述新版本Kubernetes集群组件镜像对旧版本Kubernetes集群组件进行滚动升级,包括:
利用所述新版本Kubernetes集群组件镜像,以容器化方式对所述旧版本Kubernetes集群组件进行滚动升级。
5.根据权利要求4所述的Kubernetes集群升级方法,其特征在于,从版本管理仓库中获取新版本Kubernetes集群组件镜像,包括:
从版本管理仓库中获取新版本控制面组件镜像和新版本工作面组件镜像;
利用所述新版本Kubernetes集群组件镜像,以容器化方式对所述旧版本Kubernetes集群组件进行滚动升级,包括:
利用所述新版本控制面组件镜像,以容器化方式对旧版本控制面组件进行滚动升级,升级到新版本控制面组件;
利用所述新版本工作面组件镜像,以容器化方式对旧版本工作面组件进行滚动升级,升级到新版本工作面组件。
6.一种Kubernetes集群升级系统,其特征在于,包括:
获取模块,从Kubernetes集群的版本管理仓库中获取新版本Kubernetes集群组件镜像;
升级模块,利用所述集群组件镜像对旧版本Kubernetes集群组件进行滚动升级,所述Kubernetes集群从所述旧版本升级到所述新版本;
保留模块,在Kubernetes集群中的接口服务器组件从旧版本升级到新版本情况下,还保留旧版本接口服务器组件;
所述旧版本接口服务器组件用于提供对旧版本工作负载资源模型的调度服务。
7.根据权利要求6所述的Kubernetes集群升级系统,其特征在于,在所述Kubernetes集群中部署键值存储器,则所述升级模块具体用于:
同步旧版本键值存储器中的数据到新版本键值存储器。
8.根据权利要求7所述的Kubernetes集群升级系统,其特征在于,在所述Kubernetes集群中部署索引库和资源模型转换器,所述索引库存储工作负载资源模型的各版本关键字的索引信息,所述系统还包括:
截获模块,在所述旧版本接口服务器组件发出资源调度请求的情况下,利用所述资源模型转换器截获所述资源调度请求,从所述资源调度请求得到所述工作负载资源模型的旧版本关键字;
查找模块,利用所述旧版本关键字在所述索引库中查找所述旧版本关键字所对应的新版本关键字;
写入模块,具体用于:
在所述资源模型转换器查找到所述新版本关键字的情况下,所述资源模型转换器将所述新版本关键字写入所述新版本键值存储器中;
在未查找到所述新版本关键字的情况下,所述资源模型转换器在所述资源调度请求中添加为工作负载与其宿主机节点打上旧版本标签的字段,并将所述旧版本关键字写入所述新版本键值存储器中。
9.根据权利要求6所述的Kubernetes集群升级系统,其特征在于,所述升级模块具体用于:
利用所述集群组件镜像,以容器化方式对所述旧版本Kubernetes所述集群组件进行滚动升级。
10.根据权利要求9所述的Kubernetes集群升级系统,其特征在于,所述获取模块具体用于:
从版本管理仓库中获取新版本控制面组件镜像和新版本工作面组件镜像;
所述升级模块具体用于:
利用所述新版本控制面组件镜像,以容器化方式对旧版本控制面组件进行滚动升级,升级到新版本控制面组件;
利用所述新版本工作面组件镜像,以容器化方式对旧版本工作面组件进行滚动升级,升级到新版本工作面组件。
11.一种电子设备,其特征在于,包括:
处理器;
存储器,其中存储有所述处理器的可执行指令;
其中,所述处理器配置为经由执行所述可执行指令来执行权利要求1至5任意一项所述Kubernetes集群升级方法的步骤。
12.一种计算机可读存储介质,用于存储程序,其特征在于,所述程序被处理器执行时实现权利要求1至5任意一项所述Kubernetes集群升级方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111484252.2A CN114172808A (zh) | 2021-12-07 | 2021-12-07 | Kubernetes集群升级方法、系统、设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111484252.2A CN114172808A (zh) | 2021-12-07 | 2021-12-07 | Kubernetes集群升级方法、系统、设备及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114172808A true CN114172808A (zh) | 2022-03-11 |
Family
ID=80483821
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111484252.2A Pending CN114172808A (zh) | 2021-12-07 | 2021-12-07 | Kubernetes集群升级方法、系统、设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114172808A (zh) |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111258609A (zh) * | 2020-01-19 | 2020-06-09 | 北京百度网讯科技有限公司 | Kubernetes集群的升级方法、装置、电子设备和介质 |
CN111782253A (zh) * | 2020-06-29 | 2020-10-16 | 中国工商银行股份有限公司 | 滚动升级控制方法、装置、设备及存储介质 |
CN111897558A (zh) * | 2020-07-23 | 2020-11-06 | 北京三快在线科技有限公司 | 容器集群管理系统Kubernetes升级方法和装置 |
US20210055947A1 (en) * | 2019-08-22 | 2021-02-25 | Sap Se | Configuration of decoupled upgrades for container-orchestration system-based services |
CN112905210A (zh) * | 2021-03-24 | 2021-06-04 | 青岛聚看云科技有限公司 | 服务器及灰度发布方法 |
CN113031993A (zh) * | 2021-04-26 | 2021-06-25 | 中国工商银行股份有限公司 | 基于集群容器的应用升级方法及装置 |
CN113672337A (zh) * | 2021-07-16 | 2021-11-19 | 广东浪潮智慧计算技术有限公司 | 一种应用迁移方法、装置、设备及计算机可读存储介质 |
-
2021
- 2021-12-07 CN CN202111484252.2A patent/CN114172808A/zh active Pending
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20210055947A1 (en) * | 2019-08-22 | 2021-02-25 | Sap Se | Configuration of decoupled upgrades for container-orchestration system-based services |
CN111258609A (zh) * | 2020-01-19 | 2020-06-09 | 北京百度网讯科技有限公司 | Kubernetes集群的升级方法、装置、电子设备和介质 |
CN111782253A (zh) * | 2020-06-29 | 2020-10-16 | 中国工商银行股份有限公司 | 滚动升级控制方法、装置、设备及存储介质 |
CN111897558A (zh) * | 2020-07-23 | 2020-11-06 | 北京三快在线科技有限公司 | 容器集群管理系统Kubernetes升级方法和装置 |
CN112905210A (zh) * | 2021-03-24 | 2021-06-04 | 青岛聚看云科技有限公司 | 服务器及灰度发布方法 |
CN113031993A (zh) * | 2021-04-26 | 2021-06-25 | 中国工商银行股份有限公司 | 基于集群容器的应用升级方法及装置 |
CN113672337A (zh) * | 2021-07-16 | 2021-11-19 | 广东浪潮智慧计算技术有限公司 | 一种应用迁移方法、装置、设备及计算机可读存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8812627B2 (en) | System and method for installation and management of cloud-independent multi-tenant applications | |
TWI509423B (zh) | 在叢集檔案系統間之同步更新 | |
US8832130B2 (en) | System and method for implementing on demand cloud database | |
CN102754104B (zh) | 在相关计算系统之间共享计算操作结果的系统和方法 | |
US6223345B1 (en) | System and method for building client and server application packages | |
JP2021515294A (ja) | マルチマスタ分散データ管理システムにおけるトランザクション処理 | |
CN101183379A (zh) | 用于检索数据的方法和系统 | |
US11010401B2 (en) | Efficient snapshot generation of data tables | |
CN102576354A (zh) | 支持不同部署架构的可扩展框架 | |
CN101449241A (zh) | 用于服务递送环境中的基于策略的改变管理的方法和装置 | |
CN103036855B (zh) | 一种权限管理的实现设备和方法 | |
US20050257211A1 (en) | Method and mechanism for managing incompatible changes in a distributed system | |
BRPI0701288B1 (pt) | sistema e método para gerenciar objetos de acordo com o modelo de informação comum | |
CN114461333A (zh) | 容器镜像创建和部署 | |
CN101159596A (zh) | 用于布置服务器的方法和设备 | |
US9378064B2 (en) | Orchestration management of information technology | |
US11182347B2 (en) | File sharing among virtual containers with fast recovery and self-consistency | |
US10579587B2 (en) | Space management for a hierarchical set of file systems | |
CN110119386B (zh) | 数据处理方法、数据处理装置、介质和计算设备 | |
US8930967B2 (en) | Shared versioned workload partitions | |
US10592479B2 (en) | Space management for a hierarchical set of file systems | |
WO2024001240A1 (zh) | 多种技术栈的任务集成方法及装置 | |
JP2021513137A (ja) | 階層型ストレージ管理システムにおけるデータ・マイグレーション | |
CN114172808A (zh) | Kubernetes集群升级方法、系统、设备及存储介质 | |
US10956512B2 (en) | Document link migration |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |