Routing

Overview

Normally when service APIs are exposed to ingress traffic in Kubernetes, a separate routing configuration is required, such as Kubernetes Ingress Objects or Istio Virtual Services.

The HTTP configurations specified in these ingress routes must match exactly with the service APIs provided by the backend, or risk bugs, service outages, and undefined behaviors. Furthermore, correlating the traffic handled by the ingress with the APIs it exposes is a tedious task, requiring the network administrators to have intricate knowledge of Developer APIs, or place the burden of network administration directly on developers.

Using this kind of “raw ingress” to track client identity and enforce policy is even more complex. Typically, API vendors wish to expose the same API functionality with policies that differ depending on the client, such as the ability to differentiate between “basic” and “premium” usage plans.

The Istio Dev Portal’s Routing features are designed to explicitly address these problems. The Dev Portal Routing features automatically configure the underlying networking implementation (Istio) using supported API Specifications as the source of configuration.

Dev Portal users bundle and expose their APIs in the form of API Products, wherein they define ingress, authorization, and rate limiting policies which will automatically be attached to the exposed API endpoints.

Routes generated directly from these API Products provide per-API access logging and monitoring. These routes are automatically integrated with the Dev Portal’s Auth Server and Rate Limiter to apply security and usage policies defined in each Product.

Automatic Istio Routing

The Dev Portal manages a set of Istio Networking CRDs on behalf of users: