内容简介:基于云的弹性应用一般需要具有断路器、路由、计量和监控功能,但是对一些遗留应用来说,要更改它们使得具备这些特性却很困难,因为很多应用都没有人继续维护了,或者你没有权限修改源代码。如果非要加入这些特性的话怎么办呢?答案是,你可以使用代表模式(Ambassador pattern)。代表模式可以解决这个问题,它的结构图大致如下:上面图中的Application是主应用程序,也可以看成是遗留应用。Ambassador就是添加的代理,一般部署在独立的进程中,但是和遗留应用部署在同一台机器(Host)上。代理实现的功能
1. 缘由
基于云的弹性应用一般需要具有断路器、路由、计量和监控功能,但是对一些遗留应用来说,要更改它们使得具备这些特性却很困难,因为很多应用都没有人继续维护了,或者你没有权限修改源代码。如果非要加入这些特性的话怎么办呢?答案是,你可以使用代表模式(Ambassador pattern)。
2. 解决方案
代表模式可以解决这个问题,它的结构图大致如下:
上面图中的Application是主应用程序,也可以看成是遗留应用。Ambassador就是添加的代理,一般部署在独立的进程中,但是和遗留应用部署在同一台机器(Host)上。代理实现的功能主要有:请求重试、断路保护、计量监控、安全保护。如果有多个Application,也可以共享使用一个代理,这时候代理往往以Windows服务或 Linux 后台进程的形式部署。添加代理后,可以起到分担应用程序负载的一个作用,而且还可以将工作量分派出去,让其它团队来维护代理的更新和部署。
3. 需要考虑的问题
添加代理后,也会有一些问题存在。首先是性能问题,如果是应用性能极为敏感的应用,可能就不适合添加代理。还有就是,某些逻辑功能是否要加进代理需要认真考虑,比如重试逻辑,在请求非幂等的情况下可能会破坏原有程序的逻辑。此外,还有考虑代理的部署方式,以及多个应用是否共享一个代理还是每个应用一个代理。
4. 具体示例
上面说的都是理论,我们要看一下,添加代理后,具体的请求流程是怎样的,如下图所示:
上面的流程中,应用发起远程请求后,首先进入到代理进程,代理进程具有路由、断路、日志等功能,并将请求转发到远程服务,最后再将结果数据返回给应用程序。
微信扫码,进入【技术人成长】社群逛逛。
以上所述就是小编给大家介绍的《云设计模式之: 代表模式》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 设计模式——订阅模式(观察者模式)
- 设计模式-简单工厂、工厂方法模式、抽象工厂模式
- java23种设计模式-门面模式(外观模式)
- 设计模式-享元设计模式
- Java 设计模式之工厂方法模式与抽象工厂模式
- JAVA设计模式之模板方法模式和建造者模式
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
C程序设计语言
(美)Brian W. Kernighan、(美)Dennis M. Ritchie / 徐宝文、李志译、尤晋元审校 / 机械工业出版社 / 2004-1 / 30.00元
在计算机发展的历史上,没有哪一种程序设计语言像C语言这样应用广泛。本书原著即为C语言的设计者之一Dennis M.Ritchie和著名计算机科学家Brian W.Kernighan合著的一本介绍C语言的权威经典著作。我们现在见到的大量论述C语言程序设计的教材和专著均以此书为蓝本。原著第1版中介绍的C语言成为后来广泛使用的C语言版本——标准C的基础。人们熟知的“hello,World"程序就是由本书......一起来看看 《C程序设计语言》 这本书的介绍吧!
JSON 在线解析
在线 JSON 格式化工具
HTML 编码/解码
HTML 编码/解码