1. The Use of API Gateway API Gateway The following three scenarios will be used in my analysis. Open API Enterprises need to open up their own data, capabilities, etc. as development platforms, usually in the form of REST. The best examples are Taobao Open Platform, Tencent's QQ Development Platform, and WeChat Open Platform. The Open API open platform will inevitably involve the access of customer applications, the management of API permissions, the management of call times, etc. There will inevitably be a unified entrance for management, which is when the API gateway can play a role. Microservice Gateway The concept of microservices was first proposed in 2012. With the vigorous promotion of Martin Fowler, microservices have been vigorously developed since 2014. In the microservice architecture, there is a component that can be said to be indispensable, that is, the microservice gateway, which handles load balancing, caching, routing, access control, service proxy, monitoring, logging, etc. The API gateway exists in the microservice architecture as a microservice gateway. API Service Management Platform The above microservice architecture may be difficult for enterprises to implement. Enterprises have many legacy systems, and extracting all of them into microservices will require too much modification and be too costly for enterprises. However, since there are a large number of API services calling each other between different systems, it is necessary to manage the service calls between systems, clearly see the call relationships between each system, and monitor the calls between systems. API gateway can solve these problems. We can think that if the microservice architecture is not implemented on a large scale, then the microservice gateway is the API service management platform of the enterprise. 2. The position of API gateway in the overall enterprise architecture As the complexity of an enterprise's information system increases, there will inevitably be external partner applications, the enterprise's own public network applications, and enterprise intranet applications. These three types of applications should be distinguished in the architecture, and the arrangement levels and access methods of the three applications are also different. Therefore, in my design, these three applications are managed by different gateways, namely: API Gateway (OpenAPI partner application), API Gateway (internal application), API Gateway (internal public network application). 3. How to use API Gateway in enterprises 1. For the API gateway used by OpenAPI, partners generally need to access the OpenAPI platform in the form of applications, and partners need to apply for applications on the OpenAPI platform. Therefore, in addition to the OpenAPI gateway, there needs to be a platform for partners to use, which requires the OpenAPI gateway to provide an API for this user platform to access. The following architecture: Of course, in simple scenarios, it may not be necessary to provide a portal for partners. The company's operations staff can directly add partner application IDs/keys, etc. In this case, there is no need for a partner portal subsystem. 2. For the API gateway of the intranet, it can be considered as a microservice gateway or an API service governance platform of the intranet. When an enterprise manages all applications using the microservice architecture, the API gateway plays the role of a microservice gateway. When an enterprise only uses REST API to access calls between systems and uses API gateway to manage the calls, the API gateway plays the role of API service governance. The architecture reference is as follows: 3. For the company's internal public network applications (such as APP, company website), if the management is more meticulous, it is possible that an independent API gateway can handle this part of the internal public network applications in the architecture. If you want a simpler processing, you can also use an API gateway for partners. If you use a separate API gateway, there are the following benefits:
Based on the above analysis, if the company has the ability, it is recommended to use the partner OPEN API gateway and the internal public network application gateway separately. 4. What are the competing solutions for API Gateway? 1. For the API gateway of the Open API platform, I analyzed that the API gateway can only be chosen as a solution. The industry has not found any other better solution that can be used as the entrance to the Open API platform. 2. For API gateways that serve as microservice gateways, the industry has many options for solutions to choose from, which also depends on the implementation of the microservice. Some implementations of microservice architecture do not require a microservice gateway. Service Mesh is an emerging architecture based on a non-API gateway. It shields access to the network layer through a proxy on the client, thus minimizing changes to the application layer. Currently, Service Mesh products are still under development, and there are no mature products that can be directly applied. The fastest growing product is Istio. It is recommended that you pay close attention to the development and business use of related products. Based on the duboo architecture, a gateway is usually not required in this architecture. The client directly accesses the service provider, and the registration center returns the address of the service provider to the client. 5. API Gateway Solution Private cloud open source solutions are as follows:
Public cloud solutions:
Self-developed solutions:
6. How do enterprises choose API gateways? If you want to choose an existing API gateway, you need to consider the following aspects. 1. Performance and availability Once an API gateway is adopted, it will serve as the core of the enterprise application, so performance and availability are essential requirements. From the performance point of view, the time consumption of the gateway needs to be as short as possible, and I think it needs to be less than 10ms. The system needs to use non-blocking IO, such as epoll, NIO, etc. The interaction between the gateway and various dependencies also needs to be non-blocking, so as to ensure the high availability of the overall system, such as: Node.js's responsive programming and RxJava and Future based on Java. The gateway must support cluster deployment, and the crash of one server should not affect the availability of the entire system. Multiple gateways should support the same management platform and the same monitoring center. For example, an enterprise's OpenAPI gateway and different microservice gateways of multiple system groups of internal applications can be monitored in the same monitoring center. 2. Scalability and maintainability There are always areas where a product cannot meet production needs, so we need to think about how to carry out secondary development and maintenance of the product and whether it is convenient for the company team to take over and maintain the product. 3. Demand matching You need to evaluate whether each API gateway can meet the requirements. For example, if the OpenAPI platform needs to use an API gateway, you need to consider whether the product can meet the requirements in terms of partner application access, partner portal integration, access limit and other OpenAPI core requirements. If it is a microservice gateway, you need to consider whether the product is powerful enough from the aspects of microservice operation, maintenance, monitoring and management. 4. Is it open source? Does the company have the ability to develop its own software? Existing open source products such as kong, zuul, and orange all have the core functions of basic API gateways. Most of these open source products are far from being very useful, such as: no UI interface that provides management functions, weak monitoring functions, no support for OpenAPI platforms, no company operations and maintenance functions, etc. Of course, open source products can obtain source code. If a company has relatively strong R&D capabilities and can hold these open source products, kong and zuul should still be suitable for some companies after secondary development, but the following points need to be noted:
In addition, Kong provides an enterprise version of the API gateway, which is of course based on ngnix+lua. The enterprise version can purchase their technical support, training and other services, as well as interface management, monitoring and other functions. 5. Public cloud or private cloud? Amazon, Alibaba, and Tencent Cloud are now providing public cloud API gateways. Of course, the basic functions of these gateways are certainly no problem, but secondary development, extended functions, and monitoring functions may not meet the customized needs of some users. In addition, many companies cannot use the API gateway service of the external public network due to their own information security reasons, so they can only choose the private cloud solution. In terms of demand, if the API gateway based on the public cloud can only enable internal personnel to apply for applications for external network personnel, it cannot provide a customized partner portal, which is not suitable for the needs of some enterprises. If used as a microservice gateway, in most cases it is hoped that the gateway server and the service provider server are in the intranet. In this case, only the API gateway of the private cloud can meet the requirements. Based on the above analysis, the API gateway of the basic public cloud can only meet the needs of some simple customers. For many enterprises, the API gateway of the private cloud is the right choice. |
<<: When will the chaos of number portability end?
27 years ago, anyone who mentioned the word "...
During the 4th Data Center Infrastructure Summit ...
While governments, enterprises, and research inst...
[51CTO.com original article] Recently, the recurr...
introduction: Hello everyone, I am Xiaozaojun. In...
[51CTO.com Quick Translation] A research team is ...
Continuing to share information about Maxthon Hos...
On September 20, China Mobile held the 5G+ Innova...
When data center downtime costs an average of nea...
London, UK, May 17, 2021 - The Global Mobile Supp...
At the 2018 China IT Operation and Maintenance Co...
China Mobile said that the bidding in July has be...
[[441504]] 5G remote ultrasonic robot diagnostic ...
With the development and popularization of popula...
The tribe has shared information about spinserver...