You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

66 lines
3.4 KiB

7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
  1. # Kubernetes CI/CD VSTS
  2. For k8s CI/CD pipeline delivery a series of tasks must be created in VSTS to deploy k8s in Azure
  3. ## Prerequisites
  4. * A Kubernetes cluster. Follow Azure Container Service's [walkthrough](https://docs.microsoft.com/en-us/azure/container-service/container-service-kubernetes-walkthrough) to create one.
  5. * A private Docker registry. Follow Azure Container Registry's [guide](https://docs.microsoft.com/en-us/azure/container-registry/container-registry-get-started-portal) to create one.
  6. * Optionally, previous steps can be skipped if you run gen-k8s-env.ps1 (or gen-k8s-env-aks.ps1 if you would like to use AKS instead of ACS) script to automatically create the azure environment needed for kubernetes deployment. Azure cli 2.0 must be previously installed [installation guide](https://docs.microsoft.com/en-us/cli/azure/install-azure-cli). For example:
  7. >```
  8. >./gen-k8s-env -resourceGroupName k8sGroup -location westeurope -registryName k8sregistry -orchestratorName k8s-cluster -dnsName k8s-dns
  9. >```
  10. or using AKS instead of ACS
  11. >```
  12. >./gen-k8s-env-aks -resourceGroupName k8sGroup -location westeurope -registryName k8sregistry -dnsName k8s-dns -serviceName k8s-cluster -createAcr true -nodeCount 3 -nodeVMSize Standard_D2_v2
  13. >```
  14. * An `Azure Blob storage`. It is needed for storing the kubernetes config file used by the hosted agent to access to Kubernetes cluster. Example:
  15. <img src="./img/k8s/blob_creation.png">
  16. * Upload the `kubernetes config file` to the blob storage previously created. Execute the following command which will download the config file into the directory `c:\Users\<User>\.kube\` and then, upload it to your blob storage:
  17. >```
  18. >https://eshopk8s.blob.core.windows.net/k8s-config/config
  19. >```
  20. ## Create the VSTS tasks
  21. 1. Create a `Download File` task to download the kubernetes binary `kubectl` to the hosted agent. For example:
  22. >```
  23. >https://storage.googleapis.com/kubernetes-release/release/v1.8.5/bin/windows/386/kubectl.exe
  24. >```
  25. <img src="./img/get_kubectlbin_task.png">
  26. 2. Create a Download File task to download the kubernetes config file to the hosted agent. For example:
  27. >```
  28. >https://eshopk8s.blob.core.windows.net/k8s-config/config
  29. >```
  30. <img src="./img/k8s/get_kubectlconfig_task.png">
  31. 3. Create a powershell task to execute the k8s deployment script. For example:
  32. * Deployment script path
  33. >```
  34. >$(System.DefaultWorkingDirectory)/All Microservices/docker-compose/deploy.ps1
  35. >```
  36. * Deployment script path arguments. Use value:
  37. >```
  38. >-deployCI $true -execPath '$(System.DefaultWorkingDirectory)/' -kubeconfigPath '$(System.DefaultWorkingDirectory)/' -deployInfrastructure $true -imageTag dev -configFile '$(System.DefaultWorkingDirectory)/$(Build.DefinitionName)/docker-compose/conf_local.yml'
  39. >```
  40. - deployCI: Must be set to `$true`. This avoids create images (always are pulled from registry) and compile bits.
  41. - deployInfrastructure: Can be set to `$false` if don't want to deploy infrastructure containers (like Redis, rabbit, SQL,...).
  42. - imageTag: Image tag to pull from k8s.
  43. - configFile: Configuration file (refer to [README.k8s.md](./README.k8s.md) for more info). This file is part of the VSTS build output.
  44. - execPath: path where the k8s binary is stored
  45. - kubeconfigPath: path where the k8s config file is stored
  46. You can use additional parameters (i.e. pass registry and user/password to use custom registry instead of DockerHub. Plase, refer to [README.k8s.md](./README.k8s.md) for more info.
  47. <img src="./img/k8s/deploy_script_task.png">