114 | Go编程模式:Pipeline
下载APP
关闭
渠道合作
推荐作者
114 | Go编程模式:Pipeline
2021-01-14 陈皓 来自北京
《左耳听风》
课程介绍
讲述:杨超
时长03:24大小3.10M
你好,我是陈皓,网名左耳朵耗子。
这节课,我着重介绍一下 Go 编程中的 Pipeline 模式。对于 Pipeline,用过 Unix/Linux 命令行的人都不会陌生,它是一种把各种命令拼接起来完成一个更强功能的技术方法。
现在的流式处理、函数式编程、应用网关对微服务进行简单的 API 编排,其实都是受 Pipeline 这种技术方式的影响。Pipeline 可以很容易地把代码按单一职责的原则拆分成多个高内聚低耦合的小模块,然后轻松地把它们拼装起来,去完成比较复杂的功能。
HTTP 处理
上节课,我们有很多 WithServerHead() 、WithBasicAuth() 、WithDebugLog()这样的小功能代码,在需要实现某个 HTTP API 的时候,我们就可以很轻松地把它们组织起来。
原来的代码是下面这个样子:
通过一个代理函数:
我们就可以移除不断的嵌套,像下面这样使用了:
Channel 管理
当然,如果你要写出一个泛型的 Pipeline 框架并不容易,可以使用Go Generation实现,但是,我们别忘了,Go 语言最具特色的 Go Routine 和 Channel 这两个神器完全可以用来构造这种编程。
Channel 转发函数
首先,我们需要一个 echo()函数,它会把一个整型数组放到一个 Channel 中,并返回这个 Channel。
然后,我们依照这个模式,就可以写下下面的函数。
平方函数
过滤奇数函数
求和函数
用户端的代码如下所示(注:你可能会觉得,sum(),odd() 和 sq() 太过于相似,其实,你可以通过 Map/Reduce 编程模式或者是 Go Generation 的方式合并一下):
上面的代码类似于我们执行了 Unix/Linux 命令: echo $nums | sq | sum。同样,如果你不想有那么多的函数嵌套,就可以使用一个代理函数来完成。
然后,就可以这样做了:
Fan in/Out
动用 Go 语言的 Go Routine 和 Channel 还有一个好处,就是可以写出 1 对多,或多对 1 的 Pipeline,也就是 Fan In/ Fan Out。下面,我们来看一个 Fan in 的示例。
假设我们要通过并发的方式对一个很长的数组中的质数进行求和运算,我们想先把数组分段求和,然后再把它们集中起来。
下面是我们的主函数:
再看我们的 prime() 函数的实现 :
我来简单解释下这段代码。
首先,我们制造了从 1 到 10000 的数组;
然后,把这堆数组全部 echo到一个 Channel 里—— in;
此时,生成 5 个 Channel,接着都调用 sum(prime(in)) ,于是,每个 Sum 的 Go Routine 都会开始计算和;
最后,再把所有的结果再求和拼起来,得到最终的结果。
其中的 merge 代码如下:
整个程序的结构如下图所示:
参考文档
如果你还想了解更多类似的与并发相关的技术,我再给你推荐一些资源:
好了,这节课就到这里。如果你觉得今天的内容对你有所帮助,欢迎你帮我分享给更多人。
分享给需要的人,Ta购买本课程,你将得29元
生成海报并分享
赞 17
提建议
© 版权归极客邦科技所有,未经许可不得传播售卖。 页面已增加防盗追踪,如有侵权极客邦将依法追究其法律责任。
上一篇
113 | Go编程模式:修饰器
下一篇
115 | Go 编程模式:Kubernetes Visitor模式
精选留言(5)
- Geek_Fantasy2021-01-20判断一个数是否是质数的方法可以优化一下。只需要枚举到value的平方根就可以,可以把复杂度从O(n)降到O(sqrt(n))。4
- ano2022-09-03 来自北京merge 中的 wg.Wait() 为什么必须要放到一个单独的 goroutine 中呢?
- Geek_ce69712022-01-29pipeline 最后返回 <- chan 类型,就像 java stream编程的输出流
- 方勇(gopher)2021-12-27Pipeline使用场景还是很多的,在做任务发布的时候会经常用到
- 你为啥那么牛2021-08-16没看明白 你是怎么分组的共 1 条评论