Prerequisite: read and complete the getting started document!
What is a Delivery Config?
A delivery config allows you to group resources together in a single file (e.g.
spinnaker.yml) and specify how these resources work together to promote an artifact between environments.
An artifact represents the package or docker image that you want to promote in your delivery flow.
For example, if you develop the package
keeldemo (which is built into a debian) and that is the only package that runs in your application, you’d have the following artifact section:
artifacts: - name: keeldemo type: deb reference: my-artifact # optional human-readable reference to be used elsewhere in the config, defaults to artifact name
You can have multiple artifacts in your delivery config. We will watch for new versions of every artifact you define. In order to deploy a cluster that is running an artifact you’ll need to use it within a resource (in an Environment).
For detailed artifact information, please refer to the Artifacts page.
An environment represents all the infrastructure and instructions that are needed to run your package.
For example, we usually see environments like
Each of these potentially have different resources, but are likely pretty homogeneous.
A simple and supported workflow looks like this:
Every build of your package should be deployed into your
testingenvironment. This environment might have a lower capacity, and a load balancer that only allows your team to access the running application.
Once your build has been deployed to
testingand has come up as healthy, it should be promoted to your next environment (called
staging). Staging has a different capacity than
(Coming soon…) Each build that has been healthy in staging is a candidate for
production. Before deploying to
productionyou must manually approve each version.
Defining an Environment
An environment is made up of a list of declarative infrastructure resources (like the resource you created in the getting started guide). An environment is configured as follows:
environments: - name: testing resources: - <full resource definition> - <another resource definition>
That’s all the config you need for a simple environment.
You can add environment level notifications. They apply to all resources in the environment. The config looks like:
environments: - name: testing resources: # omitted for brevity notifications: - type: slack address: "#managed-delivery" frequency: verbose
There are several
verbose: notification on task starting, completing, failing
normal: notification on task completing or failing
quiet: notification only for failure
There are two
slack: the address is the slack channel to send to (the spinnakerbot must be in the channel for you to receive notifications)
Constraints control how an artifact progresses through environments.
The config looks like:
environments: - name: staging resources: # omitted for brevity notifications: # omitted for brevity constraints: - type: depends-on environment: testing
This constraint definition says that an artifact must have been deployed successfully into the
testing environment before it can be deployed into the
A growing set of constraints are available, see Environment Constraints for more information.
Creating a delivery config
Let’s pull it all together! Delivery configs must be stored in a file called
The rough structure is:
name: sample-delivery-config application: keeldemo artifacts: - name: keeldemo type: deb reference: my-artifact environments: - name: testing notifications: # omitted for brevity constraints:  resources: # details omitted for brevity - apiVersion: bakery.spinnaker.netflix.com/v1 kind: image # details - apiVersion: ec2.spinnaker.netflix.com/v1 kind: cluster # details - apiVersion: ec2.spinnaker.netflix.com/v1 kind: classic-load-balancer # details - name: staging notifications: # omitted for brevity constraints: - type: depends-on environment: testing resources: # details omitted for brevity - apiVersion: ec2.spinnaker.netflix.com/v1 kind: cluster # details - apiVersion: ec2.spinnaker.netflix.com/v1 kind: classic-load-balancer # details
This shortened delivery config shows how to promote a debian artifact through two environments.
Note that there is an image resource in the
The image resource specifies how new debian artifacts should be baked into AMIs.
You only need to include an image resource in your first environment because you’ll be promoting that image through the environments that follow.
Also note that the first environment has no constraints.
TODO eb: add an example