Recipe for write-audit-publish / blue-green deploy #4648
Labels
content
Improvements or additions to content
developer blog
This content fits on the developer blog.
idea
Proposes an idea for new content
priority: medium
Fix or enhancement to existing information that’s creating some requests from customers
size: large
This change will more than a week to address and might require more than one person
Contact Details
dbeatty10
I have read the dbt Developer Blog contribution guidelines.
Which of these best describes you?
What is the topic of your post?
We talked about blue/green deployments in this Developer Blog post:
But we haven't (yet!) provided some hands-on recipes for blue/green deployments that utilize
dbt clone
; we just linked here instead.Link to an initial outline.
Wanna run your data tests before exposing your models to downstream consumers?
Then a blue/green deploy (also known as the write-audit-publish paradigm) is what you are looking for, and
dbt clone
is one way to accomplish it.A blue/green deployment using
dbt clone
can build your models in a "blue" environment, run the data tests against it, and then surface the output in a "green" environment.Recipes
See below for some (rough) recipes we can play around with which are all variants on a similar theme.
Basically, we can use a regular
dbt build
that targets a (stand-alone and immutable) staging environment, and then usedbt clone
to update production references to point back to it.I don't know which is "best" -- these are just a handful of different approaches that I've tried with toy projects. They would need to more fully assessed and put through their paces before applying to production workloads.
Recipe 1
This recipe assumes that the name of your target directory appears within
clean-targets
. The--full-refresh
is crucial to overwrite any pre-existing objects in the green environment.Recipe 2
Second verse, similar to the first. Only real change is using an entire folder for storing the state and using a different method to clean out that state directory in between executions.
Recipe 3
Largely cosmetic change that just switches the order of some of the commands.
Recipe 4
This time we've included a helpful error message when any of the data tests don't pass (or the build fails for some other reason). Also experiments with alternative bash syntax for forcing a successful command, no matter what.
Project files
The models act as the initial "Write".
models/table_1.sql
models/view_1.sql
models/view_2.sql
The data tests act as the "Audit".
models/_models.sql
The "Publish" piece is purely through the
dbt clone
command (which uses the target definition inprofiles.yml
).profiles.yml
And generating the relevant database object names is via a custom
generate_schema_name
macro (and supporting macros).macros/get_custom_schema.sql
Outstanding Problems
profiles.yml
, but will work just fine if we use a repeatable and constant schema name likedbt_blue
History
The general pattern has probably been practiced in various forms for longer than we'll ever know. But it's been popularized in the collective consciousness under the monikers "blue/green" and "W.A.P.".
Blue/green deployments
Write-audit-publish
dbt
Gilding the lily
Someone with the last name name Blue that was an adherent of WAP at Netflix:
The text was updated successfully, but these errors were encountered: