vmi*_*nko 12 deployment amazon-web-services gitlab docker gitlab-ci
我正在尝试使用官方 aws 映像运行 aws 命令(以使 cloudfront 无效),并具有以下 .gitlab-ci.yml 配置:
static-invalidation:
<<: *production-env
stage: static_invalidation
image: amazon/aws-cli:latest
variables:
AWS_ACCESS_KEY_ID: $CLOUDFRONT_AWS_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY: $CLOUDFRONT_AWS_SECRET_ACCESS_KEY
script:
- aws cloudfront create-invalidation --distribution-id $CLOUDFRONT_DISTRIBUTION --invalidation-batch file://deployment/configs/inv-batch.json
Run Code Online (Sandbox Code Playgroud)
作业失败并出现以下错误:
Using docker image sha256:00cf4f100b03d1b26e93cce377c1311c34efa753e379cd5c6ea5d458337cbaab for amazon/aws-cli:2.2.17 with digest amazon/aws-cli@sha256:39e9898fc43f618636a2190f82b9babcdc618d054e66b49c9959b9cd23285ade ...
usage: aws [options] <command> <subcommand> [<subcommand> ...] [parameters]
To see help text, you can run:
aws help
aws <command> help
aws <command> <subcommand> help
aws: error: argument command: Invalid choice, valid choices are:
accessanalyzer | acm
acm-pca | alexaforbusiness
...
ERROR: Job failed: exit code 252
Run Code Online (Sandbox Code Playgroud)
有什么想法为什么它不起作用吗?当我在本地运行该命令时,它可以工作。
小智 31
amazon/aws-cli
docker 已将入口点设置aws
为预期执行方式
$ docker run amazon/aws-cli cloudfront create-invalidation --distribution-id ...
Run Code Online (Sandbox Code Playgroud)
但 gitlab 期望 shell 的入口点,以便它可以执行script
命令。
查看 gitlab 文档:https://docs.gitlab.com/ee/ci/docker/using_docker_images.html#available-settings-for-image
您将在那里找到如何覆盖 docker 镜像入口点。
工作配置是:
image:
name: amazon/aws-cli:2.2.18
entrypoint: [""]
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
6215 次 |
最近记录: |