所以我想使用terraform v0.12.0来定义我的天蓝色基础设施。我们公司对使用的东西进行了严格的限制,所以我有点不愿意使用Azure DevOps Marketplace的现成的构建/发布任务。所以我下载了exe,将它添加到代码中,我也可以直接在构建/发布代理上下载它。
因此,我用下面的代码使用Azure DevOps发布管道内置的任务Azure (v1.151.1)
call az login --service-principal -u $(clientid) -p $(clientsecret) --tenant $(tenantid)
call cd $(System.DefaultWorkingDirectory)/_DevOps/drop/Terraform/
call set ARM_ACCESS_KEY=$(az keyvault secret show --name mybackendkey --vault-name mykeyvault --query value -o tsv)
call set ARM_CLIENT_ID="$(clientid)"
call set ARM_CLIENT_SECRET="$(clientsecret)"
call set ARM_SUBSCRIPTION_ID="$(subscriptionid)"
call set ARM_TENANT_ID="$(tenantid)"
call terraform init -backend-config="storage_account_name=mystorageaccount" -backend-config="container_name=terraform-state" -backend-config="key=terraform.tfstate"
call terraform plan -input=false
call terraform apply -input=false使用以下terraform.tf文件
terraform {
backend "azurerm" {
storage_account_name = "mystorageaccount"
container_name = "terraform-state"
key = "terraform.tfstate"
resource_group_name = "myresourcegroup"
subscription_id = "00000000-0000-0000-0000-000000000000"
client_id = "00000000-0000-0000-0000-000000000000"
client_secret = "mysecret"
tenant_id = "00000000-0000-0000-0000-000000000000"
}
}现在,它给出了以下错误
2019-05-27T14:45:53.7470711Z D:\a\r1\a\_DevOps\drop\Terraform>call set ARM_ACCESS_KEY=$(az keyvault secret show --name mybackendkey --vault-name mykeyvault --query value -o tsv)
2019-05-27T14:45:53.7491727Z D:\a\r1\a\_DevOps\drop\Terraform>call set ARM_CLIENT_ID="***"
2019-05-27T14:45:53.7511373Z D:\a\r1\a\_DevOps\drop\Terraform>call set ARM_CLIENT_SECRET="***"
2019-05-27T14:45:53.7532794Z D:\a\r1\a\_DevOps\drop\Terraform>call set ARM_SUBSCRIPTION_ID="***"
2019-05-27T14:45:53.7554859Z D:\a\r1\a\_DevOps\drop\Terraform>call set ARM_TENANT_ID="***"
2019-05-27T14:45:53.7574875Z D:\a\r1\a\_DevOps\drop\Terraform>call terraform init -backend-config="storage_account_name=mystorageaccount" -backend-config="container_name=terraform-state" -backend-config="key=terraform.tfstate"
2019-05-27T14:45:53.9641074Z Initializing the backend...
2019-05-27T14:45:53.9721551Z Successfully configured the backend "azurerm"! Terraform will automatically
2019-05-27T14:45:53.9721831Z use this backend unless the backend configuration changes.
2019-05-27T14:45:53.9737291Z Error: Failed to get migrated workspaces: Error creating storage client for storage account "mystorageaccount": azure: malformed storage account key: illegal base64 data at input byte 0
2019-05-27T14:45:53.9856719Z D:\a\r1\a\_DevOps\drop\Terraform>call terraform plan -out=tfplan -input=false
2019-05-27T14:45:54.1177547Z Error: Error loading state: Error creating storage client for storage account "mystorageaccount": azure: malformed storage account key: illegal base64 data at input byte 0
2019-05-27T14:45:54.1302709Z D:\a\r1\a\_DevOps\drop\Terraform>call terraform apply -input=false tfplan
2019-05-27T14:45:54.2539375Z CreateFile tfplan: The system cannot find the file specified.
2019-05-27T14:45:54.2782991Z ##[error]Script failed with error: Error: D:\a\_temp\azureclitaskscript1558968322690.bat failed with return code: 1
2019-05-27T14:45:54.2899205Z [command]C:\windows\system32\cmd.exe /D /S /C ""C:\Program Files (x86)\Microsoft SDKs\Azure\CLI2\wbin\az.cmd" account clear"如果我把我的后端移到本地,它可以工作,反正我可以让它与Azure后端一起工作吗?顺便说一句,我从Azure Key Vault得到的秘密和Ids直接注入到DevOps样条中
发布于 2019-05-28 09:32:18
对于您的问题,正如错误显示通过环境变量设置的存储帐户访问键是错误的一样。作为您的注释,设置环境变量ARM_ACCESS_KEY是一种错误的方法。
我认为有两种方法可以解决这个问题。一种是使用DevOps方法设置环境变量。好像是个窗户主机。因此,另一种方法是以windows方式设置环境变量。
添加下面的窗口:
在PowerShell中:
$env:ARM_ACCESS_KEY=$(az keyvault secret show --name mybackendkey --vault-name mykeyvault --query value -o tsv)在CMD中,您似乎不能通过命令的输出直接设置环境变量,只需使用一个字符串来设置它。
set ARM_ACCESS_KEY="xxxxx"https://stackoverflow.com/questions/56337699
复制相似问题