Before you start the deployment, confirm that you have an Azure subscription with sufficient quota, and have implemented the prerequisites.
Start the deployment by clicking on the DEPLOY button on the main page - which is README.md in the GitHub, or the solutions page in the Cortana Gallery. Once you click on DEPLOY, the deployment platform takes you through a series of questions to set up the TRI. This section explains each parameter in detail.
Provide a deployment name. This name will be assigned to the resource group that contains all the resources required for the TRI.
Provide the name of the Azure subscription where you have set up the prerequisites such as VNET, domain controller etc. and where you want to deploy the reference implementation.
Choose the Data Center location where you want to deploy the reference implementation. This is a key benefit of the TRI - it saves you the effort of putting together all the products for an enterprise BI and Reporting solution that will be available together in a given Data Center.
Provide the description for this deployment.
Once you click on create, the resource group gets created in your subscription. This is so that Azure has some resource in the subscription to record all the subsequent parameters that you are about to provide next. After this CREATE step, if you want to abandon your deployment, follow the instructions to cleanly delete your deployment.
The next screen accepts the VNET parameters. If you created the VNET and provisioned the domain controller using the steps outlined in the prerequisites, then input the values you provided for the parameters.
-VNetName "ContosoVNet" -DomainName "contosodomain.ms" -DnsVmName "contosodns"
In addition to the certificates generated/used for VNET connectivity, you will need to provide three more certificates to manage secure access between the different components in the TRI.
- A .PFX file with the private key used by Azure VMs to authenticate with Azure Active Directory, with its corresponding password.
$certName = "Contoso Client"
$certPassword = ConvertTo-SecureString "<password>" -AsPlainText -Force
$cert = New-SelfSignedCertificate -DnsName $certName `
-CertStoreLocation cert:\LocalMachine\My `
-KeyExportPolicy Exportable `
-Provider "Microsoft Enhanced RSA and AES Cryptographic Provider"
Export-PfxCertificate -Cert $cert -FilePath contosoglobalcert.pfx -Password $certPassword -Force | Write-Verbose
- A .CER file with the public key of the certificate authority to allow SSL encryption from a non-public certificate.
$rootCertAuthorityName = "Contoso Certificate Authority"
$rootCert = New-SelfSignedCertificate -Type Custom -KeySpec Signature `
-Subject "CN=$rootCertAuthorityName" -KeyExportPolicy Exportable `
-HashAlgorithm sha256 -KeyLength 2048 `
-CertStoreLocation "Cert:\LocalMachine\My" -KeyUsageProperty Sign -KeyUsage CertSign
Export-Certificate -Cert $rootCert -FilePath contosoauthority.cer
- Another .PFX file with the private key used to encrypt all of web server traffic over HTTPS, with its corresponding password. Make sure that you replace "contosodomain.ms" with domain name specified during Domain Controller setup.
$dnsName = "*.adminui.contosodomain.ms" # make sure to replace "contosodomain.ms" with your Domain Name if it is different
$certPassword = ConvertTo-SecureString "<password>” -AsPlainText -Force
$sslCert = New-SelfSignedCertificate -DnsName $dnsName `
-CertStoreLocation cert:\LocalMachine\My -KeyExportPolicy Exportable `
-Provider "Microsoft Enhanced RSA and AES Cryptographic Provider" `
-Signer $rootCert `
-HashAlgorithm SHA256
Export-PfxCertificate -Cert $sslCert -FilePath contosossl.pfx -Password $certPassword -Force | Write-Verbose
These certificate files should be publicly available for your Azure subscription, and they must be secure. We recommend that you store the files in Azure Storage with Shared Access Signature (SAS) support. This will enable you to provide the certificates as Blob files, and set the password.
It is essential to generate the certificates above with -Provider "Microsoft Enhanced RSA and AES Cryptographic Provider"
parameter and -CertStoreLocation cert:\LocalMachine\My
. Otherwise, Azure Functions will not be able to download and decrypt the certificates and the deployment will fail during the "Download Certificate" step.
Examples:
- Private key used by VMs to authenticate with Azure Active Directory: http://contosoblob.blob.core.windows.net/certificates/_contosoglobalcert.pfx
- Public key of a certificate authority to allow SSL encryption from a non-public certificate: http://contosoblob.blob.core.windows.net/certificates/_contosoauthority.cer
- Private key used to encrypt all web server traffic over HTTPS: http://contosoblob.blob.core.windows.net/certificates/_contosossl.pfx
The parameters in this section are self-explanatory in the deployment configuration page.
The parameters in this section are self-explanatory in the deployment configuration page.