diff --git a/runbooks/source/delete-cluster.html.md.erb b/runbooks/source/delete-cluster.html.md.erb index 381255ba..18adfec6 100644 --- a/runbooks/source/delete-cluster.html.md.erb +++ b/runbooks/source/delete-cluster.html.md.erb @@ -121,4 +121,3 @@ $ terraform workspace delete ${cluster} [pipelines repo]: https://github.com/ministryofjustice/cloud-platform-terraform-concourse/tree/main/pipelines/manager/main [concourse-vars]: https://concourse-ci.org/vars.html#var-syntax [concourse-static-vars]: https://concourse-ci.org/vars.html#static-vars -[Delete an EKS Cluster]: eks-cluster.html#4-delete-the-eks-cluster diff --git a/runbooks/source/eks-cluster.html.md.erb b/runbooks/source/eks-cluster.html.md.erb index 7c3da3fb..2bfe781d 100644 --- a/runbooks/source/eks-cluster.html.md.erb +++ b/runbooks/source/eks-cluster.html.md.erb @@ -1,7 +1,7 @@ --- title: EKS Cluster weight: 350 -last_reviewed_on: 2024-07-08 +last_reviewed_on: 2024-08-08 review_in: 6 months --- @@ -23,14 +23,14 @@ Alternatively, if you want to create a cluster manually, follow the steps below. export AWS_PROFILE=moj-cp ``` -- Your GPG key must be added to the [infrastructure repo](https://github.com/ministryofjustice/cloud-platform-infrastructure) so that you are able to run `git-crypt unlock` (the script will run this for you, but you must be *able* to do it) +- Your GPG key must be added to the [infrastructure repo](https://github.com/ministryofjustice/cloud-platform-infrastructure) so that you are able to run `git-crypt unlock`. - You have [docker](https://docs.docker.com/get-docker/) installed - An AWS iam user with "AdministratorAccess", this can be achieved by adding a user to the [cloud-platform-terraform-awsaccounts-iam](https://github.com/ministryofjustice/cloud-platform-terraform-awsaccounts-iam) repo - Make sure your user is added to the `terraform/aws-accounts/cloud-platform-aws/vpc/eks/cluster.tf -> module -> eks -> map_users` in [cloud-platform-infrastructure](https://github.com/ministryofjustice/cloud-platform-infrastructure) and that is deployed on main) ## Environment Variables -See the file [example.env.create-cluster](https://github.com/ministryofjustice/cloud-platform-infrastructure/blob/main/example.env.create-cluster) in the infrastructure repo. This shows examples of the environment variables which must be set in order to run the `create-cluster.rb` script to create a new cluster. +See the file [example.env.create-cluster](https://github.com/ministryofjustice/cloud-platform-infrastructure/blob/main/example.env.create-cluster) in the infrastructure repo. You can get the auth0 values from the `terraform-provider-auth0` application on [justice-cloud-platform - auth0](https://auth0.com/docs/authenticate/login). @@ -42,14 +42,18 @@ export AUTH0_CLIENT_ID= export AUTH0_CLIENT_SECRET= ``` -Execute the cloud-platform command to create a new cluster: +## Provisioning an EKS cluster with the cloud-platform CLI + +- In your terminal, navigate to the root of the `cloud-platform-infrastructure` repository. + +- Ensure your local git-crypted files are decryped with `git-crypt unlock` + +- Execute the cloud-platform command to create a new cluster: ```bash cloud-platform cluster create --name ``` -Check the pre-requisites and environment variables section of this document before running this script. - NB: Your cluster name must be **no more than 12 characters**. Any longer, and some of the computed strings which include the cluster name will exceed their maximum allowed values. The error messages you get if this happens are unhelpful. In order to prevent this, the build script will fail immediately if you supply a name which is too long. See our [cluster naming policy](https://github.com/ministryofjustice/cloud-platform/blob/main/architecture-decision-record/009-Naming-convention-for-clusters.md) for information on how to choose a suitable name for your cluster. @@ -77,7 +81,7 @@ process. The number of tests will change, so the output will vary from what is s Alternatively, if you need more control over the test cluster parameters, or you just prefer to do it manually, the rest of this document describes the process. -## Provisioning +## Manually provisioning a cluster ### 1. VPC @@ -92,7 +96,7 @@ terraform apply You should be able to see your new VPC (called `WorkspaceName`) inside the AWS Console. Check it before jumping to the next step. -**NOTE**: For conventions purposes please call all terraform workspaces the same. +**NOTE**: It is important that you use the same workspace name at each terraform level during this process. Please pick a workspace name that will make your cluster easily identifiable. ### 2. Creating EKS cluster @@ -167,6 +171,10 @@ terraform apply [cluster build pipeline]: https://concourse.cloud-platform.service.justice.gov.uk/teams/main/pipelines/create-cluster +## Deleting your test cluster + +Refer to [this runbook](delete-cluster.html) for various methods of deleting your cluster. + ## Provisioning a custom cluster If you're working on a task that involves changing/adding cluster configuration or components, you can have Concourse execute a clean cluster build for you based off your working infrastructure branch. Refer to the instructions detailed in the Concourse repository [pipelines README](https://github.com/ministryofjustice/cloud-platform-terraform-concourse/blob/main/pipelines/README.md#custom-cluster-pipeline) for the steps to follow. diff --git a/runbooks/source/joiners-guide.html.md.erb b/runbooks/source/joiners-guide.html.md.erb index 14e83a26..9799f09e 100644 --- a/runbooks/source/joiners-guide.html.md.erb +++ b/runbooks/source/joiners-guide.html.md.erb @@ -1,7 +1,7 @@ --- title: Onboarding into the Cloud Platform Team weight: 9000 -last_reviewed_on: 2024-03-19 +last_reviewed_on: 2024-08-08 review_in: 6 months --- @@ -53,7 +53,7 @@ review_in: 6 months ## Access -* Access to AWS accounts this includes MOJ DSD +* Access to required Cloud Platform AWS account(s) * Protect against accidentally pushing secrets to GitHub, using [git-secrets] ```bash @@ -70,7 +70,7 @@ git config --global init.templateDir ~/.git-templates/git-secrets * Add to [MoJ 1Password](https://ministryofjustice.1password.eu/) * Authenticate to live cluster * Add User to [EKS Admins group](https://github.com/ministryofjustice/cloud-platform-infrastructure/blob/main/terraform/aws-accounts/cloud-platform-aws/vpc/eks/cluster.tf) -* Create and destroy test cluster +* Create and destroy [test cluster](eks-cluster.html) * Access to pagerduty * Create GPG key * Add [GPG and SSH keys](https://github.com/settings/keys) to github user account (if not already there)