They should create a container image for the finished architecture and deploy it to a target runtime like Cloud Run. They may also run the gRPC gateway locally to learn how it functions:
(cd generated/gateway && docker build . -t gateway:latest)
docker run -p 8080:8080 -e GRPC_SERVER_ENDPOINT=localhost:9090 gateway:latest
Here, the gRPC endpoint that the gateway should use to route traffic is indicated by the GRPC_SERVER_ENDPOINT environment variable. In this instance, the local gRPC currency service is already up and operating on port 9090. You may now make a standard JSON HTTP request to the gRPC gateway‘s endpoint once it has been started:
curl -X POST localhost:8080/hipstershop.CurrencyService/Convert -d '{"from": {"units": 3, "currency_code": "USD", "nanos": 0}, "to_code": "CHF"}'
As you can see, they’ve released their gRPC currency service as a JSON HTTP API, which may be more user-friendly and integrated into a larger API ecosystem. When they take into account how this new API fits with the business’s well-established API strategy, there is still space for improvement:
- The API retains much of the original’s structure while deviating from the generally recognized RESTful API design guidelines.prototype guidelines.
- Features related to API administration, like error handling, centralized logging and monitoring, authentication, and monetization, are not supported by the API.
- There is no self-service alternative available to developers to help them find new APIs and register as API users.
API Proxy
They may use an Apigee API Proxy façade as an API management layer to accomplish some of these goals and eventually increase API adoption. Although Apigee is capable of exposing gRPC services in pass-through mode natively, in this case, they are using the previously converted protocol, which enables us to apply a variety of helpful settings and rules for:
- Translations of the method, path, and payload that enable us to provide a suitable RESTful façade and abstract the underlying gRPC message format.
- Metrics and rich analytics data gathering to assess the API program’s operational effectiveness and success.
- Enforcing traffic management, error handling, and consistent API security to safeguard other systems and enforce client quotas.
Reduce obstacles to entry with API management
In order to safely access their gRPC gateway and build upon it, they must first get the API proxy. This proxy can be deployed to Cloud Run, where Cloud IAM may be used to enforce authentication. Their API proxy has to be set up to either utilise Google Cloud authentication directly or pass along the credentials obtained from the API client in order to comply with this security measure.
Google Cloud can expose a RESTful path to API consumers and rebuild the path at runtime to match what their gRPC gateway expects thanks to Apigee’s thorough and flexible approach to managing routes with an API proxy.
curl -X POST "https://$APIGEE_HOSTNAME/currency/v1/convert" -d '{"from": {"units": 3, "currency_code": "USD", "nanos": 0}, "to_code": "CHF"}'
When they use an Apigee API proxy to proxy their currency service, analytics and API metrics are automatically collected, giving us valuable information about the performance and health of their APIs. By adding more traffic management, security, mediation, and even code extension rules, Google Cloud may further enhance their API proxy.
Google Cloud may publish an API product on Apigee’s developer portal so that developers can find, use, and experiment with the API, creating new possibilities, and introducing and promoting this API to a new audience. To expand on this further, they may choose monetize an API product to open up new income streams via a range of alternative approaches, such subscription plans or usage-based pricing.
Final thoughts and future actions
Ultimately, they have shown how gRPC services may be simply made available to new users via HTTP APIs, all the while using the advantages of an all-inclusive API management platform such as Apigee. Google Cloud can expand the reach of their services and data to a larger developer and application community by fusing the efficiency of gRPC with the familiarity and tools of REST APIs. They can bridge the gap between gRPC gateway and REST when developing an API ecosystem by adopting this hybrid method, allowing you to take use of the greatest features from both perspectives.
0 Comments