- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个包含 10 个微服务的微服务架构,每个微服务都提供一个客户端。在由微服务团队管理/控制的客户端内部,我们只接收参数并将它们传递给通用 http 调用程序,该调用程序接收端点和 N 参数,然后进行调用。
所有微服务都使用 http 和 web api(我猜技术无关紧要)。
对我来说作为微服务团队提供客户端没有意义,应该是消费者的责任,如果他们想创建一些抽象或直接调用它是他们的问题,而不是微服务问题。我将 Web API 视为一种契约。所以我认为我们应该删除微服务端的所有客户端(将责任传递给消费者),并在消费者端创建一个使用通用调用程序到达端点的服务层。
下图代表所有组件,其中 红线定义 边界,谁负责什么 :
最佳答案
我在工作中也有类似的设置,有几个微服务(约 40 个)和十几个团队。我被问了好几次同样的问题,我的回答是 消费者负责消费 .如果 API 按设计和预期工作,则无需让提供团队负责任何事情。
提供服务的团队(a 团队), 5 月 提供客户,如果他们愿意(有疑问,没有保证)。消费队(B队) 5 月 如果 使用客户端他们想要(承担所有风险)。
唯一的契约(Contract)应该是 API,其他一切都应该是团队可以提供的好东西。如果团队一个 有 提供一个客户,他们为什么要提供一个api呢?
鉴于两个团队松散耦合并且可能使用不同的技术(或例如不同的 spring 框架版本),向另一个团队提供客户端库被证明带来的问题比解决任何问题都多。在 Java+spring-boot 世界中,例如你很快就会陷入依赖问题,特别是如果你包括来自不同服务提供团队的几个客户,这些客户随着时间的推移而不同。
更糟糕的是:如果 A 团队的客户端库使 B 团队的系统不稳定并引入错误怎么办?现在谁负责解决这个问题?
如果您想减少消费团队所需的工作,因为重新编码客户端需要大量工作,那么您的 API 可能会很复杂和/或您的微服务可能根本不再是微服务。
想象一下在一个安静的 API 上使用 HATEOAS - 为它编写一个客户端只是几行代码,即使包含 API 浏览器、文档和诸如此类的东西。见例如spring-rest-docs、hal-browser、swagger 和各种其他技术,使阅读/浏览/记录 API 和实现客户端变得轻而易举。
上面的案例是用两个团队描述的,想象一下有 10 个。我们有一个由一个团队提供的“客户端库”,被其他 4 个团队使用。你可以猜到它在被删除之前变成一团糟的速度有多快:)
关于distributed-computing - 每个微服务的客户端 vs 通用客户端 |谁负责微服务客户端?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45515650/
是否可以使用 boost::compute 复制自定义结构数组?例如 struct A { float a; }; struct AB { float a; float b; }; BOOST_COM
有谁知道如何在项目上配置的Google Cloud Networks之间移动现有的VM实例?我知道您可以在创建新VM时指定网络,但是似乎没有一种实例化它即可对其进行更改的功能。 任何指针表示赞赏! 保
我正在尝试遵循Google云平台控制台上的教程,以使用Compute Engine创建MongoDB应用程序。我遵循创建虚拟机的教程,但未创建它们,并返回以下错误: 字段“resource.netwo
我想知道是否可以将一个实例的类型更改为另一个实例,例如: n1-standard-1至n1-standard-2 我在文档中没有看到任何内容,但可能是我错过了一些东西。 如果这是不可能的,我该如何处理
我正在尝试让我的GCE实例监听多个IP地址(出于SEO的原因-在同一实例上托管多个低流量站点)。 最终目标:mydomain.com指向IP1,myotherdomain.es指向IP2,GCE实例将
使用scp,我可以添加-r标志以通过ssh将目录下载到本地计算机。 使用时: gcloud compute scp -r 它说“ -r”不是可用选项。 没有-r,我会收到一条错误消息,说我的源路径是一
仅某些IP地址的http负载均衡器存在严重问题。 我在这里还看到了其他一些帖子。我们确保防火墙正常,甚至删除并重新创建了转发规则。自IP更改以来,这非常令人讨厌。 仍然没有喜悦。问题仅影响某些IP地址
我正在尝试删除/删除不再使用的静态IP地址,并且看不到执行此操作的方法。我可以从文档中得到的最接近的是this page,它说: When an instance is stopped, you ca
我每天从台式计算机运行一个简单的任务 3 次。它在下午 4 点、晚上 8 点和凌晨 1 点连接到某个网站,下载少量数据(小于 50mb),并将其存储在硬盘上。每天运行这一点很重要,所以我正在考虑将其转
我是一个关于在Google Compute Engine上联网的问题。 是否可以在您的帐户上设置默认的“源代码/ IP范围”,以便在创建新规则时自动设置此值? 例如,如果我创建此规则: gcloud
我正在尝试使用 POST gcloud CLI 创建一个“带有容器”的 GCE 实例(由 https://www.googleapis.com/compute/v1/projects/{project
我们像这样通过命令行创建实例: gcloud compute instances create instance-name [--stuff otherstuff] --metadata-from-f
在我的本地 macOS 上,以下命令运行良好: $ gcloud source repos clone myrepo --project=myproject (虽然我不确定它是否有效,因为之前我遵循了
在 AWS SDK , EC2实例可以通过 AmazonEC2Client 以编程方式启动.是否GCP一般或Compute Engine特别just offer the CLI-based gclou
我想使用 SparkleShare 在计算机之间同步文件,所以我正在寻找一种方法让 git 存储库在线保存文件。 我正在考虑使用 Google Compute Engine 来托管它们。如果我只为我实
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 4年前关闭。 Improve thi
几周前,我在随意玩弄 Google Cloud Console,并创建了一个 Compute Engine VM。这个过程就像“创建一个虚拟机,命名它,保存”一样简单,就是这样。我现在不需要 Comp
我正在关注 this instruction在 GCE 上设置多个实例或服务器集群。它运行良好,但我不知道如何更新应用程序代码。例如,我有一些错误修复,需要更新代码并重新加载所有实例。无论如何我可以做
我在两个 VM 实例上有一个 node.js 应用程序,我试图通过网络负载平衡来进行负载平衡。为了测试我的服务器是否已启动并提供服务,我在我的应用程序内部监听端口上收到了运行状况检查请求“/healt
如何在GCE中永久设置实例的主机名?我可以通过主机名进行设置,但是重启后它又消失了。 我试图输入元数据(主机名:f.q.d.n),但这没有完成。但是它应该通过元数据(https://github.co
我是一名优秀的程序员,十分优秀!