Micro services: shared library vs code duplication

前端 未结 3 1373
长情又很酷
长情又很酷 2021-01-02 16:39

Similar questions were asked a few times, but as every use-case can be different I thought it worth to ask it again with the specific case I\'m facing with. So, we are devel

相关标签:
3条回答
  • 2021-01-02 16:53

    When it comes to model classes, I say duplicate code. The entire idea of using JSON or some other language independent protocol instead of serialized native Java objects (for example) is to avoid side-effects of class changes in one microservice rippling throughout your entire ecosystem. A shared library of model classes locks multiple microservices into a polygamous marriage contract where divorce precipitated by even small disagreements between a pair of members can be very expensive. Service A may require changes to its model that not only are unneeded by Service B, but might be totally incompatible with it.

    This doesn't mean that code cannot be shared across different microservices. There's nothing wrong with sharing libraries among different microservices as long as their functionality is limited to addressing cross-cutting concerns. Perhaps your common timeout and retry functionality you mentioned falls in the category. Model classes that do nothing but hold a data representation of a language independent protocol do not fall into this category in my opinion.

    0 讨论(0)
  • 2021-01-02 17:00

    Of course there is DRY rule in programming. But, as Sam Newman said in his book "Building Microservice": Don't Repeat Yourself inside one microservice.

    Common entities: Let's look at your example with ResponseC. Imagine that something in ServiceB has changed so now one of the field from the response have changed - now you have to update each service that uses this shared library, even if the service don't need this changed field. If you had the ResponseA, ResponseB and ResponseC for each service, you didn't had to update each service with the new dependency.

    Common logic: Basically the same rules are applied here. However it's common to use some third party libraries for common microservices issues like time-outs and retries. What else I can suggest is to look at service mesh implementation like istio and linkerd. Service mesh will give the possibility to these issue to the infrastructure layer so you can focus on writing business logic.

    0 讨论(0)
  • 2021-01-02 17:00

    I agree with the comments above in preferring duplicating the class code. I went down the road of distributing shared classes via an internal NuGet server and it didn’t work well. The different microservice consumers of the JSON started out using the NuGet class, but soon were asking for changes that would break the others. All consumers eventually ignored the NuGet class and created their own.

    0 讨论(0)
提交回复
热议问题