truemark/terraform-aws-pipeTerraform-Docker镜像是一个预配置的Docker环境,旨在为GitHub Actions或其他CI/CD管道提供AWS CLI和Terraform工具支持。该镜像消除了在工作流中手动安装和配置这些工具的需求,可直接用于执行AWS资源管理和Terraform基础设施即代码(IaC)相关命令,简化自动化部署流程。
latest、terraform-1.6-aws-2.15等),满足版本兼容性需求.github/workflows文件中作为步骤执行Terraform init/plan/apply或AWS CLI命令通过docker run命令直接执行Terraform或AWS CLI命令:
bash# 执行Terraform版本检查 docker run --rm truemark/terraform-docker:latest terraform --version # 执行AWS CLI命令 docker run --rm -e AWS_ACCESS_KEY_ID=AKIAEXAMPLE -e AWS_SECRET_ACCESS_KEY=secret truemark/terraform-docker:latest aws s3 ls
在GitHub Actions工作流文件(如.github/workflows/terraform.yml)中配置:
yamlname: Terraform CI/CD on: [push] jobs: terraform: runs-on: ubuntu-latest steps: - name: Checkout code uses: actions/checkout@v4 - name: Run Terraform plan uses: docker://truemark/terraform-docker:latest with: args: terraform plan env: AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} AWS_REGION: us-east-1 volumes: - ${{ github.workspace }}:/workspace working-directory: /workspace
| 环境变量 | 描述 | 示例值 |
|---|---|---|
AWS_ACCESS_KEY_ID | AWS访问密钥ID(用于认证) | AKIAEXAMPLE |
AWS_SECRET_ACCESS_KEY | AWS密钥密钥(用于认证) | secret123 |
AWS_REGION | 默认AWS区域 | us-east-1 |
TERRAFORM_CLI_CONFIG_FILE | Terraform配置文件路径 | /workspace/.terraformrc |
镜像提供多种标签对应不同版本组合,格式为terraform-<TERRAFORM_VERSION>-aws-<AWS_CLI_VERSION>,例如:
truemark/terraform-docker:terraform-1.6.0-aws-2.15.0(指定Terraform 1.6.0和AWS CLI 2.15.0)truemark/terraform-docker:latest(最新稳定版本组合)truemark/terraform-docker:alpine(基于Alpine的轻量级版本)通过挂载卷将工作目录或Terraform状态文件持久化:
bash# 挂载当前目录作为工作区 docker run --rm -v $(pwd):/workspace -w /workspace truemark/terraform-docker:latest terraform init
--rm参数自动清理容器,减少资源占用
manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务