- tl;dr;
- åç½®ã
- ã¢ããã¼ã·ã§ã³
- ãã³ãã¬ã¼ããªãã¸ããªã«ã¤ãã¦
- é å¼µã£ãç¹ï¼Terraformãå®è¡ããããã®åæè¨å®ãCloud FormationãDeployment Managerã§è¡ãããã«ãã
tl;dr;
åç½®ã
9æãããã«GitHub Actionsã§OpenID Connectorï¼ä»¥ä¸OIDCï¼ãç¨ããèªè¨¼ãå©ç¨ãããã¨ãã§ããããã«ãªãã¾ããã
CIä¸ã§AWSãGCPã®APIãå©ç¨ããå ´åã¯é常IAM Userã®AWS_ACCESS_KEY_IDãAWS_SECRET_ACCESS_KEYï¼AWSã®å ´åï¼ããµã¼ãã¹ã¢ã«ã¦ã³ãã®ãã¼ãã¡ã¤ã«ï¼GCPã®å ´åï¼ããªãã¸ããªã®Secretsã«è¨å®ãããã¨ã«ãªãã¾ãããOIDCã«ãããããã®æ©å¾®æ å ±ã®çæèªä½ãä¸è¦ã«ãªãã¾ãããï¼keylessï¼
ã¢ããã¼ã·ã§ã³
OIDCã¯ä¾¿å©ã ãã°ã°ãã°ãããã§ãæ å ±ã¯åºã¦ããã®ã§ãããTerraformã®ãªãã¸ããªãä½ã度ã«èª¿ã¹ãã諸ã è¨å®ããã®ã大å¤ãªã®ã§æ¥½ãããããã«ãã³ãã¬ã¼ããªãã¸ããªãä½ãã¾ããã
ãã³ãã¬ã¼ããªãã¸ããªã«ã¤ãã¦
Terraformãªãã¸ããªã®ä½ãæ¹ãCIã®ã¯ã¼ã¯ããã¼ã¯æ§ã ãªæµæ´¾ãããã¾ãããèªåããããã
- PullRequestã§
terraform plan
,terraform fmt
,tflint
ãå®è¡ãã¤ã¤ãplançµæãPullRequestã«ã³ã¡ã³ããã - mainãã©ã³ãã§ã¯
terraform apply
ãå®è¡ - Slackéç¥
ã®ãããªä¸çªã·ã³ãã«ãªãã¿ã¼ã³ããã³ãã¬ã¼ããªãã¸ããªã«ãã¦ãã¾ãã
é å¼µã£ãç¹ï¼Terraformãå®è¡ããããã®åæè¨å®ãCloud FormationãDeployment Managerã§è¡ãããã«ãã
Terraformãå®è¡ããããã«ã¯ terraform.tfstate
ãç½®ãããã®ãã±ãããä½æãããAWSã®å ´åã¯æä»ããã¯ã®ããã®DynamoDBã®ãã¼ãã«ãå¿
è¦ã§ãGitHubã®OIDCã®ããã«ãããã¤ãè¨å®ãå¿
è¦ã§ãã
ãã®ãããªåæè¨å®ãï¼ã»ã¼ï¼ä¸çºã§çµããããããã«Cloud FormationãDeployment Managerã®è¨å®ãã¡ã¤ã«ãä½æãã¾ããã
- https://github.com/sue445/terraform-aws-template/blob/main/cloud_formation/setup-terraform.yml
- https://github.com/sue445/terraform-gcp-template/blob/main/deployment-manager/setup-terraform.jinja
åãªãã¸ããªã®READMEã«ãæ¸ãã¦ã¾ãããã³ãã¬ã¼ãããæ°è¦ãªãã¸ããªãä½ã£ãå¾ã«ããã¤ãã®æé ãè¸ãã ãã§GitHub Actionsã§Terraformãå®è¡ã§ããããã«ãªãã¾ãã
ãã ãGCPã®Deployment Managerã ã¨ç¾æç¹ã§Workload Identity Poolãä½æã§ããªããããDeployment Managerã§Terraformç¨ã®GCSãã±ããããµã¼ãã¹ã¢ã«ã¦ã³ããä½ã£ãå¾ã§ãã¼ã«ã«ããã® terraform apply
ã§Workload Identity Poolãä½ãããã«ãã¦ãã¾ãã
Terraformã®å®è¡ã«å¿ è¦ãªãªã½ã¼ã¹ãTerraformã§ä½ãã®ã¯å人çã«ã¯æ°æã¡æªããããã®ã§ãããgcloudã³ãã³ãã2ï½3åå©ãããã®ãã»ããã¢ããã®æéãå¢ãã¦å«ãªã®ã§Terraformã§ä½ã£ã¦ã¾ããï¼Deployment ManagerãWorkload Identity Poolã«å¯¾å¿ããããããã...ï¼
AWSã«é¢ãã¦ã¯Cloud Formationã®ã³ã³ã½ã¼ã«ããè¨å®ãã¡ã¤ã«ãã¢ãããã¼ãããã ãã§Terraformã®å®è¡ã«å¿ è¦ãªãªã½ã¼ã¹ãå ¨ã¦ä½ãã¾ãã