微信扫一扫
分享到朋友圈

Workflow设计模式:让你在大规模数据世界中君临天下 | 极客时间

作者:InfoQ 来源:InfoQ 公众号
分享到:

05-07

作者:蔡元楠,Google Brain 资深工程师,极客时间《大规模数据处理实战》专栏作者。  

你好,我是蔡元楠。我在《大规模数据处理实战》专栏中,为大家分析了批处理和流处理,利用好这两种处理模式,作为架构师的你就可以运筹帷幄,根据实际需求搭建出一套符合自己应用的数据处理系统了。   

      

然而,光是掌握了这两种数据处理模式就能应对大规模数据世界中的需求挑战吗?从我的实战经验中看来,其实未必。

我们每个人在最开始学习大规模数据处理的时候,可能都是以 WordCount 作为教学例子来进行学习的。

WordCount 这个例子,只需要一个单词集合作为输入,数据处理的结果是统计单词出现的次数,中间只需要经过一次数据处理的转换,就如同下图所示。



但在现实的应用场景种中,各式各样的应用需求决定了大规模数据处理中的应用场景会比 WordCount 复杂很多倍。

我还是以我在《大规模数据处理实战》第一讲中所提到过的例子来说明吧。


(扫码可以免费试读)

在根据活跃在街头的美团外卖电动车的数量来预测美团的股价这个例子中,我们的输入数据集有可能不止一个。

例如,会有自己团队在街道上拍摄到的美团外卖电动车图片,会有第三方公司提供的美团外卖电动车数据集等等。整个数据处理流程又会需要至少 10 个处理模块,每一个处理模块的输出结果都将会成为下一个处理模块的输入数据,就如同下图所示。


像上面的图示一样,我们将这种由多个不同的处理模块连接在一起,最后得出一个自己需要结果的有向无环图(Directed Acyclic Graph/DAG),称为一个工作流系统(Workflow System)。

在工作流系统的每个处理模块里,系统要执行的操作有可能不是单单一个数据转换的操作这么简单。像在上面例子的 Ingestion 这个模块中,我们需要将多个不同的数据集合并在一起,也需要将不合格的一些图片过滤掉。

如果你用过 Apache Spark 1.4 以上的版本的话,Spark 平台里面的 Execution DAG 就可以为你展示一个完整的工作流图。

今天,我为你解释四种工作流系统的设计模式,希望你能够很好地理解它们,并运用在自己的数据处理系统设计中。在遇到各种复杂的应用场景的时候能够从容面对。

复制模式(Copier Pattern)

第一种,是复制模式。

复制模式通常是将单个数据处理模块中的数据,完整地复制到两个或更多的数据处理模块中,然后再由不同的数据处理模块进行处理。工作流系统图通常如下图所示。


当我们在处理大规模数据时,需要对同一个数据集采取多种不同的数据处理转换,我们就可以优先考虑采用复制模式。

我来举个在 YouTube 视频平台中,系统处理视频数据集的一个例子吧。

我们都知道,视频平台很多时候都会提供不同分辨率的视频。4K 或 1080P 的视频可以提供给网络带宽很高的用户。而在网络很慢的情况下,视频平台系统会自动转换成低分辨率格式的视频,像 360P 这样的视频给用户。

而在 YouTube 视频平台中,如果你将鼠标放在视频缩略图上,它会自动播放一段已经生成好的动画缩略图(Animated GIF Thumbnail )。不仅如此,在平台的背后,一个视频的数据集可能被自然语言理解(NLP)的数据处理模块分析,用以自动生成视频字幕;还有可能被视频分析的数据处理模块分析,用以产生更好的内容推荐系统。那么,它的整个工作流系统就会如下图所示一样。 


我们可以看到,在这个工作流系统中,每个数据处理模块的输入是相同的,而下面的 5 个数据处理模块都可以单独并且同步地运行处理。

过滤模式(Filter Pattern)

第二种,是过滤模式。

过滤模式的作用是过滤掉不符合特定条件的数据。

在数据集通过了这个数据处理模块后,数据集会缩减到只剩下符合条件的数据。工作流系统图通常如下图所示。


当我们在处理大规模数据时,需要针对一个数据集中某些特定的数据采取数据处理时,我们就可以优先考虑采用过滤模式。

我举个商城会员系统的例子来解释吧。

在商城会员系统中,系统通常会根据用户的消费次数、用户消费金额还有用户的注册时间,将用户划分成不同的等级。

假设现在商城有五星会员(Five-stars Membership)、金牌会员(Golden Membership)和钻石会员(Diamond Membership)。

而系统现在打算通过邮件,只针对身份是钻石会员的用户发出钻石会员活动邀请。这个时候,我们就可以通过过滤模式,将钻石会员的用户从所有用户中筛选出来,如下图所示。


在这个工作流系统中,一个数据处理模块会将输入的数据集过滤成符合条件的数据,然后传输到下一个数据处理模块进行单独处理。

分离模式(Splitter Pattern)

第三种,是分离模式。

如果你在处理数据集时并不想丢弃里面的任何数据,而是想把数据分类为不同的类别来进行处理时,你就需要用到分离模式来处理数据。它的工作流系统图通常如下图所示。


需要注意的是,分离模式并不会过滤任何数据,只是将原来的数据集分组了。

还是以刚刚商城会员系统为例。假设现在商城有五星会员、金牌会员和钻石会员。

系统现在打算通过邮件,针对全部的会员用户发出与他们身份相符的不同活动的邀请。

这个时候,我们就可以通过分离模式将用户按照会员等级分组,然后发送相应的活动内容,如下图所示。


需要注意的是,在分离模式下,同样的数据其实是可以被划分到不同的数据处理模块的,例如下图


数据 B 是可以同时划分到工作流 1 和工作流 2 中。其实这种情况挺常见的,我可以给你举个例子来解释。

在北美的银行系统上,用户可以通过勾选以短信通知或者以邮件通知的方式来提醒用户一笔交易成功。如果用户同时勾选了短信和邮件两种方式,那么属于这个用户的交易信息既会通过短信通知的数据处理模块来处理,也会通过邮件通知数据处理模块来处理。

合并模式(Joiner Pattern)

第四种,是合并模式。

合并模式会将多个不同的数据集转换集中到一起,成为一个总数据集,然后将这个总的数据集放在一个工作流中进行处理。工作流系统图通常如下图所示。


还是以根据活跃在街头的美团外卖电动车的数量来预测美团的股价这个例子来说吧。

数据接入这一处理模块里,我们的输入数据有自己团队在街道上拍摄到的美团外卖电动车图片和第三方公司提供的美团外卖电动车图片。

如果我们打算先整合所有数据然后进行其它数据处理的话,工作流系统图通常如下图所示。


小  结

接下来我为这一讲做个小结。

今天我们一起学习了在大规模数据处理中用到的四种设计模式,分别是复制模式、过滤模式、分离模式和合并模式。在设计大规模数据处理系统的时候,我们都希望能事先设计好一个工作流系统图出来作为参考。

有了这样一个大规模数据处理的整体蓝图之后,对于我们理解不同的处理模块是如何相互关联或者对未来优化系统设计是有很大帮助的。

如果你希望在大规模数据领域有所成长,想了解硅谷式的技术领导力与批判性思维。推荐给你我的专栏《大规模数据处理实战》,我将与你分享 Google 的大数据处理前沿技术和思维。

专栏会通过大量的硅谷最佳实践,从实际场景出发引导你进行独立思考,帮助你从普通工程师成长为大规模数据处理技术专家。

拼团仅需¥79/3 人成团

(限时 24 小时)


点击阅读原文,即可免费试读专栏

阅读39884
天下 
举报0
关注InfoQ微信号:infoqchina

用微信扫描二维码即可关注
声明

1、头条易读遵循行业规范,任何转载的稿件都会明确标注作者和来源;
2、本文内容来自“InfoQ”微信公众号,文章版权归InfoQ公众号所有。

评论
更多

文章来自于公众号:

InfoQ

微信号:infoqchina

邮箱qunxueyuan#163.com(将#换成@)
微信编辑器
免责声明
www.weixinyidu.com   免责声明
版权声明:本站收录微信公众号和微信文章内容全部来自于网络,仅供个人学习、研究或者欣赏使用。版权归原作者所有。禁止一切商业用途。其中内容并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。如果您发现头条易读网站上有侵犯您的知识产权的内容,请与我们联系,我们会及时修改或删除。
本站声明:本站与腾讯微信、微信公众平台无任何关联,非腾讯微信官方网站。