Moving components
modules into core
In order to migrate a terraform module from components
into core
, there are a number of steps that need to be taken in order to make sure the process runs smoothly. From a high level, the terraform module needs to be moved and then tested in a test cluster.
The aim is to make sure that when a terraform plan is run against both core
and compoents
after the MTM tool is ran, there should be no terraform changes.
There is a pipeline in Concourse that accepts $CLUSTER_NAME
, $MODULE_NAME
and $RESOURCE
setting these and running the pipeline will migrate that module/resource on the cluster specified. Resources can be passed as comma-seperated strings. Getting a list of resources to migrate is a manual process that requires you to read through the terraform files in components
. Some can be found by tracing back dependencies, others should be obvious via there name. The name format for resources follow $resource_type.$resource name
so resource "kubernetes_storage_class" "storageclass"
becomes kubernetes_storage_class.storageclass
, you can double check this by running terraform state list
.
If you need to upgrade the mtm
cli, you can update the $MTM_VERSION
parameter in the pipeline.
Notes on the pipeline
The pipeline takes the following arguments:
cluster_name
- Name of the cluster to target e.g.cp-0001-0001
.module_name
- Name of the module to target e.g.cert_manager
.resource
- Name of the resource to target e.g.kubectl_manifest.prometheus_operator_crds
, accepts a comma-separated list for multiple resources.flagged_resource
Name of flagged resource to target, this is used for resources that need to be pulled out of a module, accepts a comma-separated list for multiple resources.
Because of the way concourse variables work, none of the above can be blank. You can pass a dummy string in like module.null
and the MTM tool will try to migrate a module/resource that doesn’t exist.
 Process
- Notify
#cloud-platform
that you are pausing concourse pipelines - Pause
bootstrap
,live-2
,manager
andlive
pipelines. - Raise a PR with migrated module
- Log in to Concourse using
fly -t moj-cp login -c https://concourse.cloud-platform.service.justice.gov.uk/
- Ensure you are in the
cloud-platform-terraform-concourse
directory. - Update pipelines with module and/or resource(s) name(s) and cluster name:
fly -t moj-cp set-pipeline --pipeline migrate-module --config migrate-module.yaml -v cluster_name=cp-0306-0730 -v module=tigera_calico -v resources=kubectl_manifest.calico_crds,http.calico_crds -v flagged_resources=module.null
- Run
migrate-module
pipeline from the Concourse UI. - Unpause pipeline environment-specific pipeline (e.g. live-2)
- Re-run PR plan - the plan should show “No changes. Your infrastructure matches the configuration.”
- Re-run step 5-9 with the next environment (e.g. manager)
- Get approval for the PR and merge.
- Un-pause
live-2
and check for a clean apply - Repeat 9. with
manager
andlive
- Update #cloud-platform informing the team of the completed migration and that pipelines are unpaused.
Disaster Recovery
If for some reason something goes wrong, then you can use the backed up state file to overwrite the remote.
Alternatively, all our tf state objects are versioned in S3 so you can restore a previous known working version from the AWS console.