forked from Azure/application-gateway-kubernetes-ingress
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
continous deployment example (Azure#665)
- Loading branch information
1 parent
4b18ce4
commit 17c9514
Showing
12 changed files
with
452 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
# Continuous Deployment with AKS and AGIC using Azure Pipelines | ||
|
||
To achieve an efficiently deployed and managed global infrastucture, it is important to setup workflows for continuous integration and deployment. `Azure Devops` is one of the options to achieve this goal. | ||
|
||
In following example, we setup a Azure Devops release pipeline to deploy an AKS cluster along with AGIC as ingress. This example is merely a scaffolding. You need to separately setup a build pipeline to install your application and ingress on the AKS cluster deployed as part of the release. | ||
|
||
## Setup up new service connection with service pricipal | ||
|
||
> **Note**: Skip if already have service connection with owner access for role assigment | ||
1. Create a service principal to use with Azure Pipelines. This service principal will have owner access to current subscription. Access will be used to perform role assigement for AGIC identity in the pipeline. | ||
|
||
```bash | ||
az ad sp create-for-rbac -n azure-pipeline-cd --role owner | ||
# Copy the AppId and Password. We will use these in the next step. | ||
``` | ||
|
||
1. Now, create a [new service connection](https://docs.microsoft.com/en-us/azure/devops/pipelines/library/service-endpoints?view=azure-devops&tabs=yaml#create-a-service-connection) in Azure Devops. Select "*use the full version of the service connection dialog*" option so that you can provide the newly created service principal. | ||
data:image/s3,"s3://crabby-images/f21d6/f21d6e30626e51d79483f37094ea8e1bdff1a2c9" alt="Add Service Connection page" | ||
|
||
## Create a new Azure release pipeline | ||
|
||
We have prepared an [example release pipeline](./continuous-deployment-pipeline.json). This pipeline has following tasks: | ||
1. Deploy AKS Cluster | ||
1. Create a user assigned identity used by AGIC Pod | ||
1. Install Helm | ||
1. Install AAD Pod identity | ||
1. Install AGIC | ||
1. Install a [sample application (with ingress)](https://raw.githubusercontent.com/Azure/application-gateway-kubernetes-ingress/aksgupta/cd/docs/examples/aspnetapp.yaml) | ||
data:image/s3,"s3://crabby-images/73e9e/73e9e97a29f1a7c46297de4d48b82fd65945d41c" alt="workflows" | ||
|
||
To use the example release pipeline, | ||
1. Download the [template](./continuous-deployment-pipeline.json) and import it to your project's release pipeline. | ||
data:image/s3,"s3://crabby-images/64211/6421104205ef45e2ff2f37da822bdd1cd5ec546d" alt="import pipeline" | ||
1. Now provide the required settings for all tasks: | ||
1. Select the correct `Agent Pool` | ||
data:image/s3,"s3://crabby-images/87476/874763e6ce08235313eab9537f1ecc8b7e778015" alt="import pipeline" | ||
1. Select the newly created service conenction for the `Create Kubernetes Cluster` and `Create AGIC Identity` tasks. | ||
data:image/s3,"s3://crabby-images/35682/35682367cb42bebbe748dd172f727f6431545d76" alt="import pipeline" | ||
1. Provide the values for `clientId` and `clientSecret` that will be configured as cluster credentials for the AKS cluster. You should create a separate service principal for the AKS cluster for security reasons. | ||
```bash | ||
# create a new one and copy the appId and password to the variable section in the pipeline | ||
az ad sp create-for-rbac -n aks-cluster | ||
``` | ||
data:image/s3,"s3://crabby-images/4172a/4172a9d36a3796fe17c56719c7e348aea3b80071" alt="import pipeline" | ||
1. Click `Save`. Now your pipeline is all set up. | ||
Hit `Create release` and provide a location(Azure region) where you want the cluster to be deployed. | ||
data:image/s3,"s3://crabby-images/936b2/936b277eb516a13c15488c8a73c817bb2481c146" alt="import pipeline" | ||
Snapshot of how the AKS node resource group will look: | ||
data:image/s3,"s3://crabby-images/1a65c/1a65cc1e2c80f735a1fd296a0f150253eea063e7" alt="import pipeline" | ||
If this is your first deployment, AGIC will create a new application gateway. You should be able to visit the Application Gateway's ip address to visit the sample application. | ||
data:image/s3,"s3://crabby-images/947c7/947c78f5d4d550e16920643530bca0a4687a5b22" alt="import pipeline" |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.