Functional Layers
Background
Section titled “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
Section titled “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: UDSBundlemetadata:  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.54.1-upstream  - name: core-identity-authorization    repository: ghcr.io/defenseunicorns/packages/uds/core-identity-authorization    ref: 0.54.1-upstream  - name: core-metrics-server    repository: ghcr.io/defenseunicorns/packages/uds/core-metrics-server    ref: 0.54.1-upstream  - name: core-runtime-security    repository: ghcr.io/defenseunicorns/packages/uds/core-runtime-security    ref: 0.54.1-upstream  - name: core-logging    repository: ghcr.io/defenseunicorns/packages/uds/core-logging    ref: 0.54.1-upstream  - name: core-monitoring    repository: ghcr.io/defenseunicorns/packages/uds/core-monitoring    ref: 0.54.1-upstream  - name: core-backup-restore    repository: ghcr.io/defenseunicorns/packages/uds/core-backup-restore    ref: 0.54.1-upstreamLayer Selection
Section titled “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 Layers | Selection 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 Restore | Allows 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 UI | Provides 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 Registry | Provides 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 Agent | Allows 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 Operator | Provides storage for the Logging and Backup and Restore layers (install after core base but before logging/backup and restore if selected) | 
| UDS Package MetalLB | Provides a simple LoadBalancer implementation (install after Zarf init and before UDS Core Base) |