Skip to content

Latest commit

 

History

History
76 lines (49 loc) · 7.36 KB

README.md

File metadata and controls

76 lines (49 loc) · 7.36 KB

Pulumi and Custom Configuration

The purpose of this repository is to show an example of a user-defined configuration layer which can extend pulumi's configuration capabilities, by adding user-defined organization and options.

For more information on getting started with pulumi, visit Get Started with Pulumi.

See the following links for more information about pulumi and it's out of the box configuration model.

This user-defined custom config does not support pulumi secrets!!! You should continue to use pulumi's out of the box configuration that provides excellent support for secrets! YAY Secrets!

Why

Pulumi configuration currently supports the use of a single yaml file, in a single location (Eg- Pulumi.stack.yaml). One cannot support a hierarchical configuration or organize individual stack configurations in a directory structure, without some effort.

What

To support hierarchical configuration or directory organization, we'd need to write some code to interact with pulumi and it's configuration system.

How

Using an intermediary configuration layer, we will support hierarchical configuration, organization of our stack configuratiions, and multi-tenant configurations. This configuration layer will wrap the existing configuration model and automatically search for configuration keys in other stack specific files.

The custom_config will resolve configuration items through the following order:

  1. Look in the stack configuration in the environments/{env}/ directory.
  2. Look in the defaults.yaml file in the environments/{env}/ directory.

Getting Started

We'll use a new pulumi python app to demonstrate how to use the custom_config. AWS will be the cloud provider used, however, this solution is not cloud provider specific.

mkdir pulumi_custom_config && cd pulumi_custom_config
pulumi new aws-python

Walk through the interactive CLI prompt and fill out, as you need. Most importantly to the custom_config, your stack must be named following a specific scheme and your stack configuration file must be located in a unique directory.

  • Stack name must be in the following scheme: {environment}-{customer-id} where environment is either 'prod' or 'sdlc' and customer-id is a user chosen value. Eg- 'sdlc-ks123'.
  • Stack configuration file must be located in a directory that corresponds to the environment portion, in the stack name. Eg- if the stack name is sdlc-ks123, the Pulumi.sdlc-ks123.yaml file must be located at: ./environments/sdlc/Pulumi.sdlc-ks123.yaml.

Assuming we added two stacks, prod-customer123 and sdlc-customer123 your dashboard on app.pulumi.com should look like:

image

The next step is we need to make a couple of changes to our project structure. Our current project structure should look like this:

image

Notice the environments directory. This directory should have a sub-directory for each environment you wish to support per stack. Eg- prod and sdlc. Expanded view should look like:

image

The last configuration step in this process is optional. In each environment directory located in environments, you can create a defaults.yaml configuration file which can be used to store common configuration items, for a specific environment. These would be common reusable values all stacks in an environment share.

Our project setup is now complete. Before we execute a pulumi up or pulumi preview, we need to account for one details. The Pulumi CLI, be default, looks in the root directory of the Pulumi project for a stack configuration file. For example, if the stack is named sdlc-ks123 the Pulumi CLI will look for a yaml file named Pulumi.sdlc-ks123.yaml located in the root directory of the project. If this file is not found, an error will be experienced.

To accomodate for our custom configuration directories, we will take advantage of an optional flag/parameter Pulumi allows when using preview or up, the --config-file flag. According to pulumi docs the flag allows "Use the configuration values in the specified file rather than detecting the file name"

Wrapping up, we now must specify what config we want Pulumi to utilize when executing an up or preview. For example, using the sdlc-ks123 stack, we would exeucte a preview with pulumi preview --config-file ./environments/sdlc/Pulumi.sdlc-123.yaml.

Populate the necessary pulumi configuration files, execute pulumi up, and see the different values retrieved! Using the output of our main.py file in this repo, the output looks as follows:

image

Simplifying Preview and Up Usage with Custom_Config

After reading the above documentation, one thing you'll notice about this solution is the --config-file flag is now required when executing a pulumi up or pulumi preview. In addition to that flag, you'll also need to specify the stack configuration file Pulumi will use to read the necessary configuration values. You can certainly build that the path to the config file each time you execute an up or preview, however, there are options to automating this step.

Using Stack Tags and Stack Name to Identify a Config File

One option is to use a combination of stack tags and stack name to automatically identify the config file location to pass with the --config-file flag. The one requirement we haven't discussed is the stack tag. You can read more about stack tags here.

With a single stack tag and the stack name we can simplify our up and preview commands by using:

  • pulumi preview --config-file ./environments/$(pulumi stack tag get ks:env)/Pulumi.$(pulumi stack --stack-name).yaml
  • pulumi up --config-file ./environments/$(pulumi stack tag get ks:env)/Pulumi.$(pulumi stack --stack-name).yaml

For every stack, you'll need to set a tag specifying the environment. Eg- pulumi stack tag set ks:env sdlc or pulumi stack tag set {my_env_key} {my_env_value}. You'll then be able to use the above up and preview calls without having to manually identify your stack configuration file!

Steps to Create a New Stack

  1. Create your new stack. Make sure the naming schema follows the above mentioned schema. Eg- pulumi stack init {env}-{customer_id}
  2. Tag your stack with the environment tag. Eg- pulumi stack tag set ks:env sdlc | prod
  3. Navigate to the environment folder for your stack and create a new Pulumi config file. Eg- cd ./environments/sdlc && pulumi config set some:key value This will create a new Pulumi config file.
  4. From the root directory of your Pulumi project, execute pulumi preview --config-file ./environments/$(pulumi stack tag get ks:env)/Pulumi.$(pulumi stack --stack-name).yaml