如何管理在开发(而非测试)环境中使用多个微服务并对其进行模拟?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何管理在开发(而非测试)环境中使用多个微服务并对其进行模拟?相关的知识,希望对你有一定的参考价值。

我正在使用Spring Boot 1.5.9,我们有一个与另一个微服务连接的微服务。

用于集成测试和开发(开发人员计算机),我想模拟/存根对另一个微服务的其余调用。对于单元/集成测试,已经多次回答了这个问题:WireMock,MockBean和MockRestServiceServer是很好的工具。但是for development我正在尝试找出最佳方法。

为什么?启动实际微服务所依赖的每个微服务是一个问题。因此,我们的想法是使微服务独立并启动,而无需在开发人员的机器上或其他地方运行任何其他服务器。因此,一个简单的`mvn spring-boot run'就足以启动我的微服务并开始工作,而无需担心其他微服务。

所以,我的问题是:在开发中建议的模拟/存根休息方法是什么?在这种情况下,Wiremock也是一种很好的方法?

我的项目

我在src/main/java/resources/中有两个配置文件:“默认”(application.properties,用于另一个环境)和“ dev”(application-dev.properties,用于开发)。

在我的测试(src/test/java/resources/)中,我只有一个application.properties,这是application-dev.properties的基本副本。

我已经尝试使用Wiremock进行集成测试,并且效果很好。但是我也不想将其用于开发,因为我不太喜欢在JAR中引入仅用于开发的依赖项的想法。我的意图是使用相同的策略来集成测试和开发。

那么,有什么选择?

答案

因此您想在本地启动微服务,例如用于手动测试,但您不想启动它依赖的所有其他微服务。

团队执行以下任一操作:

  • 将本地微服务连接到共享的,已部署的微服务实例(登台环境)
  • 将本地微服务连接到其他微服务的易于启动的Docker映像
  • 连接到模拟某些/所有其他微服务的单个本地运行的Wiremock实例。您可以为此单独启动Wiremock,与微服务分开启动
  • 编写其他微服务的最小限度的轻量级定制模拟(仅在必须执行某些业务逻辑时比Wiremock更好)
  • 不连接任何东西,但是从内部API客户端返回伪值。
  • 实际上是在本地启动所有其他微服务

其中哪一种最适合您取决于您​​的环境,以及其他微服务依赖项到底提供了什么功能。您不能期望其中的任何一个都是最适合所有团队和所有情况的银弹。

另一答案

有一个名为OTDD-在线测试驱动开发]的开源项目。它将入站请求/响应及其相应的出站请求/响应记录为在线测试,然后将其用于本地开发和测试。

这个主意很好地解决了您的麻烦。在这里看看https://otdd.io

以上是关于如何管理在开发(而非测试)环境中使用多个微服务并对其进行模拟?的主要内容,如果未能解决你的问题,请参考以下文章

微信公共号网页开发开发环境获取微信授权

在微信开发框架中增加对菜单分组的管理,方便多个项目自由切换处理和功能测试

如何在多个微服务中管理安全上下文

如何在从单体架构过渡到微服务架构之间管理多个暂存环境

微信云托管如何实现一套代码对应多个环境

微服务太杂乱难以管理?一站式服务治理平台来袭!