Skip to main content
Framed content
A deployment is a set of config instances delivered to a device for consumption by your software. Deployments tie together config instances, releases, and devices to simplify configuration management and delivery. Deployments have a variety of constraints designed to simplify configuration updates:
  1. A deployment’s config instances are immutable Once created, the configs in a deployment cannot be updated. A new deployment must be created to modify a device’s configs.
  2. Deployments belong to a single release Deployments belong to exactly one release, whose config schemas are used to validate the configurations in the deployment.
  3. Deployments belong to a single device Deploying the same configs to two devices requires a deployment for each device.
  4. Deployments are one-time use Once removed from a device, a new deployment must be created to restore a device’s previous configurations.

Properties

description
string
A user-provided description of the deployment.Example: “increase acceleration limit to 1.2 m/s^2”
target status
enum
The desired state of the deployment.Allowed values:
  • staged
  • deployed
  • archived
activity status
enum
The deployment’s last known activity state.Allowed values:
  • staged
  • needs_review
  • queued
  • deployed
  • removing
  • archived
error status
enum
The deployment’s last known error state.Allowed values:
  • none
  • failed
  • retrying
status
string
The status is a merged property of the activity status and error status fields, with error states taking precedence over activity states when errors are present.So, if the error status is none, then the status is simply the activity status. If the error status is not none, then the status is the error status.Below are examples of status values for different activities and error states.
Activity StatusError StatusStatus
stagednonestaged
deployednonedeployed
queuedretryingretrying
removedfailedfailed
Enum: staged, needs_review, queued, deployed, removing, archived, failed, retrying
parent
Deployment
The deployment from which this deployment was patched.Examples: DPL-L5B8b
release
Release
The release which the deployment adheres to.Examples: 1.0.1, 1.7.0-beta.1
config instances
[] Config Instance
The config instances in the deployment, each of which satisfies a different config schema in the deployment’s release.Examples: CFG-68hdX, CFG-Cpa13

Methods

Broadly speaking, there are two methods for creating and deploying configurations. Configurations can be:
  1. Edited per device via the config editor
  2. Staged in a release’s staging area to be deployed at a later time
Per-Device Editing Each device has a dedicated config editor for viewing and editing its configurations. Changes made in the config editor are immediately deployed to the device. The config editor deals only with a single device’s configurations. It does not support multiple devices at once nor does it support staging new deployments. For more information, check out the config editor documentation. Release Staging Staging a deployment is the process of creating a new deployment in a release’s staging area to be deployed in the future. Staging is primarily used to rollout a new release, providing an unobstrusive place to create and review deployments before being deployed to devices. A release’s staging area is also useful for batch operations. Deployments can be created, deployed, and archived in bulk, which helps manage large numbers of deployments at once. For more information, check out the staging area documentation.

Status

The status is a merged property of the activity status and error status fields, with error states taking precedence over activity states when errors are present. So, if the error status is none, then the status is simply the activity status. If the error status is not none, then the status is the error status. Below are examples of status values for different activities and error states.
Activity StatusError StatusStatus
stagednonestaged
deployednonedeployed
queuedretryingretrying
removedfailedfailed

Target Status

The target status is the desired state of a deployment. There are three possible target statuses.
Target StatusDescription
stagedDeployment doesn’t want to be deployed, but may be deployed in the future
deployedDeployment wants to be delivered to its device
archivedDeployment no longer wants to be deployed; it can never be deployed again
With Staging If a deployment is staged before being deployed, the diagram below shows the valid transitions between target statuses. Target status state machine Without Staging Of course, many deployments skip staging and deploy immediately (such as those deployed from a device’s config editor). The diagram below shows the valid transitions between target statuses for a deployment that is immediately deployed. Target status state machine One-Time Use As you can see, the target status can only move forward, never backwards. Once a deployment’s target status has been set to deployed, it can never be set to staged again. Similarly, once a deployment’s target status has been set to archived, it can never be set to deployed again. This is intentional—deployments are one-time use. Once a deployment has been deployed, it cannot be redeployed. You must create a new deployment with identical content to roll back.

Activity Status

The activity status is the last known state of a deployment. We use the last known state intentionally — poor network connectivity can prevent devices from immediately syncing their activity state with the cloud. In practice, this isn’t too common. However, it’s still a critical point to keep in mind. There are six possible activity states for a deployment.
Activity StatusDescription
stagedDeployment has been created and is ready to be deployed
needs reviewDeployment has drifted and needs to be reviewed
queuedDeployment is waiting for the device to be so it can be delivered to the device
deployedDeployment has been delivered to the device, and its configurations are available for consumption
removingDeployment will be removed from the device as soon as the device is online
archivedDeployment is available for historical reference, but can never be deployed again
With Staging When a deployment is staged before being deployed, it can pass through all the listed activity states. Below is a diagram of the valid transitions between activity states. Deployments start in the staged state. If a deployment drifts, it transitions to needs review and must either be restaged or archived. Eventually, the deployment is queued for delivery to the device, where it passes through the primary deployment lifecycle from queued to archived. Without Staging Deployments which are immediately deployed and skip the staged state have a simpler lifecycle. They simply go through the primary deployment lifecycle from queued to archived. One-Time Use As with the target status, activity states can only progress forward since deployments are one-time.

Error Status

The error status is the last known error state of a deployment. Again, we use the last known state intentionally — poor network connectivity can prevent devices from immediately syncing their error state to the cloud. The error status is independent of the activity and target statuses. The error status does not imply any particular activity or target state, and vice versa. The error status is only concerned with errors encountered during deployment. There are three possible error states for a deployment.
Error StatusDescription
noneThere are no errors with the deployment
retryingA non-fatal error has been encountered; the agent is retrying to fulfill the deployment’s target status
failedA fatal error has been encountered; the deployment is (or will be) removed from the device and archived
Below are the valid transitions between error states. Error status state machine Deployments start in the none error state. If no errors are encountered, the deployment remains in the none error state for the duration of its existence. Non-Fatal Errors If a non-fatal error is encountered, the deployment transitions to the retrying error state. Non-fatal errors include unexpected network drops, sudden power cycles, and similar events. If the agent recovers the deployment from the error, the deployment transitions back to the none error state once the deployment’s target status is reached. On the other hand, as long as the agent is unable to recover the deployment, the deployment remains in the retrying error state. The agent continually attempts to reach the deployment’s target status, using exponential backoff to prevent resource throttling. If the deployment is stuck in the retrying error state, try replacing or archiving the deployment to allow the agent to start fresh. Fatal Errors If a fatal error is encountered, the deployment transitions to the failed error state, is removed from the device, and marked as archived.