Applying Policies

Once installed, Kuma can be configured via its policies. You can apply policies with kumactl on Universal, and with kubectl on Kubernetes. Regardless of what environment you use, you can always read the latest Kuma state with kumactl on both environments.

We follow the best practices. You should always change your Kubernetes state with CRDs, that’s why Kuma disables kumactl apply [..] when running in K8s environments.

  1. echo "
  2. apiVersion: kuma.io/v1alpha1
  3. kind: ..
  4. spec: ..
  5. " | kubectl apply -f -
  1. echo "
  2. type: ..
  3. spec: ..
  4. " | kumactl apply -f -

In addition to kumactl, you can also retrieve the state via the Kuma HTTP API.

Applying policies on Zone and Global Control Planes

Multi-zone deployment consists of Global Control Plane (Global CP) deployment with one or many Zone Control Planes (Zone CP) connected to it. Each Zone CP represents a single cluster (i.e. Kubernetes or Universal cluster). Policies can be applied on both Global and Zone CPs.

When policy is applied on Global CP:

  • it is propagated to all Zone CPs and applied to all matched data plane proxies in all zones
  • Global CP is a source of truth for the policy (when Global CP is down it’s not possible to create/update those policies)
  • You cannot manage this policy (modify / delete) on Zone CP

When policy is applied on Zone CP:

  • it is applied only to matched data plane proxies in the same zone
  • Zone CP is a source of truth for the policy (when Global CP is down it’s still possible to create/update zone-originated policies)
  • you cannot manage this policy (modify / delete) on Global CP
  • it is synced to Global CP to be visible in the UI and API calls

Applying policy on Zone CP requires setting kuma.io/origin label to zone (zone is a keyword, not a name of the zone):

  1. apiVersion: kuma.io/v1alpha1
  2. kind: MeshTimeout
  3. metadata:
  4. name: timeout-on-zone-cp
  5. namespace: kuma-system
  6. labels:
  7. kuma.io/origin: zone
  8. kuma.io/mesh: default
  9. spec:
  10. targetRef:
  11. kind: Mesh
  12. to:
  13. - targetRef:
  14. kind: Mesh
  15. default:
  16. idleTimeout: 20s
  17. connectionTimeout: 2s
  18. http:
  19. requestTimeout: 2s
  1. type: MeshTimeout
  2. name: timeout-on-zone-cp
  3. mesh: default
  4. labels:
  5. kuma.io/origin: zone
  6. spec:
  7. targetRef:
  8. kind: Mesh
  9. to:
  10. - targetRef:
  11. kind: Mesh
  12. default:
  13. idleTimeout: 20s
  14. connectionTimeout: 2s
  15. http:
  16. requestTimeout: 2s

Validation of the origin label can be disabled by configuring a zone CP with KUMA_MULTIZONE_ZONE_DISABLE_ORIGIN_LABEL_VALIDATION: "true".