APIs
Exposing a service API
When building cloud applications, you need APIs to expose logic or data that other users, applications, APIs, or services can use. This is an integral part of a sound microservices architecture and engineering.
Hybrid cloud services that facilitate development and evolution of these service APIs include service API gateways that can limit or control API access, services to secure ingresses to services and APIs, tools and services to document and test APIs, in addition to the ability to meter and charge for APIs.
Why is API exposure important to hybrid cloud developers?
There are many reasons why a microservices architecture should expose services APIs, including:
APIs open your services to the world. Each service might have multiple APIs that can be exposed.
Enable serverless usage so that customers can truly pay for what they use. For many companies, there is a desire to pay for the exact cloud resources consumed, while also being able to access unlimited cloud resources when scaling is required.
Advanced API features are now available as a service and in many clouds. For instance, specific services enable you to meter the API, to throttle and deal with rapid scale,to secure all endpoints, and to allow retries and other “corner cases” that arises when using an API at scale.
Solution sketch
When exposing APIs, there is a common set of tasks and a common high-level architecture. The steps include figuring out what part of the service or application or data that needs to be exposed as a service. This is called API design. The output of this step is an Open API document listing the different endpoints, the methods exposed (i.e., POST, PUT, GET), and the data structures in and out of these methods.
After the design phase, you need to generate the stubs and skeletons for the API document and connect that to the backend code that implements the API methods and consume and return the necessary data structures.
Finally, you need to plan for non-functional attributes for the API and deployment. An API Gateway is an excellent means to achieve this last step. Many cloud providers have API Gateways readily available to use. You can also deploy your own. The next sections highlight examples of these depending on the targeted cloud or open source projects you can use if you want to deploy your own.
Constraints and limitations
- Serverless approaches to API consumption is not in scope since we plan to cover the whole topic of serverless as its own guide.
- Scaling applications, services, and APIs, at very large scale, is a topic that requires its own treatment. However, basic scaling, which is required by all APIs can be achieved by an API Gateway.
- Securing APIs is certainly in scope, however, there are advanced authentication and security and access control that are outside the scope and best provided as a separate service from the cloud provider or externally.
Key open source projects
API documentation
Source code | Governing body | Get started | |
---|---|---|---|
Open APIs | Linux Foundation | Documentation | |
Swagger Hub | Smart Bear | ||
Kong API Gateway | Kong |
Example Cloud(s)
Cloud | Key references | |
---|---|---|
Azure | API Management | |
IBM Cloud | IBM API Connect | |
Google Cloud | Creating an API |
Additional resources
Blogs
- RESTful web API design
- Best Practices in API Design
- Best Practices for Designing a Pragmatic RESTful API
Videos
- Kong Gateway: 3 Steps to Getting Started
- Service Connectivity for Mordern Architecture
- Swagger API documentation tutorial for beginners