原文 https://medium.com/netflix-te...
本文介绍了了内容配置工程团队使用Hollow,一个Netflix OSS技术,从新架构与简化咱们内容管道上的基础组件 - 在流程中交付巨大业务价值。git
每一个在Netflix服务上的电影和秀都被精心处理以提供最佳的观看体验。团队对处理主要负责标题运营(Title Operation)。标题运营会确认,除了:github
当标题达到了以上需求的最低要求,它就能够发布到服务上上线。Gatekeeper是在Netflix负责评估网站上视频和资产的“活跃度”。在Gatekeeper批准前标题对于会员是不可见的 - 若是它验证不了设置,它会指出从客户体验基线上缺了什么来辅助标题运营(Title Operation)。缓存
Gatekeeper经过聚合多个上游系统的数据来完成预处理任务,使用合适的业务逻辑,生产和输出每一个国家每一个视频的详细状态。微信
Hollow, 是咱们几年前发布的OSS技术。并被描述为一种靠近缓存的全高密度(total high-density near cache)技术:架构
对于这个全(total)技术有一个使人兴奋的内容 - 由于咱们不须要担忧清除内存中的数据项,咱们能够对内存中的数据集展现作一些假设与预计算,没有这个特性是不可能的。结果是,对许多数据集,提升了很大的内存使用效率。而在传统的部分缓存方案上你可能会想是否你只缓存了5%的数据集,或者你须要被10%保留足够的空间用来获得一个可接受的命中/丢失率 - 使用一样的内存Hollow能够缓存100%的数据集数据并获得100%的命中率。ide
很明显,若是你有100%的命中率,你能够消除全部访问你数据的IO需求 - 并能够更有效的提升数据访问效率,能够开启更多可能性。网站
在不久之前,Gatekeeper是一个彻底的事件驱动系统。当任何上游系统对视频有改动,系统会发送给Gatekeeper发送一个事件。Gatekeeper会对那条事件进行响应,进入每个它的上游服务,收集必要的输入数据来评估视频与它的对应资产的活跃性。它会产生一条输出记录来输出这条视频的详细状态。编码
这个模型有一些相关的问题:spa
为了减轻这些问题能够“清扫”目录让视频能够匹配特定的查询条件(好比,计划下周上线)可让事件自动注入处处理队列中。不幸的是,这种方式会往队列中增长更多的事件,会使问题更加恶化。.net
很明显,颇有必要改变方向。
本文来自微信公众号「麦芽面包,id「darkjune_think」转载请注明。微信扫一扫关注公众号。交流Email: zhukunrong@yeah.net