快手_ 部署GPU服务器:快手为2亿日活用户保驾护航

日活2亿人以上的速度,库存短视频超过130亿部,以每天上传1500万部以上的短视频的速度新增,拥有庞大的数据应用场景。 快速基础设施规模已经居国内顶尖网络公司之首。 目前,快速服务器规模已超过10万台,数据总量达到EB水平,每天新增的数据超过5PB。

为了确保千亿级别的数据处理和基础设施稳定、高效运行,快速服务器选择和业务优化团队(以下简称“快速SAT团队”)首次选择了合作伙伴NVIDIATesla V100GPU和下一代Turing体系结构NVIDIA T4GPU

速手SAT团队成员经验丰富,人均工作经验10年左右,其中专注于硬件的成员多来自国内外大型服务器和硬件制造商,专注于软件的成员多来自国内头部互联网企业。 这样的软硬结合团队,为速度超过2亿的日活水平提供了坚实的保障。

据快手SAT团队的研究开发人员介绍,快手大数据的应用场景如视频推荐平台、语音视频理解、风控、商业广告、强化学习等是公司的核心业务,多种业务场景的数据处理需求大,NVIDIA推出新的Tesla产品后, SAT团队以部署T4和TeslaV100 GPU为首要任务,使用下一代GPU结合现有的计算平台将T4部署到新集中,同时以最快的速度适应公司核心业务,确保硬件基础设施处于业界领先地位。

GPU体系结构优化性能提高了一倍,成本降低了30%

对于快速增长的业务需求,不仅需要尽可能满足业务灵活性的变化需求,而且还需要考虑成本优化的目标,这些目标不仅不能分散课程数量,而且面临的问题非常复杂。 为了最大限度地平衡需求和复杂性,快速SAT团队最终部署了两组GPU,并且决定虚拟化容器以满足不同的业务场景需求。

在实际计算中,GPU服务器(特别是多GPU服务器)经常面临CPU性能成为瓶颈的问题。 为了解决CPU性能瓶颈、GPU使用率低的问题,快速SAT团队和算法团队以在Resnet50/SSD上将Resize、Augment等从CPU侧转移到GPU侧的方式,将CPU的加载逐渐转移到GPU上

GPU之间的性能平衡是另一个问题。 某些业务场景中的模型体积非常大,单GPU视频内存通常无法存储整个模型。 在这种情况下,通常模型存在于存储器中,CPU进行对应的运算操作,因此快速SAT团队通过优化CPU亲和性,避免了负荷的不均匀和探索路径远的问题。

速手训练模型要求精度高,以前一般使用FP32,但模型大,现在逐渐使用混合精度取代原方案,性能显着提高。 在实际使用中,快手SAT队也容易使用AMP (自动混合精度),但发现不能适应所有的业务。 因此,有必要尝试快速SAT和业务团队不同的方法,结合FP32、AMP和手动混合精度等手段,为业务侧训练提供最佳的计算性能。

推理模型相对于训练模型,batch size较小的问题较多,需要频繁的读写存取存储器,并且推理比训练所要求的精度不那么高。 为了在解决这些问题的同时更好地利用新体系结构的Tensor Core性能,快速SAT团队在第一时间部署TensorRT,使业务能够在GPU中快速使用,大大提高了运行速度,编译后的代码所占的内存

H264:T4 / P4 = 2.6倍左右解码Hevc:T4/P4 = 4倍左右的解码. 对于Hevc的高性能,对于T4的两个nvdec引擎在解码Hevc时允许更多的计算单元

T4的Fast Preset和P4的Slow preset在质量和同时数上几乎相同。

与文本类ification相比,tensorrt-inflatione-server的性能提高了大约两倍

如上图所示,当前的GPU计算体系结构优化使业务性能平均提高了一倍,成本比以往节约了30%以上。

采用硬软结合优化着地

为了更好地改善新产品的特性,快速SAT团队提供了一系列的工艺计划。 了解业务使用需求后,通过分析当前瓶颈点和高频使用资源,合理选择硬件产品,将这些产品快速集成到包装中。 新硬件通常伴随新框架和指令集的支持,例如对FP16的T4支持,以显着改进T4性能。 借鉴这些新功能,事业部部门优化了代码,使其在线实施。 使用Vtune/Nsight等工具分析代码,优化效率低下的部分,最终显示最佳效果后提高灰度,追求高效快速的技术。

(图:选择快速卡爪时的流程)

(图:快速手机新硬件/新技术部署平台模块)

自定义监控以预防故障

如果说使用是第一步的话,那么运输维度是第二步。 快手SAT队就GPU的监视做了三件事。 一是自主开发的GPU使用率监测,二是定制的GPU故障监测,三是GPU故障预测。

通过监视GPU的使用率,业务可以更好地了解自己的负荷状况,验证之前选定的构成的合理性。 通常,在行业中大多使用smi中的GPU-Util参数来判断GPU的使用状况,但在实际的使用状况下,判断GPU的使用率是复杂的问题,GPU-Util所响应的不仅是每单位时间的GPU的整体使用状况,不能明确地反映GPU的负荷状况 针对这种情况,快手SAT团队手动开发了使用率监视脚本,从SM单元、编解码器单元的采样值、带宽负荷、读写时间比等多个维度进行了分析,最终导出了GPU的综合使用率。

故障监视是比较早就成为话题的问题,在任何硬件产品中都会遇到。 由于GPU的高功耗和温度以及对业务的强依赖性,最初的快速SAT团队设立了很多监视指标,这些监视指标都是由GPU设备的API提取出来的,但随着监视事例的增加,警报的数量也大幅增加。 这些警告包括持久警告、波动警告和相关警告。 当然,这些警告使得速手能够在最初的时间发现问题,但也给速手的运输业者带来了很大的麻烦。 为了解决报警泛滥的问题,快速SAT团队对监控参数进行了分析整合,针对不同业务使用GPU时的不同需求,制定了业务生死标准:影响业务生存的标准优先报告,单位时间内发生的报警只报告一个。

该故障的预测判断的正确性很重要,以防止可能发生的故障对业务造成损害。 故障的预判往往是导线,是随着时间的推移逐渐达到现象水平的过程。 快速SAT队列在故障的事前判定中,在GPU中设定十几个监视参数,通过训练这些存储的数据得到阈值,使用该阈值进行故障的事前判定。 通过这个训练预测循环过程,使故障的预测越来越准确。

下一个计划

随着快速日活量的增加,用户数据越来越丰富,模型数量越来越多,越来越复杂,空间占有也呈几何级数增长。 目前,快手SAT团队正在做一些事情。 采用高容量、低成本的NVM和GPU构成异构存储服务器100G/200G/400G RDMA的组合,创建CPU offload体系结构,将提高分布式计算效率的存储资源与计算资源分开。

快速选择在线流程和NVIDIA企业级技术支持团队已经有1年以上的合作经验,以最新的GPU部署为契机,快速SAT团队整理了GPU服务器部署和应用优化的一系列科学体系,在实践中获得了良好的业务优势,快速节省了大量时间成本, 同时,计算能力更强的GPU计算体系结构也为未来快速重要业务线的复杂模型奠定了坚实的基础。

大家都在看

相关专题