pexels.com |
The number of Internet users is increasing rapidly. So in order to handle massive loads, we need such a technology which can be used. In the past, we had or even now most applications have a monolithic structure. This architecture is easy to use for small functional applications. All codebase stay in one bundle(repository). Once an application getting complex logic, it will be hard to add another function or debugging. Another disadvantage is to handle high loads. Yes, you can say that you can upgrade memory of server. But, it is costly.
In such a scenario, we can apply Microservice architecture to our application. There are plenty of plus sides:
- All services separated and can be developed n number of developer in any language.
- If one functions fails to perform, rest of logic still works.
- It easy apply load balancing solutions.
- You can choose multiple databases for your application.
- You can use latest HTTP protocol. For example, HTTP2/3
- Easy to scale.
Now, you can imagine how it works by analyzing picture below.
ncube.com |
API Gateway - connects all endpoints into a single point. This means, all your services call to API Gateway using RPC calls. We can use GRPC, then time transmission will increase by 10x by comparing simple REST API. GRPC uses HTT2 protocol and you need code Proto in order to keep type of messages. Golang language is perfect for building API Gateway for its high speed.
Here useful links:
https://ncube.com/blog/microservices-vs-monolithic-which-architecture-suits-best-for-your-project
https://microservices.io/patterns/apigateway.html
https://github.com/nodirshox/nodejs-service
Comments
Post a Comment