This topic explains how to configure and manage the Apigee hybrid runtime plane components. For a list of the runtime plane components that you can configure, see Runtime service configuration overview.
About the overrides file
The first time you install the hybrid runtime into a cluster, you must create a configuration overrides file. This file lets you override default configuration values as needed, configure environments, reference TLS certificates and service account keys, assign Kubernetes node pools to specific hybrid components, and so on.
The hybrid installation steps walk through the process of creating an overrides file and applying your configuration to a cluster. If you want to change the configuration later, modify the overrides file you created and re-apply it.
Making a configuration change
To make a configuration change to a hybrid runtime plane component,
  edit your overrides file and
  apply the changes with apigeectl.
For example, to change the replica count on the Message processor, follow these steps:
- Open your
    OVERRIDES.yamlfile. Be sure to use the same overrides file that was used to install the hybrid runtime into the cluster.
- Locate the runtimeelement in the file. For example:... runtime: nodeSelector: key: cloud.google.com/gke-nodepool value: apigee-runtime replicaCountMin: 1 replicaCountMax: 2 ...
- 
  Change the replica count properties as needed. For example:
... runtime: nodeSelector: key: cloud.google.com/gke-nodepool value: apigee-runtime replicaCountMin: 2 replicaCountMax: 4 ...
- Use apigeectlto apply the change to the cluster:apigeectl apply -f ./OVERRIDES.yaml --org --env ENV_NAME 
Which configuration properties can you modify?
You can find the complete list of configurable properties in the Configuration property reference. The reference only lists the properties you can modify; if you try to modify a property that's not in the reference, the change is ignored.
How to use the configuration reference
The Configuration property reference uses dot notation to describe configuration elements, where the first item is the top-level element name followed by properties and child properties. For example:
authz.image.pullPolicy
In the overrides file, the properties are formatted in proper YAML. For the above example,
  the top-level authz element is left-indented
  and sub-element properties are indented under it. Also, YAML requires a colon at the
  end of each element and sub-element.
For example, to set the authz.image.pullPolicy property to Always, locate
this YAML stanza in the overrides file and set it as follows:
authz: image: pullPolicy: Always
For another example, the property cassandra.auth.admin.password (as it
    is listed in Configuration property reference) is used to set the Cassandra
    admin password. To change it, locate the following YAML in the overrides file and set
    it as follows:
cassandra: auth: admin: password: abc123
Remember, the Configuration property reference describes all of the properties that you can set on hybrid runtime plane components. Follow the pattern explained above to modify these elements in your overrides file before applying the changes to your cluster.
Using pre-defined example overrides files
When you first install hybrid runtime, Apigee recommends that you use one of the pre-configured example overrides files. These examples provide a complete set of configuration properties for specific installation scenarios, such as for setting up a production or test installation. All you need to do is provide appropriate values for the properties and apply the overrides file to your cluster. See Step 7: Configure the hybrid runtime for more information.
About configuration defaults
Apigee maintains its default component configuration in the file
  HYBRID_ROOT_DIR/config/values.yaml. Your overrides files follows the same YAML
  structure as values.yaml.
An overrides file typically includes only a subset of the configuration properties found in
  values.yaml. Remember, not
  all properties are editable. When you apply a configuration
  to a cluster, your overrides are merged with the defaults to create the complete Kubernetes
  cluster configuration. See also Test
  the merged configuration.
The following code shows the default configuration for the mart component as
  found in values.yaml. Note
that some values have defaults, while others such as sslCertPath and
  sslKeyPath do not. You must provide these missing values in your
overrides file, as explained in the installation steps.
  If you want to change any of the default values, make sure they
  are editable by checking in the Configuration property reference.
...
mart:
  replicaCountMin: 2
  replicaCountMax: 4
  targetCPUUtilizationPercentage: 75
  terminationGracePeriodSeconds: 30
  sslCertPath:
  sslKeyPath:
  hostAlias:
  nodeSelector:
    key:
    value:
  revision: blue
  image:
    url: "gcr.io/apigee-release/hybrid/apigee-mart-server"
    tag: "1.3.6"
    pullPolicy: IfNotPresent
  resources:
    requests:
      cpu: 500m
      memory: 512Mi
  initCheckCF:
    resources:
      requests:
        cpu: 10m
  livenessProbe:
    timeoutSeconds: 1
    failureThreshold: 12
    periodSeconds: 5
    initialDelaySeconds: 15
  readinessProbe:
    timeoutSeconds: 1
    successThreshold: 1
    failureThreshold: 2
    periodSeconds: 5
    initialDelaySeconds: 15
  metricsURL: "/v1/server/metrics"
  cwcAppend: |
...If you want to modify a component's defaults and the component is
    not already in your overrides file, you can copy its YAML from values.yaml into your
    overrides file and modify it there.
Sample overrides files
Apigee provides a set of sample overrides files to help guide you in setting up your hybrid deployment. It's a good practice to copy and modify the overrides file that most closely matches your installation requirements.
The following samples are included in the
directory HYBRID_ROOT_DIR/examples:
| Sample overrides files | Description | 
|---|---|
| overrides-small.yaml | This sample is ideal for a getting started quickly. It uses the minimum recommended footprint
      to start the hybrid runtime components. This sample configuration relies as
      much as possible on default settings and values. All the minimum replicas are set to 1. | 
| overrides-medium.yaml | This sample is a good starting point for testing and QA environments. Individual components have been granted a higher level of resources to deal with additional traffic. Cassandra uses SSD disks for performance. In this environment, it is recommended that users install stateful and stateless components on separate nodes. See Configure dedicated nodes. | 
| overrides-large.yaml | This sample is a good starting point for high performance environments such as pre-production and production. The sample includes properties for setting encryption keys, passwords, and others. Individual components have a minimum of two replicas. | 
Custom annotations
Annotations are key/value maps used to attach metadata to Apigee hybrid Kubernetes pods. You can create custom annotations for the following properties listed in Configuration property reference:
To add a custom annotation, add a stanza to the OVERRIDES.yaml file
      for the respective component.
The following example illustrates how an annotation can be specified in runtime
      pods:
runtime: annotations: businessunit: "bu1"
Test the merged configuration
You can use the --dry-run flag with apigeectl to test the merged
  configuration file without actually applying it to your cluster. This option is useful for debugging an
  installation problem because it shows you exactly what will be applied to the cluster.
  It is also a good practice to test the configuration and store it in
  source control so that you have a reference of the resources installed
  and configured in the cluster.
In Apigee hybrid, the syntax of the --dry-run flag depends on the version of
    kubectl you are running. Check the version of kubectl with the
    following command:
kubectl version
kubectl version 1.17 and older:
APIGEECTL_HOME/apigeectl init -f overrides/OVERRIDES.yaml --dry-run=true
kubectl version 1.18 and newer:
APIGEECTL_HOME/apigeectl init -f overrides/OVERRIDES.yaml --dry-run=client
For more information, see apigeectl.
Create multiple overrides files as needed
You can create as many overrides files as you want, where each one serves a specific requirement. For example, you might have an overrides file that tunes your cluster for production, and another for creating a testing cluster. You can then maintain these files in your source control system.
  Use the -f option with apigeectl to specify the location and name
  of an overrides file. For example:
apigeectl apply -f ./test_env_override.yaml
For more information, see apigeectl.
Delete hybrid-specific runtime plane components
  To delete the hybrid-specific runtime plane components from your cluster, use the
  apigeectl delete command. These components include synchronizer, mart,
  runtime, cassandra, and udca. Be sure to specify the same overrides file that
  you used to install the runtime components:
For example:
apigeectl delete -f ./OVERRIDES.yaml
You can use the apigeectl apply command to recreate a specific component or
  components:
apigeectl apply --org --env ENV_NAME -f ./OVERRIDES.yaml
For more information, see apigeectl.
Delete a specific component
For example, to delete the synchronizer component, use this command:
apigeectl delete --org --env ENV_NAME -f ./OVERRIDES.yaml
You can then use the apigeectl apply command to recreate the component:
apigeectl apply --org --env ENV_NAME -f ./OVERRIDES.yaml
For more information, see apigeectl.
Delete all components
  To delete all of your cluster components hybrid, including those created by the
  apigeectl init command, use the
  apigeectl delete command with the --all flag. Be sure
  to specify the same overrides file that
  you used to install the runtime components:
For example:
apigeectl delete -f ./OVERRIDES.yaml --all
For more information, see apigeectl.