Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Knot.x vs application architecture: Monolithic vs Microservice #507

Open
malaskowski opened this issue Dec 17, 2019 · 1 comment
Open

Knot.x vs application architecture: Monolithic vs Microservice #507

malaskowski opened this issue Dec 17, 2019 · 1 comment

Comments

@malaskowski
Copy link
Member

malaskowski commented Dec 17, 2019

Context
Let's discuss on how Knot.x impacts application architecture choice. Being more specific, which architecture approach does Knot.x promote: Monolithic vs Microservice.

Describe the solution you'd like
A solid comparison of two architecture approaches when using Knot.x as part of the application. Differences between using Knot.x in monolithic vs microservice architectures with simple examples. Also, basic recommendation when use one or another approach and finally, what are advantages of using Knot.x in any of them.

Additional context
If Knot.x enables it, describe (in form of blog post or documentation) how to switch one architecture to another (preferably monolithic to microservice, which will be the most common). How Knot.x supports such transitions, what are prerequisites, when to do that.

@malaskowski
Copy link
Member Author

malaskowski commented Dec 17, 2019

Microservices

Approach 1 - Remote Nodes

There is an idea on "Remote Nodes" (just working name) that are actually a Microservices. They can be grouped into tasks as standard (local) nodes now (also combining both in a single task should be possible). There will be a contract defined exactly the same as for normal nodes (input: Fragment, output: modified Fragment + Transition).
For now, 2 ways to communicate with Remote Nodes were identified:

  • via Vert.x Event Bus
  • via HTTP e.g. using RestAPI exposed by the microservice

Remote Nodes

The internals of Remote Node is not known to a task, only the contract matters. Of course, the Remote Node can also use Fragment processing and have its actions. But what is also very important, any service can be used (e.g. written in Spring, PHP or Go) as a Remote Node, when communicating via HTTP.

Pros

  • any technology can be selected to write a microservice (the only requirement is keeping the Fragment contract)
  • microservices communicating via Event Bus does not have to worry about having its own HTTP Server
  • complicated scenarios can be designed as a graph OOTB, which makes them easier to understand
  • some of the behaviours are available OOTB (like Circuit Breaker) and can wrap "Remote Nodes"

Cons

  • there is a Fragments contract, that each microservice need to follow (Fragment -> Fragment' + Transition)

Approach 2 - pure Rest API

Communication between microservices takes place via HTTP (Rest APIs). Each microservice, have its own HTTP Server with simple RestAPI exposed and additionally it may use Fragments processing to produce the output. Each microservice defines its own API, there are no restrictions on working on Fragment. Also, there might be other technologies used to create a microservice (e.g. Spring, PHP or Go), the only contract is their API.

pure Rest API

Pros

  • any technology can be selected to write a microservice
  • microservices are not bound to any specific Rest API contract, they define it themselves

Cons

  • each microservice needs an HTTP Server to expose Rest API
  • stability patterns such as Circuit Breaker must be implemented independently, when communicating with each microservice via Rest API

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant