#azure #powershell #azure-app-service-envrmnt #terraform-provider-azure
#azure #powershell #azure-app-service-envrmnt #terraform-provider-azure
Вопрос:
Я использую шаблон ARM для развертывания ILB ASE, который работает нормально, но сейчас я пытаюсь установить самозаверяющий сертификат на ILB ASE как часть этого развертывания, и он продолжает завершаться ошибкой The specified network password is not correct
.
На самом деле я применяю шаблон ARM через Terraform. Я храню сертификат и пароль в хранилище ключей. Я извлекаю сертификат из хранилища ключей, используя строку PowerShell ниже, а затем передаю его в Terraform в качестве переменной. Это сертификат в формате, закодированном в Base64:
$aseCertBase64 = (Get-AzureKeyVaultSecret -VaultName $kvName -Name $kvASECertName).SecretValueText
Сначала я попытался получить пароль сертификата, используя ресурс данных Terraform, но это развертывание завершилось неудачей с The specified network password is not correct
ошибкой. Пытаясь устранить проблему с паролем, я ввел пароль с открытым текстом непосредственно в шаблон ARM и повторно запустил развертывание. Развертывание снова завершилось неудачей с той же ошибкой, поэтому теперь я не уверен, что он ищет.
Я проверил правильность пароля, извлек сертификат и пароль из хранилища ключей с помощью PowerShell, преобразовал сертификат и затем успешно импортировал его в свое локальное хранилище.
Ниже приведен шаблон ARM, который я использую:
{
"$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"ilbase_name": {
"type": "string",
"metadata": {
"description": "The name of the ILBASE"
}
},
"ilbase_domain_name": {
"type": "string",
"metadata": {
"description": "The prviate domain name inside ILBASE"
}
},
"ilbase_subnet_name": {
"type": "string",
"metadata": {
"description": "The name of the subnet assigned to the ILBASE"
}
},
"ilbase_rglocation": {
"defaultValue": "East US",
"type": "string",
"metadata": {
"description": "The region where the ILBASE will be deployed"
}
},
"vnet_name": {
"type": "string",
"metadata": {
"description": "The name of the vnet the ILBASE subnet is part of"
}
},
"vnet_rg": {
"type": "string",
"metadata": {
"description": "The name of the resource group the ILBASE vnet is in"
}
},
"vnet_id": {
"type": "string",
"metadata": {
"description": "The resource id of the ILBASE vnet"
}
},
"aseCert": {
"type": "string",
"metadata": {
"description": "The Base64 encoded string containing the cert to be applied to the ILBASE"
}
},
"aseCertPwd": {
"defaultValue": "XNKVTzCell637BNl",
"type": "string",
"metadata": {
"description": "The password for the ILBASE certificate"
}
},
"aseCertName": {
"defaultValue": "aseCert",
"type": "string",
"metadata": {
"description": "The password for the ILBASE certificate"
}
}
},
"resources": [
{
"apiVersion": "2015-08-01",
"type": "Microsoft.Web/certificates",
"name": "[parameters('aseCertName')]",
"location": "[parameters('ilbase_rglocation')]",
"properties": {
"pfxBlob": "[parameters('aseCert')]",
"password": "[parameters('aseCertPwd')]",
"hostingEnvironmentProfile": {
"id": "[resourceId('Microsoft.Web/hostingEnvironments',parameters('ilbase_name'))]"
}
},
"dependsOn": [
"[concat('Microsoft.Web/hostingEnvironments/',parameters('ilbase_name'))]"
]
},
{
"apiVersion": "2018-02-01",
"type": "Microsoft.Web/hostingEnvironments",
"name": "[parameters('ilbase_name')]",
"kind": "ASEV2",
"location": "[parameters('ilbase_rglocation')]",
"properties": {
"name": "[parameters('ilbase_name')]",
"location": "[parameters('ilbase_rglocation')]",
"vnetName": "[parameters('vnet_name')]",
"vnetResourceGroup": "[parameters('vnet_rg')]",
"vnetSubnetName": "[parameters('ilbase_subnet_name')]",
"virtualNetwork": {
"Id": "[parameters('vnet_id')]",
"Subnet": "[parameters('ilbase_subnet_name')]"
},
"dnsSuffix": "[parameters('ilbase_domain_name')]",
"internalLoadBalancingMode": "Web, Publishing",
"multiSize": "Medium",
"multiRoleCount": 2,
"ipsslAddressCount": 0,
"networkAccessControlList": [],
"frontEndScaleFactor": 15,
"suspended": false
}
}
]
}
Ответ №1:
Рассмотрите возможность вызова параметра thumbPrint для сертификата. Я полагаю, что это требуется на основе шаблона ARM по умолчанию, который есть у Microsoft на GitHub здесь. Некоторая дополнительная ссылка здесь наlearn.microsoft.com.