API Gateway The following three scenarios will be used in my analysis.
Enterprises need to open up their own data and capabilities as development platforms, usually in the form of REST. The most famous 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.
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. The microservice gateway handles load balancing, caching, routing, access control, service proxy, monitoring, logging, etc. The API gateway exists in the microservice architecture as a microservice gateway.
The above-mentioned microservice architecture may be difficult to implement for enterprises. Enterprises have many legacy systems, and extracting all of them into microservices would 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, monitor the calls between systems, etc. 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. 02. 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). 03. How to apply API gateway in enterprises
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.
When an enterprise manages all applications using a microservices architecture, the API gateway plays the role of a microservices 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:
If you use a separate API gateway, there are the following benefits: The priorities for partners and the company's main business are different, and different API gateways can isolate business impacts. The management process for internal API usage may be different from the management process for partner-facing APIs. The internal API's requirements for functional expansion and other aspects are generally greater than the OpenAPI's requirements for functions. 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. 04. What are the competing solutions for API 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. 05.API Gateway Solution Private cloud open source solutions are as follows:
Public cloud solutions:
Self-developed solutions:
06How do enterprises choose API gateways? If you want to choose an existing API gateway, you need to consider the following aspects.
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.
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.
It is necessary to evaluate whether each API gateway can meet the requirements. For example, if the OpenAPI platform needs to use an API gateway, then it is necessary to consider whether the product can meet the requirements of the OpenAPI core requirements such as partner application access, partner portal integration, and access limit. If it is a microservice gateway, then you need to consider whether the product is powerful enough from the aspects of microservice operation, maintenance, monitoring, and management.
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 still a long way from being well used, such as: no UI interface that provides management functions, weak monitoring functions, no support for OpenAPI platforms, and no company operation and maintenance functions. Of course, open source products can obtain source code. If the company has strong R&D capabilities and can hold these open source products, kong and zuul should still be suitable for some companies after secondary development. However, the following points need to be noted: Kong is based on ngnix+lua. From the company's perspective, it is difficult to find people who can maintain this kind of architecture product. Need to assess whether the current company has the ability to maintain this product. Zuul's performance is not high under high concurrency conditions due to its architecture. At the same time, it is necessary to integrate open source monitoring and management systems that are compatible with Zuul based on research. Orange is not widely used, and it is open sourced by individuals in China. It lacks sustainability and community resources, so it may not be easy to find someone to ask questions when problems arise. 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.
Amazon, Alibaba, and Tencent Cloud are now providing basic 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 be able to meet the customized needs of some users. In addition, many companies cannot use API gateway services on the public network due to their own information security reasons, so they have no choice but to choose a 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. |
<<: Hot Topic | What’s so great about 5G that makes the United States tremble?
>>: Why should enterprises choose SD-WAN?
At present, the digital economy is entering a new...
On May 13, according to IDC's Global Semi-ann...
Embedded Subscriber Identity Module (eSIM) has gr...
The social dream of the three major operators has...
RackNerd has launched some promotions in Los Ange...
Tiago Rodrigues, who took over as CEO of the Wire...
edgeNAT has released a promotional plan for June,...
Bluetooth Low Energy is a new Bluetooth wireless ...
TripodCloud (Yunding Network) is a relatively low...
On April 23, General Secretary Xi Jinping emphasi...
Wireless mesh networks have been around since the...
DogYun has launched a promotion during this year&...
Cloud-based unified communications (UC) tools are...
2023 has officially begun, and RAKsmart has launc...