我熟悉码头码头(dind),但使用与microsoft/azure-cli图像抛出docker command not found。
这是我对gitlab-ci.yml文件的设置。我已经创建了Service Principal,它用于对蔚蓝云和各自的资源组进行身份验证。
image: docker:latest
variables:
PASSWORD: *********
TENANT_ID: *****-************-*************
APP_ID: *********-*****-*****
CLIENT_ID: ****************
ACR_ID: *******************
stages:
- build
- deploy
services:
- docker:dind
before_script:
- docker info
build_staging_image:
stage: build
image: microsoft/azure-cli
script:
- az login --service-principal --username $APP_ID --password $PASSWORD --tenant $TENANT_ID
- docker build -t azure-vote:latest ./azure-vote
- docker tag azure-vote votingtestapp.azurecr.io/azure-vote:latest
- docker push votingtestapp.azurecr.io/azure-vote:latest
deploy:develop:
stage: deploy
script:
- az login --service-principal --username $APP_ID --password $PASSWORD --tenant $TENANT_ID
- az acr login --name votingTestApp
- az role assignment create --assignee $CLIENT_ID --role Reader --scope $ACR_ID
- kubectl apply -f azure-vote-all-in-one-redis.yaml
only:
- develop任何修复这个错误的方法。我只是尝试创建CI/CD管道。
发布于 2018-03-16 16:02:06
问题是,microsoft/azure-cli停靠库映像确实安装了对接器,并且没有将对接器套接字安装到容器上。这将导致docker命令失败。
您使用microsoft/azure-cli只是为了登录到registery。但是请注意,您也可以使用docker login登录。检查登录到注册表。
因此,要解决这个问题,请使用dind映像并使用以下方法登录到azure寄存器:
docker login myregistry.azurecr.io -u xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx -p myPasswordhttps://stackoverflow.com/questions/49324762
复制相似问题