Skip to content

Commit

Permalink
Update documentation for how to perform rollbacks (#3878)
Browse files Browse the repository at this point in the history
* Update documentation for how to perform rollbacks

* Add further context about the workflows triggered by publishing a release.

Co-authored-by: zack <[email protected]>

* lint

---------

Co-authored-by: zack <[email protected]>
  • Loading branch information
stacimc and zackkrida authored Mar 8, 2024
1 parent 5ee011b commit 9460b14
Show file tree
Hide file tree
Showing 5 changed files with 39 additions and 29 deletions.
11 changes: 6 additions & 5 deletions documentation/api/guides/deploy.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,10 +21,11 @@ For more information on how deployments work, please see the [general deployment
and verify the SHA is the same as the value you deployed.
1. Review and Approve the automatically-generated changelog pull request in the
repository.
1. In the event of errors or problems, repeat the deployment process using the
latest stable version of the application. You can find the release version
number in the [changelogs](/changelogs/index), and then the tag to pass to
the action is the version number prefixed with "rel-", for example
"rel-2023.07.03.17.52.00".
1. In the event of errors or problems, rollback the application by running the
appropriate deployment workflow from the WordPress/openverse-infrastructure
repository using the tag of the latest stable version. You can find the
release version number in the [changelogs](/changelogs/index), and then the
tag to pass to the workflow is the version number prefixed with "rel-", for
example "rel-2023.07.03.17.52.00".
1. If anything else goes wrong or service is disrupted, consider this a
Production Incident and notify the team.
11 changes: 6 additions & 5 deletions documentation/catalog/guides/deploy.md
Original file line number Diff line number Diff line change
Expand Up @@ -44,10 +44,11 @@ the app is built and tagged, deploy production:
repository.
1. Push up a PR to the infrastructure repository with the Terraform changes you
pushed (the version bump for the relevant module).
1. In the event of errors or problems, repeat the deployment process using the
latest stable version of the application. You can find the release version
number in the [changelogs](/changelogs/index), and then the tag to pass to
the action is the version number prefixed with "rel-", for example
"rel-2023.07.03.17.52.00".
1. In the event of errors or problems, rollback the application by running the
appropriate deployment workflow from the WordPress/openverse-infrastructure
repository using the tag of the latest stable version. You can find the
release version number in the [changelogs](/changelogs/index), and then the
tag to pass to the action is the version number prefixed with "rel-", for
example "rel-2023.07.03.17.52.00".
1. If anything else goes wrong or service is disrupted, consider this a
Production Incident and notify the team.
9 changes: 5 additions & 4 deletions documentation/frontend/guides/deploy.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,10 +21,11 @@ For more information on how deployments work, please see the [general deployment
verify the SHA is the same as the value you deployed.
1. Review and Approve the automatically-generated changelog pull request in the
repository.
1. In the event of errors or problems, repeat the deployment process using the
latest stable version of the application. You can find the release version
number in the [changelogs](/changelogs/index), and then the tag to pass to
the action is the version number prefixed with "rel-", for example
1. rollback the application by running the appropriate deployment workflow from
the WordPress/openverse-infrastructure repository using the tag of the latest
stable version. You can find the release version number in the
[changelogs](/changelogs/index), and then the tag to pass to the action is
the version number prefixed with "rel-", for example
"rel-2023.07.03.17.52.00".
1. Add any new analytics events to Plausible:

Expand Down
26 changes: 16 additions & 10 deletions documentation/general/deployment.md
Original file line number Diff line number Diff line change
Expand Up @@ -148,11 +148,14 @@ release for an application. Publishing a release automatically tags the latest
docker image for the application and opens a PR to add the changelog to the
[documentation site's changelog directory](https://docs.openverse.org/changelogs/index.html).
This needs to be manually approved and merged by maintainers. The person who
triggers the release app workflow is pinged in the PR description to help with
the visibility of the PR.
publishes the release is pinged in the PR description to help with the
visibility of the PR.

For the API and frontend, publishing the release also triggers an automated
production deployment. For the catalog and ingestion server, however,
production deployment using the
[release app workflow](https://github.com/WordPress/openverse/blob/main/.github/workflows/release-app.yml),
which itself triggers the appropriate _deploy_ app workflow in the
infrastructure repository. For the catalog and ingestion server, however,
maintainers must manually deploy the changes to production using the Terraform
deployment process.

Expand All @@ -163,8 +166,11 @@ realise that the deployed code is not behaving as we expected. In these cases it
may be necessary to force an environment to be deployed to a specific version,
usually the previous version of the application.

The same staging and production deployment workflows are used directly to
rollback any environment for any service. Only members of the
The same staging and production deployment workflows in the
WordPress/openverse-infrastructure repository are used directly to rollback any
environment for any service. **Do not attempt to perform a rollback using the
release-app workflow in the monorepo, or by creating a new release; this will
result in the creation of duplicate tags.** Only members of the
@WordPress/openverse-maintainers GitHub team are able to dispatch the workflows
to completion. Anyone else who tries to dispatch them will have the workflow
automatically fail.
Expand Down Expand Up @@ -201,12 +207,12 @@ it. Please see the
this yourself (i.e., if you do not have the ability to make changes to our
Terraform configuration)

2. Deploy the code that depends on the new or updated variable by dispatching
the appropriate deployment workflow for the application and environment that
was updated.
2. Deploy the code that depends on the new or updated variable by publishing the
release for the application and environment that was updated.
- If the application only needs to be re-deployed to the already
running-version, dispatch the workflow with the version present at the
version endpoint for the application. See the "version endpoint" in the
running-version, dispatch the appropriate deployment workflow in the
WordPress/openverse-infrastructure repository with the application's
current version. See the "version endpoint" in the
[real-time deployment information](#real-time-deployment-information)
tables above to determine the currently running version.

Expand Down
11 changes: 6 additions & 5 deletions documentation/ingestion_server/guides/deploy.md
Original file line number Diff line number Diff line change
Expand Up @@ -33,10 +33,11 @@
1. Push up a PR to the infrastructure repository with the Terraform changes you
pushed (the version bump for the relevant module). Be sure to restore the
value of `data_refresh_cleared` back to `false`.
1. In the event of errors or problems, repeat the deployment process using the
latest stable version of the application. You can find the release version
number in the [changelogs](/changelogs/index), and then the tag to pass to
the action is the version number prefixed with "rel-", for example
"rel-2023.07.03.17.52.00".
1. In the event of errors or problems, rollback the application by running the
appropriate deployment workflow from the WordPress/openverse-infrastructure
repository using the tag of the latest stable version. You can find the
release version number in the [changelogs](/changelogs/index), and then the
tag to pass to the action is the version number prefixed with "rel-", for
example "rel-2023.07.03.17.52.00".
1. If anything else goes wrong or service is disrupted, consider this a
Production Incident and notify the team.

0 comments on commit 9460b14

Please sign in to comment.