-
Notifications
You must be signed in to change notification settings - Fork 0
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
docs: add rfc 007 static nonprod platform environment #159
Open
barkerl
wants to merge
142
commits into
main
Choose a base branch
from
add-rfc-007-static-nonprod-platform-environment
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from 140 commits
Commits
Show all changes
142 commits
Select commit
Hold shift + click to select a range
5441610
feat(terraform): vol5504 add single batch job
cmarstondvsa 2b85d46
feat(terraform): vol5504 add single batch job
cmarstondvsa 5a01872
feat(terraform): vol5504 add single batch job
cmarstondvsa 121937b
docs: update Terraform docs
github-actions[bot] 43a6718
feat(terraform): vol5504 add single batch job
cmarstondvsa 0c4b08b
feat(terraform): vol5504 add single batch job
cmarstondvsa 175fdaa
feat(terraform): vol5504 add single batch job
cmarstondvsa 46510c4
docs: update Terraform docs
github-actions[bot] 9915316
feat(terraform): vol5504 add single batch job
cmarstondvsa fe4eeec
feat(terraform): vol5504 add single batch job
cmarstondvsa 7248068
feat(terraform): vol5504 add single batch job
cmarstondvsa 656c85a
docs: update Terraform docs
github-actions[bot] 4bfbf53
feat(terraform): vol5504 add single batch job
cmarstondvsa fd41436
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa a9a15d2
docs: update Terraform docs
github-actions[bot] 57f0bce
feat(terraform): vol5504 add single batch job
cmarstondvsa 762e601
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa dfd518e
docs: update Terraform docs
github-actions[bot] 271aa4a
feat(terraform): vol5504 add single batch job
cmarstondvsa d565190
feat(terraform): vol5504 add single batch job
cmarstondvsa df89a0a
feat(terraform): vol5504 add single batch job
cmarstondvsa 7eb23f7
docs: update Terraform docs
github-actions[bot] 211cc89
feat(terraform): vol5504 add single batch job
cmarstondvsa 441eb6c
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa 91925ee
docs: update Terraform docs
github-actions[bot] 6a2881f
feat(terraform): vol5504 add single batch job
cmarstondvsa 8ddffe5
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa 957da96
docs: update Terraform docs
github-actions[bot] 5b228a5
feat(terraform): vol5504 add single batch job
cmarstondvsa aea89ae
docs: update Terraform docs
github-actions[bot] 4604948
feat(terraform): vol5504 add single batch job
cmarstondvsa 3b64b38
docs: update Terraform docs
github-actions[bot] af3898e
feat(terraform): vol5504 add single batch job
cmarstondvsa 85ab629
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa 52b3b09
feat(terraform): vol5504 add single batch job
cmarstondvsa 1b61aef
feat(terraform): vol5504 add single batch job
cmarstondvsa 17ccd2a
feat(terraform): vol5504 add single batch job
cmarstondvsa 9f4acf7
feat(terraform): vol5504 add single batch job
cmarstondvsa 19ec94c
docs: update Terraform docs
github-actions[bot] 00d924d
feat(terraform): vol5504 add single batch job
cmarstondvsa a0c4a1c
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa 8a98f58
feat(terraform): vol5504 add single batch job
cmarstondvsa 1450a6f
docs: update Terraform docs
github-actions[bot] 7064cea
feat(terraform): vol5504 add single batch job
cmarstondvsa 65539d8
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa 0bc3997
feat(terraform): vol5504 add single batch job
cmarstondvsa 9f350c8
feat(terraform): vol5504 add single batch job
cmarstondvsa 6b89685
feat(terraform): vol5504 add single batch job
cmarstondvsa 7a108ba
feat(terraform): vol5504 add single batch job
cmarstondvsa adbafab
feat(terraform): vol5504 add single batch job
cmarstondvsa d768aa1
feat(terraform): vol5504 add single batch job
cmarstondvsa 6a80885
feat(terraform): vol5504 add single batch job
cmarstondvsa fc0c3ad
docs: update Terraform docs
github-actions[bot] 1caf3d4
feat(terraform): vol5504 add single batch job
cmarstondvsa 4c0f074
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa b8de449
feat(terraform): vol5504 add single batch job
cmarstondvsa b814eb5
docs: update Terraform docs
github-actions[bot] 13ef98f
feat(terraform): vol5504 add single batch job
cmarstondvsa 636013b
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa e188c3a
feat(terraform): vol5504 add single batch job
cmarstondvsa aee2f98
docs: update Terraform docs
github-actions[bot] f522bb7
feat(terraform): vol5504 add single batch job
cmarstondvsa 685e7fd
feat(terraform): vol5504 add single batch job
cmarstondvsa d0e0e53
docs: update Terraform docs
github-actions[bot] a2ea5f3
feat(terraform): vol5504 add single batch job
cmarstondvsa 9c6c986
docs: update Terraform docs
github-actions[bot] 393a9b2
feat(terraform): vol5504 add single batch job
cmarstondvsa 64164e7
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa 7fd73cb
feat(terraform): vol5504 add single batch job
cmarstondvsa 4aded81
feat(terraform): vol5504 add single batch job
cmarstondvsa 3097968
feat(terraform): vol5504 add single batch job
cmarstondvsa bae9162
feat(terraform): vol5504 add single batch job
cmarstondvsa 7ca21c4
feat(terraform): vol5504 add single batch job
cmarstondvsa c05391e
feat(terraform): vol5504 add single batch job
cmarstondvsa af27d08
feat(terraform): vol5504 add single batch job
cmarstondvsa 5f980d6
feat(terraform): vol5504 add single batch job
cmarstondvsa 924aeeb
feat(terraform): vol5504 add single batch job
cmarstondvsa 1ebfa31
feat(terraform): vol5504 add single batch job
cmarstondvsa 38da013
docs: update Terraform docs
github-actions[bot] 9e62e49
feat(terraform): vol5504 add single batch job
cmarstondvsa 1579ccd
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa fe2ab3c
feat(terraform): vol5504 add single batch job
cmarstondvsa 5323fc0
feat(terraform): vol5504 add single batch job
cmarstondvsa ad534d7
feat(terraform): vol5504 add single batch job
cmarstondvsa bc0060f
feat(terraform): vol5504 add single batch job
cmarstondvsa bd012b8
feat(terraform): vol5504 add single batch job
cmarstondvsa 226f8a3
feat(terraform): vol5504 add single batch job
cmarstondvsa 601b65c
feat(terraform): vol5504 add single batch job
cmarstondvsa b364b1a
feat(terraform): vol5504 add single batch job
cmarstondvsa 47532ef
feat(terraform): vol5504 add single batch job
cmarstondvsa acce8aa
feat(terraform): vol5504 add single batch job
cmarstondvsa 1e21979
feat(terraform): vol5504 add single batch job
cmarstondvsa b828631
feat(terraform): vol5504 add single batch job
cmarstondvsa 9980da3
feat(terraform): vol5504 add single batch job
cmarstondvsa 45018e2
feat(terraform): vol5504 add single batch job
cmarstondvsa 0a59e25
docs: update Terraform docs
github-actions[bot] a6f7827
feat(terraform): vol5504 add single batch job
cmarstondvsa 274b7ee
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa 9954bd6
feat(terraform): vol5504 add single batch job
cmarstondvsa 78005b6
feat(terraform): vol5504 add single batch job
cmarstondvsa f741337
docs: update Terraform docs
github-actions[bot] 9677748
feat(terraform): vol5504 add single batch job
cmarstondvsa 4a0d43b
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa 510426a
docs: update Terraform docs
github-actions[bot] 5e145d1
feat(terraform): vol5504 add single batch job
cmarstondvsa ff45e36
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa 15319e6
docs: update Terraform docs
github-actions[bot] aba78ed
feat(terraform): vol5504 add single batch job
cmarstondvsa 87b1a8f
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa 4b896b6
feat(terraform): vol5504 add single batch job
cmarstondvsa f5f29a3
docs: update Terraform docs
github-actions[bot] cc52b05
feat(terraform): vol5504 add single batch job
cmarstondvsa aec40c3
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa 598829a
feat(terraform): vol5504 add single batch job
cmarstondvsa 87b0ff0
docs: update Terraform docs
github-actions[bot] a13f54d
formatting altered TF files using tf fmt
barkerl c27ac35
docs: update Terraform docs
github-actions[bot] 03306c4
feat(terraform): vol5504 add single batch job
cmarstondvsa ccf3fd8
feat(terraform): vol5504 add single batch job
cmarstondvsa 0279171
feat(terraform): vol5504 add single batch job
cmarstondvsa 9ed82c5
docs: update Terraform docs
github-actions[bot] 29f099b
feat(terraform): vol5504 add single batch job
cmarstondvsa 805d28c
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa e27b2c1
feat(terraform): vol5504 add single batch job
cmarstondvsa 02e279c
docs: update Terraform docs
github-actions[bot] 23dbe3f
feat(terraform): vol5504 add single batch job
cmarstondvsa ec40a06
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa 3acc511
feat(terraform): vol5504 add single batch job
cmarstondvsa 1718150
docs: update Terraform docs
github-actions[bot] e117f0c
addressing terraform fmt errors
barkerl 39b0301
docs: update Terraform docs
github-actions[bot] 08949d2
feat(terraform): vol5504 add single batch job
cmarstondvsa 7f17f6f
Merge branch 'vol5504-batch-cli-module' of https://github.com/dvsa/vo…
cmarstondvsa 60d6b0d
feat(terraform): vol5504 add single batch job
cmarstondvsa 219bbe0
Merge remote-tracking branch 'origin/main' into HEAD
barkerl 3130922
add-rfc-007-initial-commit
barkerl a0a40c1
fixing typo
barkerl b464042
rebased
barkerl 8a3cc82
docs: update Terraform docs
github-actions[bot] 96de3fb
missed empty lines
barkerl 165315d
Update docs/rfc/rfc-007-static-nonprod-platform-environment.md
barkerl a32455c
Update docs/rfc/rfc-007-static-nonprod-platform-environment.md
barkerl File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
# RFC-007: Static non-prod platform environmentq | ||
barkerl marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
## Summary | ||
|
||
This RFC proposes having a static platform environment (possibly QA) to be used by the infrastructure release pipeline. This is to provide an alternative route for any substantial infrastructure changes to attempt to prevent breaking or impeding the container path to live while being proved. | ||
|
||
## Problems | ||
|
||
### Application container release pipeline | ||
|
||
As per [rfc-005](https://github.com/dvsa/vol-app/blob/main/docs/rfc/rfc-005-add-terraform-to-mono-repository.md) the scope of terraform code deployed to the application repo was limited to prevent further Terraform dependency complexity. As the time of writing this has not been superseded by any future request for comment that amends this stance. | ||
barkerl marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
The existing pipeline fundamentally guides the deployment of containers to ECS clusters that sit upon the entirety of the VOL cloud infrastructure. Any change to just the container image (which as per current understanding will be a significant amount of the change requests going forward) will be efficient as per design. This means that container change will be ready for rapid promotion through the remaining three environment leading to decrease in release cadence. | ||
|
||
### Platform based changes and potential scope for disruption | ||
|
||
Infrastructure change will in most cases be broader and may involve a greater degree of proving. As such any breaking change will break the path to live for all other change being promoted to production. This has the potential to impede the progress we have made towards decreasing the release cadence. | ||
|
||
An additional static environment using containers will be cheap and will give the longer riskier changes a pathway to live, ensuring proving on the container based solution removing some of the risk of impeding container deployment and creating feature bottlenecks. | ||
|
||
## Proposal | ||
|
||
During the CI/CD workflow, once a change is merged to main we will deploy to an additional static non-prod environment in parallel to Int after proving in Dev. | ||
|
||
This will improve our deployment resilience when working on long-running potentially breaking changes while still allowing us to test on the existing containerised solution (currently this is only deployed to one non-prod environment). | ||
|
||
If this does not achieve the stated aim of testing long-running cloud changes on a representative environment then we will remove and apply directly to the Dev environment as per the container pipeline. This is accepting in the vol-terraform pipelines and accept the potential for blocking the promotion route to live for all changes. As part of this we should also monitor the usage. | ||
|
||
## Other options considered | ||
|
||
### Deploying changes directly to Dev for any functional testing | ||
|
||
This would allow us to test any functional capability along with the infrastructure change. It comes at the risk of delaying container change and preventing value being delivered as early as it could be from a delivery perspective. Given the reduced cost and complexity this container design is going to provide us it doesn't seem worth it. | ||
|
||
### Deploying to ephemeral environments | ||
|
||
Ephemeral environments won't allow us to effectively test the scope of a platform change in a single ephemeral environment. A network change (security group, Nacl etc.) break all ephemeral environments impeding all other container based change. |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
While I think the theory behind this is logical and makes sense. I believe there are more appropriate alternatives to solve this problem without adding what I believe is complexity to the code and development process.
The
dev
environment is a playground for the team, the team includes developers and platform engineers.Any breaking change that can't be fixed within a certain amount of time (which could vary, but we're the same team so can be raised) should be reverted,
git
and GitHub give us this functionality with a command/click. Once reverted, the environment will be back working.Feedback:
vol-terraform
repository, as thevol-app
will always be applyingmain
to this environment and usingmain
app version. This increases the cognitive load on a platform engineer while making changes in VOL as the test process will change depending on the nature of the change.vol-app
the team would need to test indev
.vol-app
andvol-terraform
the team would need to test indev
.vol-terraform
the team would need to test in the newly proposed environment.All said, I'm not a platform engineer so if the above doesn't persuade then I'll not stand in the way.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
my thoughts on this are that there is not foolproof pattern for continuous delivery and i think we have to understand what works for the service (otherwise there would be one pattern and tool set that everyone would use and that certainly isn't the case). The main platform changes going forward will be in the vol-terraform repo, as per rfc-005. To test changes to vol-terraform there will need to be a pipeline for that anyway as it isn't covered in the existing ones.
the test changes aren't quite correct, only if a change was made purely in the app component would we test in Dev. Anything else we would need to test in the new environment and then in dev/ephemeral.
Fundamental changes to the foundational elements of the platform (networks etc) that are changed semi regularly are potentially across all environments. This isn't about the effort but rather what these resources support and that is the important factor here. This is why the current ephemeral environment design may not have that use case, i would rather not have a pattern of applying and potentially breaking small well defined changes with the containers proving the case for a higher release cadence.
If we find that with the rationalisation that is continuing in VOL we are in a place where some of the concerns are not longer valid I will be the first to support tearing it down.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If you make a change in the
vol-app
andvol-terraform
, for the Terraform or app changes invol-app
to take effect (applied) they will need to be merged and indev
first for it to make it to the new environment. Without merging changes invol-app
they will not be deployed anywhere.As nothing is in place yet this is anticipating a theoretical problem in a theoretical solution, would a better way be to wait until we try the existing planned solutions (dev/ephemeral) to identify a practical problem and then iterate upon the solution we have? Rather than fixing the anticipated problem, and then tearing it down once (and if) it's proved to not be a problem?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.