政务公开既网站信息化建设会议,青岛开发区网站,做cpa没有网站怎么办,杨谦教授编的营销课程Ambassador pattern
#xff08;https://learn.microsoft.com/en-us/azure/architecture/patterns/ambassador#xff09;
简单描述 创建一个助手服务#xff0c;这个服务代表消费服务或者应用程序发送网络请求。大使服务可以看做是与客户机同一个位置的进程外代理。 这种…Ambassador pattern
https://learn.microsoft.com/en-us/azure/architecture/patterns/ambassador
简单描述 创建一个助手服务这个服务代表消费服务或者应用程序发送网络请求。大使服务可以看做是与客户机同一个位置的进程外代理。 这种设计模式可以用于承担常见的连接任务例如监控日志路由安全。并且可以以语言无关的方式进行弹性扩展。它经常用于历史遗留应用或者那些很难去修改的应用用于扩展他们的网络功能它同样可以由专门的团队去实现特性。 背景和问题 弹性云应用需要一些特性例如熔断机制路由统计和监控并且具有更新网络相关配置的能力可能很难或者不可能去更新历史遗留应用或者在已有代码库上增加特性因为这些代码很久没有维护或者开发团队很难去修改。 网络调用需要对连接、身份验证和授权进行大量的配置如果这些调用使用在跨多个应用中用多种语言和框架构建这些调用必须在每个实例中都要配置。此外网络和安全功能需要由组织内的中心团队去管理。对于大型代码库团队成员去修改他们不熟悉的代码可能有风险。 解决办法 在另外一个进程中放入框架和库在你的应用和其他服务之间作为一个代理。在应用所在的环境中部署一个代理用以允许控制路由弹性和安全特性并且避免任何与主机有关的访问限制。你同样可以使用大使模式去标准化和扩展工具。代理可以监控性能指标例如延迟、资源消耗并且这种监控发生在与应用相同的环境中。 特性从大使卸载后也可以被应用单独管理您可以在不影响应用程序遗留功能的情况下更新和修改大使。同样也可以考虑专门的团队去实现和维护已经被移动到大使中的安全、网络或者身份验证特性。 大使服务可以作为辅助工具部署伴随消费应用程序或服务的生命周期。或者大使被一个公共主机的多个不同进程使用它同样可以部署为一个守护进程或者windows服务。如果消费服务是容器化部署大使应该在同一个主机上作为一个单独的容器创建使用适当的链接配置去通信。 问题和考虑 代理增加了一些延迟开销。考虑应用程序直接调用客户端库是一个更好的方法。 考虑到代理包含的普遍特性可能产生的影响。例如大使可以处理重试但不是很安全除非所有操作都是幂等的。 考虑一种机制允许客户端将一些上下文传递给代理以及返回给客户端。例如包括HTTP请求头以选择不重试或指定重试的最大次数。 考虑如何打包和部署代理。 考虑是否使用单例或者每个客户端使用一个实例。 什么时候使用 需要为多语言或者框架构建一组通用的客户端连接特性。 需要将横切客户端连接问题卸载给基础设施开发者或者其他专业团队。 需要在历史遗留应用或者很难修改的应用中支持云或者集群连接需求。 不适合的场景 当网络延迟非常严重时代理会有开销 虽然很小在有些场景会影响到应用程序。 当客户端连接特性是由单一语言使用的。这种情况下更好的办法是作为客户端库作为包分发给开发团队。 当连接特性不能通用化并且需要和客户端应用程序深度集成。 示例
下面的图展示了应用程序经过了大使代理进行了一段远程请求。大使提供了路由熔断和日志。它调用了远程服务并且给客户端机器返回了应答。 欢迎大家留言沟通