Runtime service configuration overview

The Apigee hybrid runtime plane is made up of a variety of services. Each service is deployed on nodes within your Kubernetes cluster, and each one can be configured using the overrides.yaml file.

The following image shows how each of the runtime services interacts with other services in hybrid:

alt_text

The following table summarizes the runtime services:

Service Description Configuration Object Implemented As Scope
Apigee Connect Apigee Connect allows the Apigee hybrid management plane to connect securely to the MART service in the runtime plane without requiring you to expose the MART endpoint on the internet. If you use Apigee Connect, you do not need to configure the MART ingress gateway with a host alias and an authorized DNS certificate. connectAgent Deployment Kubernetes cluster
Apigee Ingress Gateway Apigee Ingress gateway routes incoming traffic through that endpoint to the correct message processor. By default, it generates a LoadBalancer service with external endpoints. apigeeIngressGateway
ingressGateways
Deployment Kubernetes cluster
Apigee Operators Apigee Operators (AO) creates and updates low level Kubernetes and Istio resources that are required to deploy and maintain the ApigeeDeployment (AD) configuration. For example, the controller carries out the release of message processors and validates the AD configuration before making it persistent in Kubernetes cluster. ao Deployment Kubernetes cluster
Cassandra Acts as a runtime datastore that provides Apigee local persistent storage for KMS, OAuth, KVMs, and caching for the runtime plane. You can have separate Cassandra rings for KMS, OAuth, KVMs, and caching.
apigee-cassandra-default pods are the pods running the Hybrid Cassandra database on a Kubernetes cluster. One or more pods together make a cluster that reads, writes, and stores persistent data for Apigee Hybrid.
apigee-cassandra-user-setup pod initializes and configures the users and roles for the Cassandra database. These roles are used by Cassandra and Runtime components to read and write data to the Hybrid Cassandra database.
apigee-cassandra-schema-setup pod initializes and configures the database schema of the Hybrid Cassandra database. This pod is for setting up Cassandra keyspace and table definitions with the Hybrid Cassandra database.
cassandra StatefulSet Organization (one or more orgs)
Guardrails Validates that required conditions are satisfied before allowing Runtime services to be created. Guardrails pods are created when you apply the Apigee hybrid charts with Helm install or update commands. guardrails Kubernetes pod Cluster (one or more organizations in the same cluster)
Logger Extracts log files and sends the data to the monitoring application associated with your Google Cloud account (currently Cloud Operations). logger DaemonSet Cluster (one or more organizations in the same cluster)
Management API for Runtime data (MART) Exposes an endpoint to administer data entities on the runtime plane, such as KMS (API keys and OAuth tokens), quotas, KVMs, and API products. MART services are scoped to a single organization. mart Deployment Organization
Message Processor Consumes rolling updates from the management plane to provide API request processing and policy execution on the runtime plane. Each Message Processor is scoped to a single environment. runtime Deployment Environment
Metrics Collects operations metrics that you can use to monitor the health of hybrid services, to set up alerts, and so on. metrics Deployment Cluster (one or more organizations in the same cluster)
Redis Redis is used for storing cluster-level rate limit counts used for distributed rate limiting used for SpikeArrest policies that use effectiveCount option to synchronize request counts across message processors. redis DaemonSet and Deployment (both) Cluster (one or more organizations in the same cluster)
Synchronizer Fetches configuration data about an API environment from the management plane to the runtime plane. A Synchronizer can poll one or more environments in the same or different organizations. synchronizer Deployment Environment
Universal Data Collection Agent (UDCA) Extracts analytics and deployment status data and sends it to the UAP service in the management plane so that you can access it with the management UI. udca Deployment Environment
Watcher Watcher periodically executes task in the runtime cluster such as reconfiguring Ingress routes, checking ingress status for new proxy deployments, fetching deployment status from Message Processors and Ingress in order to report status to Management Plane. watcher Deployment Cluster (one or more organizations in the same cluster)

Most services make socket connections with other internal or external services that you should be aware of. For more information, see Hybrid ports.