首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >微服务中的公共逻辑

微服务中的公共逻辑
EN

Stack Overflow用户
提问于 2019-09-23 06:57:06
回答 2查看 298关注 0票数 1

我们开发了5-6个微服务,按照微服务原则彼此独立地拥有自己的数据库。

现在,我们正在重构服务,并面临以下困境。

  1. 所有微服务都从ActiveMQ发送和接收消息。
    • 在所有这些服务中,ActiveMQ ( JmsListenerContainerFactory,Handler等)锅炉板代码的配置细节都在重复。

  1. 所有微服务都有审计功能(例如:对订单创建、更新和删除的审计)。- AOP逻辑相关的配置也在所有这些微服务中重复。

将这些公共逻辑转移到库或公共服务是一种好做法吗?请建议一下。

谢谢,

EN

回答 2

Stack Overflow用户

发布于 2019-09-23 07:50:45

当我开始在工作中使用微型服务的时候,我也在同一条船上。

我们已经确定了以下“共同”的地方。当然,这份清单并不满,只是想给出一个想法:

  • 消息传递基础设施(生产者/消费者、pub-sub),与您的情况类似。
  • 计量基础设施(我们已经用于千分尺的一些扩展)
  • 日志配置(相同的附加程序、模式、windows/linux/mac os机器的略有不同的行为等)
  • 弹簧致动器扩展部分(附加端点)
  • 错误处理
  • 关系数据库配置扩展(执行器健康检查,一些驱动程序扩展,等等)

我们提供的解决方案是从maven的角度提供一种不同类型的工件。这将有包装罐,并将不依赖于弹簧引导(除了必要的部件,如执行器的API,如果需要)。

我们已经从上面提到的列表中创建了一个maven模块,它本身就有一个能够加载所有所需bean的@Configuration。如果您希望使用“自动配置”来解决这个问题,请考虑使用"spring工厂“。我们使用过这种方法,它对我们非常有用。或者,如果您希望更显式,您可以创建一个注释,比如@EnableXYZ,它将实质上导入jar模块的配置:

代码语言:javascript
运行
复制
 @Target(ElementType.TYPE)
 @Retention(RetentionPolicy.RUNTIME)
 @Import({CommonErrorHandlingConfiguration.class})
 public @interface EnableErrorHandling {

 }

 ...

 @Configuration 
 public class CommonErrorHandlingConfiguration {
   // beans relevant for error handling appear here
 }

在本例中,有一个名为common-error-handling的模块,它包含上述两个类。

现在,您的微服务将它作为依赖项,可以使用这个@EnableErrorHandling注释来激活CommonErrorHandlingConfiguration

我们还发现有两种类似的公共库。与所有微服务(如日志记录、计量等)相关的内容,以及与一个微服务相关、与另一个微服务完全无关的内容。

因此,作为一种解决方案,我们已经将所有的微服务类型jars (带有spring引导插件、集成测试等等)从一个“公共-微服务”pom.xml中扩展出来,它实际上定义了所有这些公共依赖项。

因此,如果每个微服务与所有服务相关,就没有必要重新定义它们的依赖关系。

还值得一提的是,这种方法只有在所有微型服务共享相同技术的情况下才能起作用,否则在相同情况下使用侧车容器可能更合适。

票数 6
EN

Stack Overflow用户

发布于 2019-09-23 07:34:05

正如@harkesh kumar所建议的那样,您可以提供所有微服务都可以在general.The依赖项中使用的依赖关系,该依赖关系的体系结构应该具有灵活性,以便采用依赖关系的不同微服务能够根据它们的需要进行更改。

例如,您可以将ActiveMQ配置作为要添加的独立依赖项提供,同时通过application.yml键提供自定义,或者重写配置( manually.That )方式--所有不需要默认配置的微服务都可以这样做。

朗读

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58057114

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档