一种有状态容器跨集群实时迁移方法
2024-02-20汤红波许明艳
吴 宪 汤红波 赵 宇 许明艳
(解放军信息工程大学 郑州 450001)
(infinity_w@outlook.com)
随着网络结构的不断演进,包括边缘计算、物联网甚至5G 核心网等网络服务都将会部署在云化基础设施上[1-2]. 云化为5G 等网络服务带来软硬件解耦、切片友好运营等大量优势,但也使得网络服务更加依赖虚拟容器技术. 在云端虚拟容器面对集群硬件维护停机、集群负载失衡、云平台故障、服务容器升级、更换云供应商以及特殊服务需要时,经常需要使用有状态虚拟容器实时迁移技术[3].
针对虚拟化容器迁移技术的研究主要集中于同一集群内部的迁移方法优化,对跨集群容器迁移方法优化的研究相对较少,而且由于在实际工况下容器迁移应用场景经常面临跨集群的情况,该场景下物理存储介质不同导致容器在集群内部迁移方法无法应用,因此需要一种合理高效的迁移方法来缩短跨集群场景中的有状态虚拟容器迁移造成的服务停机时间. 在有状态虚拟容器跨集群迁移的过程中会存在3 个问题:
1) 当前用户空间中的检查点/还原工具(checkpoint/restore in userspace, CRIU)均采用一次性迁移全部状态文件的方法,当CRIU 状态文件过大或集群间网络传输速率过慢时,状态文件的迁移耗时会很长,将直接导致容器所提供服务的停机时间变得很长且不可控.
2) 同一集群内的虚拟容器迁移依赖底层存储硬件的访问共享,集群内迁移方法的高效执行均依赖硬盘、DRAM 以及内核的共享,而在跨集群场景中无法共享底层存储介质. 因此这些方法均无法在有状态容器的跨集群迁移过程中应用.
3) 在有状态容器跨集群迁移过程中,经常遇到集群间距离远、网络延迟长的问题,较高的网络延迟会对当前的一些迁移模型产生很大影响,导致对于迁移所需时间及服务停机时间的计算不准确.
为解决有状态容器跨集群迁移过程中网络延迟会导致服务停机时间长且不可控的问题,本文提出了一种针对网络延迟的迭代迁移算法. 本文具体贡献包括3 个方面:
1) 在有状态虚拟容器跨集群迁移中使用迭代迁移的方式,缩短服务停机时间;
2) 在跨集群容器迁移场景中重点考虑网络延迟,提出了一种迭代迁移模型,并确定了迭代过程的起始和终止条件,给出了最优迭代次数的计算方法;
3) 在模拟环境中的计算结果表明本文提出的迭代迁移算法能够在满足应用条件的情况下,有效缩短服务停机时间,并根据网络延迟的情况,停机时间可缩短至未采用迭代传输方法服务停机时间的25%以下.
1 相关工作
本文主要研究内容为通过迭代迁移的方法对有状态虚拟容器跨集群迁移进行优化以缩短服务停机时间,接下来将对当前虚拟容器迁移方法的优化和容器迭代迁移2 个方面的相关研究工作进行阐述.
1.1 集群内容器迁移优化相关研究
虚拟容器通过从内核隔离独立的命名空间和用户空间,实现容器中进程的虚拟化隔离. 一般虚拟容器由镜像、容器、网络和卷4 个部分组成[4].
镜像中包含运行应用程序所需的内容,是一个能够运行应用程序的基础. 容器则是镜像的实例,该实例包含了进程、日志和对原始文件系统的更改. 容器的迁移发生在2 个镜像实例间,即容器的进程运行状态和数据的迁移. 卷是容器的虚拟存储器,通常在主机上以共享文件夹的方式实现. 这些卷可以在1个或多个容器上挂载,能够永久存储所连接容器的程序运行状态和数据. 卷可以采用主机文件挂载的方式,使容器直接访问主机的共享文件夹. 因此容器迁移过程中,如何快速合理地迁移卷的内容就成为了关键. 目前虚拟容器的实时迁移主要通过CRIU 完成. 该工具可以暂停运行中的容器,将生成的状态文件迁移到目标容器后恢复运行状态[5-6].
Yin 等人[7]提出了一种根据集群内节点的负载率选择迁移目标节点的容器迁移优化方式,优化容器迁移后的各节点负载均衡,提高迁移后的服务性能. Venkatesh 等人[8]提出了一种将基于CRIU 的数据保存在虚拟地址空间(virtual address spaces, VAS)中的方法VAS-CRIU,利用其读写速度比磁盘快的特点提高容器迁移效率. Xu 等人[9]提出了对集群内容器迁移CRIU 功能的改进,使其能够迭代地迁移CRIU增量,达到缩短服务停机时间的目的. Lei 等人[10]则在容器迁移过程中使用马尔可夫模型预测内存访问模式,调整内存页面传输顺序,提高迁移过程中的内存读写效率. Lv 等人[11]则提出了通信感知最坏适应减少(communication aware worst fit decreasing, CA-WFD)算法作为集群内容器迁移的放置策略,这个算法巧妙地把经典装箱问题的最坏适应算法应用在了容器放置的场景中,该算法结合文献中提出的另一个用于确定容器迁移计划的扫描与搜索(Sweep&Search)算法,能够高效地制定迁移计划并将容器放置到最合适的地方,提高集群的整体性能. 该文献提出的算法在百度大型数据中心进行了应用,实际性能比当时最先进的容器迁移放置方法提高了70%.
集群内虚拟容器迁移的优化方法均要求源容器与目的容器能够共享、访问物理存储介质. 这是在跨集群容器迁移过程中无法做到的,因此这些优化方法不能直接应用在跨集群容器迁移的场景中.
1.2 跨集群容器迁移优化相关研究
虽然集群内容器迁移优化方法无法直接应用于跨集群容器迁移场景中,但其思路大体一致. 其中一部分方法经过改进摆脱对底层物理存储共享的依赖就可以在跨集群容器迁移过程中应用. 同时,相比集群内容器迁移,跨集群场景下多了一种针对网络传输过程的优化方法.
Di 等人[12]通过多线程并行迁移过程的方式更加合理地安排容器迁移的工作流程,提出了一种通过管道(pipeline)进行容器迁移的策略,降低迁移过程中的资源开销,提高资源利用率及容器的迁移性能.赵倩等人[13]利用远程直接内存访问(remote direct memory access, RDMA)技术跳过了迁移过程中内存数据写入磁盘的过程,节约了迁移时间. Stoyanov 等人[14]通过利用CRIU 的特性,即其独有的缓存/代理技术,达到了缩短容器迁移总时间和服务停机时间的目的.
除针对迁移过程中硬件及性能的优化工作以外,还有大量针对迁移过程自身展开的研究. 这部分研究通过改进容器迁移的流程来提高容器迁移效率,达到缩短停机时间的目标,迭代迁移就是这类技术之一.
迭代迁移实现思路是通过CRIU 等工具,对源容器的运行状态建立检查点(checkpoint)并传输状态文件. 但在checkpoint 建立过程、数据传输过程以及在目标容器内恢复过程中源服务并不停机,在第1 个checkpoint 传输完成后,将进程运行增量再次建立checkpoint 进行传输. 此过程不断迭代进行,达到缩短单次传输时间的目的,直至满足迭代终止条件,完成迁移过程. 完整迁移过程如图1 所示.
Fig. 1 Illustration of iterate migration process图1 迭代迁移过程示意图
Junior 等人[15]将迭代迁移的思路应用于跨集群容器迁移中,并通过实验证明迭代迁移能够缩短服务的停机时间. 但在研究及实验过程中由于没有考虑集群间网络延迟的影响,未能根据收益制定迭代过程的终止条件,无法确定最优迭代次数.
2 考虑网络延迟的迭代迁移算法
本节首先介绍算法所需的各个参数并根据模型列出计算重要参数的表达式,然后对使用迭代迁移的判定条件和终止条件进行计算,最后根据终止条件计算出最优迭代次数.
2.1 基本参数及表达式
设迁移过程总迭代次数为n,每个迁移过程分为3 个阶段,分别为快照拍摄阶段a、快照在集群间网络迁移阶段b 和快照恢复阶段c. 其中当整数x满足0 ≤x≤n−1时,第x+1个checkpoint 的快照拍摄、传输和恢复过程的总用时为Tx,单次迭代迁移过程中的源容器进程增量拍摄快照消耗的时间为Txa,快照从源容器网络传输到目标容器所消耗的时间为Txb,在目标容器中将快照恢复为进程状态所需要的时间为Txc(单位为ms),需要迁移的状态文件大小为Vx.
开始迁移时需要制作镜像的进程状态文件大小为V0,在迁移过程中进程状态文件的增长速率为ΔV.本文模型认为在容器迁移过程中目标容器与源容器性能完全相同,因此快照的拍摄与恢复的速率均为vP,进程状态文件快照的压缩率用K来表示.
根据跨集群迁移的实际情况,网络延迟经常会达到数十至数百毫秒,因此本文模型将网络延迟作为重要参数纳入考虑. 设源集群与目的集群间网络延迟为TL,传输速率为vT. 本模型所用迁移环境参数含义如表1 所示.
Table 1 Migration Environment Parameters表1 迁移环境参数
在本文模型中,我们假设容器迁移过程中两端的源集群和目的集群的性能相同,则可以认为在源容器中拍摄快照的速率与在目的容器中恢复快照的速率相同,即
因此第x+1个checkpoint 迁移过程的用时为
最后1 次迁移过程,即第n次迁移开始时,源容器停止服务,以防止迁移过程中产生新的进程增量,迁移过程完成后,在目标容器中恢复对用户的服务,整个迁移过程结束. 因此,对用户的服务停机时间即为第n次迁移的用时,可表示为
快照的拍摄速率与恢复速率均为vP,则可计算第x+1个快照镜像及恢复的用时为
因为在一次连续的网络传输过程中,网络延迟只产生1 次影响,所以能够得到镜像的网络传输用时:
将式(4)和式(5)代入式(2),可得
特别地,有
当1 ≤x≤n−1时,第x+1个进程状态文件大小Vx受Tx−1影响,可以得到:
将式(9)代入式(6),可得
令
则式(10)可化作等比数列:
求其通项公式,可得
将式(12)和式(13)带入式(14),可解得
2.2 迭代迁移的起始和终止条件
实际的跨集群容器迁移场景中,2 个集群性能稳定,因此本文模型以集群间的网络延迟TL的值作为迭代传输是否继续的判断依据.
在该迭代模型中,迭代传输的起始条件依赖的重要指标是T0与T1的差值,共存在3 种情况:
第1 种情况为满足条件T0−T1<0,此时有T0ΔV<T1ΔV⇒V1<V2,则每次迭代传输过程中需要传输的状态文件大小是递增的,即每次迭代传输消耗的时间也是单调递增的,传输过程总用时和对用户的停机时间会随着迭代次数的增加越来越高,迭代传输产生负收益. 因此应当通过一次传输完成整个迁移过程,即迭代次数为1,服务停机时间为第1 次的传输时间,即T=T0.
第2 种情况为满足条件T0−T1=0,此时有T0ΔV=T1ΔV⇒V1=V2,则每次迭代传输过程消耗的时间相同,迭代并没有起到缩短单次传输时间的效果,反而增加了集群的其他方面性能压力以及传输总时间.因此与第1 种情况相同,在该情况下也应当通过一次传输完成整个迁移过程,即迭代次数为1,服务停机时间为第1 次的传输时间,即T=T0.
第3 种情况为满足条件T0−T1>0,此时有T0ΔV>T1ΔV⇒V1>V2,每次迭代的传输过程消耗时间是单调递减的,迭代传输将缩短单次传输的消耗时间,对用户的停机时间随迭代次数的增加而缩短,迭代迁移的使用产生收益,此时应当使用迭代迁移方法. 因此迭代迁移的起始条件为T0−T1>0.
令T0−T1>0,将其带入式(10),可得
解此不等式,得
因此,当集群间网络延迟TL满足式(17)条件时,容器的迁移应采用迭代的方式. 将式(7)带入式(17),可得
式(18)即为迭代迁移的起始条件. 当TL的值不满足式(18)时,则不采用迭代迁移方法,通过1 次迁移完成容器的迁移过程,也可认为是迭代次数为1 的迭代迁移过程.
当满足条件需要进行迭代传输时,需要确定传输过程的迭代次数. 本文认为迭代迁移的停止条件为第x次迁移时间与第x+1次迁移时间的差不大于网络延迟TL时,网络延迟时间成为影响单次迭代时间的主要原因,且不受迭代过程影响,因此此时应停止迭代过程完成传输. 即有当
时,停止迭代过程完成传输,总迭代次数为x. 在满足迭代传输的条件下,一定有Tx−1>Tx,因此式(19)可展开为
因此式(20)为迭代迁移的终止条件.
2.3 迁移过程迭代次数的计算
将式(10)带入式(20),得到
将Tn的通项式(15)带入式(21),解得
根据式(17),结合网络延迟的物理意义可知,网络延迟TL为大于0 的实数,因此有
即
同时结合迭代次数n的物理意义,n为不小于1的正整数. 令总迭代次数n的值为式(22)结果向上取整,可得n的计算公式为:
当
时,n=1;
当
时,
3 实验设置
3.1 实验环境设置
本文提供的迭代迁移算法主要考虑网络延迟对迁移过程的影响,因此在实验环境的设置中保证了2 端集群和容器的硬件性能稳定,将集群间网络延迟的变化作为实验结果的重要影响因素.
本文将实验环境设置为较为典型的云平台性能条件,令开始迁移时的状态文件大小V0=100 MB,迁移过程中状态文件的增长速率 ΔV=0.03 MB/ms,checkpoint 快照拍摄速率与恢复的速率vP均为0.1 MB/ms,状态文件快照的压缩率K=68%,集群间的网络传输速率vT=0.2 MB/ms.
在本实验环境中,认为容器迁移过程中容器性能保持稳定,容器各性能的值在实验过程中不发生变化.
3.2 评价指标
针对本文主要研究目标,为验证本文所提出的迭代迁移方法的贡献,评价指标根据迭代迁移方法是否能够缩短服务停机时间和能够将服务停机时间缩短多少这2 方面进行划分:
1) 当集群间网络延迟满足式(18)时,通过迭代迁移的方式能否缩短服务停机时间;
2) 在不同的网络延迟条件下,采用迭代迁移方法能够将服务停机时间缩短多少.
根据本文所建立模型,不采用迭代迁移的一次性迁移方式,也可看作是迭代次数为1 的迭代迁移方式,其服务停机时间即为第1 次迭代迁移过程的时间T0. 迭代迁移过程的服务停机时间即为最后一次迭代迁移过程的时间Tn−1. 在本模型中,采用二者的比值
来表示迭代迁移方法缩短服务停机时间的效率,R值越低效率越高.
4 实验结果分析
4.1 迭代迁移有效性分析
根据迭代传输的起始条件式(18),将实验环境中各参数的值带入,计算得到满足条件的网络延迟TL<993.33. 为验证迭代传输判定条件的有效性,分别取5 种不同网络延迟TL1=1 200 ms,TL2=1 100 ms,TL3=993 ms,TL4=900 ms 和TL5=800 ms. 其中TL1和TL2不满足式(18)条件,TL3的值与起始条件值相近,TL4和TL5满足式(18)条件. 计算并绘制5 个条件下迭代过程的单次迭代传输时间Tn随迭代次数n的变化情况如图2 所示.
Fig. 2 Effect of the network latency on the iterative transmission time图2 网络延迟对迭代传输时间的影响
从结果中能够看出,当TL与式(18)计算所得迭代传输起始条件TL的值相同时,每次迭代的时间几乎没有变化. 图中TL3=993 ms 时,其对应的T0=3 333 ms而后续单次迭代传输时间为3 332 ms,主要原因为本文假设TL3=993 ms 与起始条件TL=993.33 ms 并非完全相同.
TL1与TL2大于式(18)计算所得迭代传输起始条件的值时,每次迭代传输的耗时是单调递增的. 综上可知,在网络延迟满足TL1=1 200 ms,TL2=1 100 ms,TL3=993 ms 这3 种情况时,迭代传输并没有缩短单次传输时间,也就是服务的停机时间,同时随着迭代次数的增加,也会增加对集群的性能压力和传输总时间.
TL4与TL5满足式(18)计算所得迭代传输起始条件的值时,能够看到每次迭代传输的耗时是单调递减的,此时迭代传输缩短了单次传输时间,达到了缩短服务停机时间的目的.
我们取3 个不同的满足迭代传输起始条件的网络延迟的值,分别为TL6=900 ms,TL7=600 ms,TL8=300 ms,计算并绘制单次迭代传输时间Tn随迭代次数n的变化情况如图3 所示.
Fig. 3 Effect of the network latency when the iteration conditions are met图3 满足迭代条件时网络延迟的影响
结合图2 与图3 所示,可以从中得出2 点结论:
1) 当网络延迟TL满足迭代传输起始条件时,传输过程中单次迭代传输时间随迭代次数的增加而缩短,迭代传输能够达到缩短服务停机时间的目的;
2) 网络延迟TL与起始条件值相差越大,相邻2次迭代间减少的传输时间越多,最终停止迭代时单次传输时间更低,即服务停机时间越短,迭代传输的收益越大.
4.2 迭代迁移收益分析
根据式(25)可知,当
时,n=1,化简可得
将式(7)带入式(29),计算并化简后解得
将模型中的各项参数值带入式(30),解得当网络延迟TL≥409.71 ms 时,总迭代传输次数为1,即因为每次传输过程受网络延迟TL影响较大,通过1 次传输完成容器迁移.
当网络延迟TL<409.71ms 时,迭代次数将大于1,可通过式(27)计算总迭代次数n. 根据计算结果,绘制总迭代次数随网络延迟TL变化的图像如图4 所示.
Fig. 4 Trend plot of the number of iterations varying with the network latency图4 迭代次数随网络延迟变化趋势图
从图4 中能够看出,总迭代次数是随着集群间网络延迟TL的增加而不断降低.TL增加单次传输时间的影响越来越大,收益越来越低,因此总迭代次数不断下降,直至总迭代次数为1.
实际环境中,跨集群间的网络延迟通常在30~500 ms 之间,可以看到本文建立的迁移模型在这个延迟区间的总迭代次数变化平稳.
在得到不同网络延迟对应的总迭代次数的基础上,结合式(28)计算不同网络延迟时迭代迁移方法能够提供的服务停机时间缩短的效率. 在网络延迟为100~400 ms 时,以50 ms 作为间隔,对服务停机时间缩短效率进行分析. 从表2 中可以看出,随着集群间网络延迟的降低,总迭代次数增加会使服务停机时间缩短的效率提高. 在网络延迟足够低时,甚至可将服务停机时间缩短至不使用迭代迁移方法停机时间的1/4 以内.
Table 2 Features Comparison of the Main Strategies with TLP Enhancing表2 提升TLP 的主要策略的特点对比
4.3 真实环境应用可能产生的问题
在真实的有状态容器跨集群迁移过程中,网络延迟和集群性能并非稳定,从4.2 节的分析结果来看,一次完整的迁移过程可能会持续数秒甚至数十秒,这个时间对于远距离的网络传输来说,很难保证性能持续稳定.
针对传输性能不稳定对传输过程造成的影响,我们分别从网络延迟和集群性能2 个方面来讨论.
1)在集群性能稳定的情况下,网络延迟TL的波动会对单次迭代传输时间Tx产生影响,进而会影响到下一次迭代过程中的状态文件大小,对后续的传输过程产生影响. 当传输过程中TL增大时,会使下一次迭代过程中的状态文件大小Vx变大,导致单次迭代传输时间变长. 但是由于网络延迟波动造成的意外情况,TL会随着后续的迭代过程再次缩短,最终导致的结果可能是,按照确定好的迭代次数完成整个容器迁移过程时,并不能满足迭代过程的终止条件Tx−1−Tx≤TL.
同时,网络延迟的变化存在着另一种变化方式,即传输过程中网络延迟TL变小. 这种情况可能会导致在达到确定好的迭代次数之前即满足终止条件Tx−1−Tx≤TL. 产生的后果是虽然已经满足了终止条件,却仍然在进行迭代过程,直至达到迁移过程开始前确定好的迭代次数为止. 这种情况下,会造成网络资源和集群性能的浪费.
2)集群性能的波动对传输过程的影响与网络延迟的影响类似,集群性能同样影响到当前传输过程的单次迭代传输时间Tx. 因此集群性能的降低所产生的影响与网络延迟增大所产生的影响一样,而集群性能的提高则与网络延迟降低对迭代迁移过程产生的影响一致.
本文方法中总迭代次数是根据性能参数在容器迁移过程开始之前确定的,因此迁移过程中性能的波动不会对总迭代次数产生影响,但会影响到后续的单次迭代传输过程的时长,可能会造成最后一次迭代过程不能满足终止条件,以及提前满足终止条件而对网络和集群性能造成浪费的情况.
5 结 论
本文提出了一种考虑集群间网络延迟的迭代迁移算法,提高了有状态容器跨集群迁移效率,缩短服务停机时间. 根据提出的迁移方法确定迁移过程的总迭代次数,并通过实验分析了迭代迁移对服务停机时间的缩短效率,证明了本文提出方法能够有效大幅度缩短有状态容器跨集群迁移过程导致的服务停机时间.
未来我们还将继续完善迭代迁移方法、优化方向有2 个:1)考虑优化迭代迁移过程,通过改进迭代方法提高迁移效率;2)根据实际迁移情况,考虑其他的迭代迁移终止条件. 对真实环境容器迁移过程中的性能波动更进一步分析,定量地研究迁移过程中网络延迟和集群性能对迁移过程终止条件的影响.
作者贡献声明:吴宪负责模型设计并完成论文撰写;汤红波改进模型,确定迭代迁移方式的收益计算方法并指导实验;赵宇提出实验方法并审核实验结果;许明艳指导论文写作,并设计和修改论文的插图.