This repository includes the ARM templates for Project Jackson.
Regional resources depend on Global ARM resources. Complete this deployment first, so those variables can be used below.
To deploy all the global resources, see the Global Readme which includes details on populating a CosmosDB instance with test data.
To deploy all the resources, the script deploy.sh can be used. The below values are required as inputs to the script:
- Azure Subscription ID
- Azure Resource Group (Add existing if one exists; else create a new one)
- Azure Deployment Location (i.e., EastUS, WestUS)
- App-name: Application Name
Another way to deploy is to run one-click deploy for all resources using Deploy to Azure:
Once the ACR is deployed, follow these manual steps to set up CD pipeline:
- Create a new variable group in Azure Pipeline Library
- Create variable ACR_SERVER and set value to the server name, which will be the output of your deployment (container.azurecr.io)
- Get values of username and password from container using Azure Portal
- Create variables ACR_USERNAME and ACR_PASSWORD and set them to the values you got from the Azure Portal.
Your deployment resources can now be used as part of your CD pipeline.
- Different environments like Dev, QA, Staging and Production environments are created under the resource group for all the resources to be deployed using ARM Template.
- Policies can be created between each of the environments to promote builds from one environment to another based on the requirements of the customer.
- These policies can differ for each customer and product.
- Once the tests under Dev environment passes, they can be approved to run on the QA environment based on policies set for approvals on each. These policies can be set under Azure DevOps Release Pipeline.
- A Redis cache is used to enhance query performance.
- The capacity of the Redis cache can be set to a value 1-6 in the ARM template.
- You can enable or disable non-SSL port in the ARM template.
- Azure allows 3 different values for the sku viz. Basic, Standard and Premium having different costs for each.
- The app service uses auto scaling.
- When the CPU usage for an instance exceeds 70%, the app will automatically be scaled to add another compute instance, up to 5 instances. This limit can be changed based on requirements.
- When memory usage for an instance exceeds 70%, the app will automatically be scaled to add another compute instance, up to 5 instances. This limit can be changed based on requirements.
- The minimum number of instances is set to 1. This means that if the memory used on an instance is less, the instances will be scaled down automatically.
To test the performance of an App Service:
- Navigate to the Azure Portal for your App Service
- Under
Developer Tools
selectPerformance Testing
- Select
New
- Name the new performance test and configure the settings appropriately
- Submit the test. After resources are automatically allocated, the test will run.
- After the test completes, Azure will automatically generate graphs and charts for analysis.