Skip to content

Functional Layers

Background

Context on the inclusion of “functional layers” can be viewed in our ADR. In short, UDS Core publishes smaller Zarf packages that contain subsets of core’s capabilities, grouped by their function (such as monitoring, logging, backup/restore, etc) to allow more flexibility in deployment. This helps to support resource constrained environments (edge deployments) and other situations where an environment has different needs than the default core stack.

Each layer is published as an individual OCI Zarf package. Package sources can be viewed under the packages directory, with each folder containing a readme detailing the contents and any dependencies. All layers assume the requirement of the base layer which provides Istio, the UDS Operator, and UDS Policy Engine.

Example Usage

Functional layers are designed to be combined into a UDS bundle for deployment. The example below shows all layers in the correct order. Keep in mind that ‘base’ must always be the first layer, and any other layers should follow based on their dependency order. When building your bundle, you can skip layers that don’t fit your deployment needs and apply overrides to individual layers as needed. Ensure all layers are using the same version for compatibility.

kind: UDSBundle
metadata:
name: functional-layer-core-bundle
description: An example bundle for deploying all of core using functional layers
version: "0.1.0"
packages:
- name: core-base
repository: ghcr.io/defenseunicorns/packages/uds/core-base
ref: 0.29.0-upstream
- name: core-identity-authorization
repository: ghcr.io/defenseunicorns/packages/uds/core-identity-authorization
ref: 0.29.0-upstream
- name: core-metrics-server
repository: ghcr.io/defenseunicorns/packages/uds/core-metrics-server
ref: 0.29.0-upstream
- name: core-runtime-security
repository: ghcr.io/defenseunicorns/packages/uds/core-runtime-security
ref: 0.29.0-upstream
- name: core-logging
repository: ghcr.io/defenseunicorns/packages/uds/core-logging
ref: 0.29.0-upstream
- name: core-monitoring
repository: ghcr.io/defenseunicorns/packages/uds/core-monitoring
ref: 0.29.0-upstream
- name: core-backup-restore
repository: ghcr.io/defenseunicorns/packages/uds/core-backup-restore
ref: 0.29.0-upstream

Layer Selection

Layer selection will always be deployment-specific but below are guidelines for what layers to consider for your deployment. The layers marked with a cross (†) are those needed to follow the Big Bang Conformant Stack though if you are not bound by that document, UDS Core Base is the only technical layer required to install most UDS Packages.

UDS Core LayersSelection Criteria
Runtime Security†*Provides more advanced security with runtime inspection
(install if resources allow and more advanced security is desired)
Monitoring†*Provides frontend log / metrics monitoring and alerting
(install if resources allow and more advanced debugging is desired)
Backup and RestoreAllows volumes and k8s objects to be backed up and restored
(install if deployment provides critical data or must maintain state)
Identity and Authorization†Provides authentication and authorization functionality
(install if deployment requires an auth mechanism (i.e. direct user login))
Logging†Provides backend log storage and log shipping capabilities
(install if the deployment requires log aggregation and shipping)
Metrics Server†**Provides metrics collection capabilities (req of UDS Runtime)
(install if the cluster does not provide its own metrics server)
Base†Provides the base for all other functional layers
(required for all “UDS” deployments and all other functional layers)
UDS Add-ons*Selection Criteria
UDS UIProvides a common operating picture for a Kubernetes cluster and UDS deployments
(install if you would like to have an easy-to-use window into your cluster/deployments)
UDS RegistryProvides a storage location for UDS components and mission applications
(install if you would like to be able to easily store and view the software available in your environment)
UDS Remote AgentAllows for more advanced remote cluster management / deployment
(install if you would like to manage UDS deployments from more advanced clients than UDS CLI)
UDS Core Pre-Requisites*Selection Criteria
UDS Package Minio OperatorProvides storage for the Logging and Backup and Restore layers
(install after core base but before logging/backup and restore if selected)
UDS Package MetalLBProvides a simple LoadBalancer implementation
(install after Zarf init and before UDS Core Base)