云架构(二) 大使模式

Ambassador pattern

https://learn.microsoft.com/en-us/azure/architecture/patterns/ambassador)

简单描述

创建一个助手服务,这个服务代表消费服务或者应用程序发送网络请求。大使服务可以看做是与客户机同一个位置的进程外代理。
这种设计模式可以用于承担常见的连接任务,例如监控,日志,路由,安全。并且可以以语言无关的方式进行弹性扩展。它经常用于历史遗留应用或者那些很难去修改的应用,用于扩展他们的网络功能,它同样可以由专门的团队去实现特性。

背景和问题

弹性云应用需要一些特性,例如熔断机制,路由,统计和监控,并且具有更新网络相关配置的能力,可能很难或者不可能去更新历史遗留应用或者在已有代码库上增加特性,因为这些代码很久没有维护或者开发团队很难去修改。
网络调用需要对连接、身份验证和授权进行大量的配置,如果这些调用使用在跨多个应用中,用多种语言和框架构建,这些调用必须在每个实例中都要配置。此外,网络和安全功能需要由组织内的中心团队去管理。对于大型代码库,团队成员去修改他们不熟悉的代码可能有风险。

解决办法

在另外一个进程中放入框架和库,在你的应用和其他服务之间作为一个代理。在应用所在的环境中部署一个代理,用以允许控制路由,弹性和安全特性,并且避免任何与主机有关的访问限制。你同样可以使用大使模式去标准化和扩展工具。代理可以监控性能指标,例如延迟、资源消耗,并且这种监控发生在与应用相同的环境中。
特性从大使卸载后也可以被应用单独管理,您可以在不影响应用程序遗留功能的情况下更新和修改大使。同样也可以考虑专门的团队去实现和维护已经被移动到大使中的安全、网络或者身份验证特性。
大使服务可以作为辅助工具部署,伴随消费应用程序或服务的生命周期。或者大使被一个公共主机的多个不同进程使用,它同样可以部署为一个守护进程或者windows服务。如果消费服务是容器化部署,大使应该在同一个主机上作为一个单独的容器创建,使用适当的链接配置去通信。

问题和考虑

代理增加了一些延迟开销。考虑应用程序直接调用客户端库是一个更好的方法。
考虑到代理包含的普遍特性可能产生的影响。例如,大使可以处理重试,但不是很安全,除非所有操作都是幂等的。
考虑一种机制,允许客户端将一些上下文传递给代理,以及返回给客户端。例如,包括HTTP请求头以选择不重试或指定重试的最大次数。
考虑如何打包和部署代理。
考虑是否使用单例或者每个客户端使用一个实例。

什么时候使用

需要为多语言或者框架构建一组通用的客户端连接特性。
需要将横切客户端连接问题卸载给基础设施开发者或者其他专业团队。
需要在历史遗留应用或者很难修改的应用中支持云或者集群连接需求。

不适合的场景

当网络延迟非常严重时,代理会有开销 ,虽然很小,在有些场景会影响到应用程序。
当客户端连接特性是由单一语言使用的。这种情况下,更好的办法是作为客户端库作为包分发给开发团队。
当连接特性不能通用化,并且需要和客户端应用程序深度集成。

示例

下面的图展示了应用程序经过了大使代理进行了一段远程请求。大使提供了路由,熔断和日志。它调用了远程服务并且给客户端机器返回了应答。

欢迎大家留言沟通

相关推荐
无心水30 分钟前
【分布式利器:大厂技术】4、字节跳动高性能架构:Kitex+Hertz+BytePS,实时流与AI的极致优化
人工智能·分布式·架构·kitex·分布式利器·字节跳动分布式·byteps
海市公约1 小时前
HTML网页开发从入门到精通:从标签到表单的完整指南
前端·ide·vscode·程序人生·架构·前端框架·html
Dxy12393102162 小时前
MySQL如何做读写分离架构
数据库·mysql·架构
---学无止境---3 小时前
i386 架构中断管理函数详解
linux·架构
Linux_Nathan7 小时前
【服务部署】ELFK架构篇之Elasticsearch
elk·elasticsearch·架构
Wang's Blog9 小时前
Elastic Stack梳理:Logstash持久化队列与高可靠数据处理架构深度解析
搜索引擎·架构·elastic search
@YDWLCloud9 小时前
用腾讯云国际版搭建全球加速架构:5 分钟实现多地访问提速
服务器·架构·云计算·github·腾讯云
櫻花9 小时前
微服务各大组件总结
微服务·云原生·架构
-大头.9 小时前
微服务架构深度演进与实践指南
微服务·云原生·架构
踏浪无痕9 小时前
我们是如何把登录系统从“一行JWT”升级成企业级SSO的?
后端·面试·架构