AuTO:扩展深度强化学习以启用数据中心级自动流量优化--论文阅读笔记

sigcomm'18--香港科技大学

摘要:

目前DRL(深度强化学习)算法的时延过大,不能直接应用于处理流级别的数据中心流量优化,因为短流在决策未生成之前已经结束了。

基于数据中心的流量分布类型为长尾分布,本文提出了两级DRL系统:周边(PS)和中枢系统(CS)。PS位于终端,收集流信息,在本地为短流作出决策,保证最小时延,但PS的决策还是由CS干预的。CS拥有全局流量信息,为长流作出决策。实验搭建在32个服务器的实验床上,相比现有方法,AuTO将RTT从几周降低到了100毫秒,同时提高了性能。平均FCT也比现有方法降低了48.14%。

简介:

问题:现有TO算法依赖于人工启发式算法,依据为流量负荷,流量大小分布,流量密集度等分量分布状况。存在问题有:1)TO算法的参数设置与真实情况不匹配,造成性能下降。举例:PIAS,pFabric,Aalo。2)已存在的TO启发式算法的RTT太长,以周为单位。因为需要很长的时间收集应用信息,流量数据信息,才能设置启发式算法的相关参数。举例: 部署监测系统,收集足够多的数据分析,设计启发式算法,仿真优化工具寻找合适参数,最后在实验床上测试启发式算法。这一完整的周期很长。

动机:强化学习是机器学习的分支,主要用于决策和动作控制。现有领域在深度学习方面取得了成果:DeepMind的Atari结果,AlphaGo等等。受到这些启发,本文尝试在数据中心TO方面应用DRL工具。一个流调度的小测试验证了单一的集中式TO系统在大规模的数据中心(10的5次方台服务器)中不能满足短流的需求,存在决策速度慢,无用的问题,因此本文才尝试用分层TO架构。

关键:AuTO可扩展的关键将耗时的DRL算法处理与需要快速采取动作的短流处理分开。解决方案为在PS系统采用多级反馈队列(MLFQ)和一组门限值进行流调度。每条新流都是最高优先级,随着发送的字节数增加,优先级会降低。这样,PS系统就会根据本地信息(发送字节数和门限值)对每条流进行快速决策。门限值由CS系统通过DRL算法优化,更新周期会较长。对于长流来说,CS系统会使用另一种DRL算法确定路由,速率和优先级。

实验测试:搭建环境为32台服务器和2台交换机。流量模式为固定的负载和流分布,对比方案为标准的启发式算法(最少工作优先和最小服务优先),训练时间为8小时,平均FCT降低了8.71%。

背景和动机:

介绍了DRL模型,通过小型流调度实验证明现有DRL系统处理时延过长,不能满足数据中心级TO。

AuTO设计:

两级系统:PS运行在终端,为短流做TO决策,CS为长流做决策。

AuTO系统

PS系统:

根据CS下发的一组门限值和流的大小,为流打上不同的优先级标签,从而确保PS系统仅仅根据本地信息就可以为短流作出全局最优决策。分为执行模块和监测模块。

MLFQ-多级优先级反馈队列

执行模块:采用MLFQ(最早在PIAS中出现)为短流分配优先级。优先级字段填充在IP头部的服务类型字段中的DSCP字段中(占6个比特)。这样每条流就可以在终端根据发送的字节数和门限值快速打上相应的优先级标签。这样,长短流自然就分开了,对于长流,CS也可以单独做决策(路由策略,速率限制和优先级)。

监测模块:主要用来收集已完成流的大小、流完成时间。CS根据收集信息更新流分布模型。同时,检测系统也需向CS报告即将到来的长流信息,以便CS及时作出决策。

CS系统:

4队列的AuTO系统示例

CS系统由两种DRL代理(agent)组成:短流代理(sRLA)和长流代理(lRLA)。短流代理解决最小化FCT的问题,使用DDPG算法,用来更新门限值;长流使用PG(策略梯度)算法生成长流的路由、速率、优先级。

DRL理论分析

优化MLFQ门限值:

难点在于计算最优门限值。之前的工作提供了计算门限值的数据分析,并且建议更新周期为周或月。AuTO的优化目标是在连续的动作空间中寻求一个真实的最优值。将门限值优化问题看做一个DRL问题,用DNN网络模拟复杂的数据中心网络。

将门限值优化转化为M/M/1排队模型:到达时间服从泊松分布,服务时间服从指数分布,先到先服务,队列长度无限制,可加入队列的人数无限。假设流分布的累计密度函数为F(x),表示流大小不大于x的概率,Li表示给定流在队列Qi中引入的数据包的数量, 则E[Li]≤(αi-αi-1)(1-F (αi-1))。流到达速率为λ,则队列Qi中数据包到达速率为λi=λE[Li ]。假定链路服务速率为μ,则Q1的服务速率为μ,空闲概率为1-ρ1,ρi表示服务被占用的概率。imax (x)表示大小为x 的流的大于x的最小门限值的下标。

队列i的服务速率
数据包在Qi中的逗留时间
T(x) :大小为x的流的平均FCT

则最小化FCT即可表示为:

最小化FCT数学表达

状态空间:一组已完成流的属性集合。每条流有7个属性:五元组、流大小、流完成时间。100条短流

动作空间:一组MLFQ门限值{αi,t}

反馈函数:前一时刻与当前时刻目标函数的比值。

优化长流:

使用PG算法,优化长流。

动作空间:每条流对应优先级,限速,路径(路径的枚举方式与XPath相同)

状态空间:未结束的流(11条长流):五元组,优先级;已经结束的流(10条长流):五元组,流大小,FCT

反馈函数:通过已经结束的流获得。每条已完成流的吞吐量为流大小与流完成时间的比值。则反馈函数设置为两个连续时间所有已完成流的平均吞吐量的比值。

(a)反馈函数  (b)单一流的吞吐量计算公式

系统实现部分:

语言Python2.7,深度学习框架Keras,PS和CS系统是通过RPC接口通信的。

PS系统:

监测模块:在linux内核中实现是最高效的,但现有方案是在流发生器中实现的。一个周期为T秒,MM收集已结束的流(7个属性)(10条长流,100条短流),未结束的流(6个属性)(11条未结束的长流)信息,并将其整合通过RPC接口发送给CS。收集流的个数是由流量负载和采样周期决定的。

执行模块:在linux内核实现。周期性接收CS下发的一组门限值和本地长流的路由、限速、优先级信息。对于短流,用ECMP选路和负载均衡,这样就不需要对每条流进行集中式控制和拥塞控制。对于长流,EM利用相同的linux内核模块为长流打上优先级标签。在限速操作上,使用TCHTB实现。HTB队列“控发不控收”。EM首先建立一个父类的HTB队列,将速率设置为CS指定该节点的总出口带宽。当某条流到达最低优先级队列时,EM通过HTB过滤器匹配流的五元组为其设置CS下发的速率。速率上限为min{原始速率,CS下发的速率的两倍}。

CS系统:

借鉴了SEDA系统架构,分为三块:HTTP请求处理、深度网络学习或处理、回复发送。使用三个进程分别实现,进程之间使用队列,这样避免了Python实现过程中的全局锁问题。超参数(架构,神经网络层数,节点数等)的选择由经验得出。

评估:

1.在固定的流大小分布和流量负载分布情况下,AuTO性能与标准启发式算法相比:平均FCT降低了48.14%

2.当流量特征变化时,AuTO能够适应这种变化吗:四组服务器分别生成不同流大小分布的流量,测试结果为平均流完成时间降低了37.20%

3.AuTO在多长时间内可以应对流量特征变化:四组服务器的流量模式周期性变化,性能稳定,优于标准启发式算法。

4.AuTO的整体性能开销和可扩展性如何:平均10ms就可以完成门限值等更新,传统算法需要几个月或者几周。对于PS系统,CPU利用率和吞吐量的开销也显著下降。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352

推荐阅读更多精彩内容