-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathazure-pipelines-1.yml
executable file
·107 lines (94 loc) · 3.31 KB
/
azure-pipelines-1.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
# Deploy to Azure Kubernetes Service
# Build and push image to Azure Container Registry; Deploy to Azure Kubernetes Service
# https://docs.microsoft.com/azure/devops/pipelines/languages/docker
trigger:
- master
resources:
- repo: self
variables:
# Container registry service connection established during pipeline creation
dockerRegistryServiceConnection: '3e63a2da-ee1d-40dc-83fc-2d6e34d95ecb'
imageRepositoryApi: 'api-gateway'
imageRepositoryEvent: 'events-manager'
imageRepositoryCi: 'ci-service'
containerRegistry: 'fingreg.azurecr.io'
dockerfilePath-api: '$(Build.SourcesDirectory)/api-gateway/Dockerfile'
dockerfilePath-event: '$(Build.SourcesDirectory)/events-manager/Dockerfile'
dockerfilePath-ci: '$(Build.SourcesDirectory)/ci-service/Dockerfile'
dockerfilePath-cd: '$(Build.SourcesDirectory)/cd-service/Dockerfile'
dockerfilePath-cloud: '$(Build.SourcesDirectory)/cloud-mgmt/Dockerfile'
dockerfilePath-theye: '$(Build.SourcesDirectory)/theye-service/Dockerfile'
tag: '$(Build.BuildId)'
imagePullSecret: 'persys-dev'
# Agent VM image name
vmImageName: 'ubuntu-latest'
stages:
- stage: Build
displayName: Build stage
jobs:
- job: Build
displayName: Build
pool:
vmImage: $(vmImageName)
steps:
- task: Docker@2
displayName: Build and push an image to container registry
inputs:
command: buildAndPush
repository: $(imageRepositoryApi)
dockerfile: $(dockerfilePath-api)
containerRegistry: $(dockerRegistryServiceConnection)
tags: |
$(tag)
- task: Docker@2
displayName: Build and push an image to container registry
inputs:
command: buildAndPush
repository: $(imageRepositoryEvent)
dockerfile: $(dockerfilePath-event)
containerRegistry: $(dockerRegistryServiceConnection)
tags: |
$(tag)
- task: Docker@2
displayName: Build and push an image to container registry
inputs:
command: buildAndPush
repository: $(imageRepositoryCi)
dockerfile: $(dockerfilePath-ci)
containerRegistry: $(dockerRegistryServiceConnection)
tags: |
$(tag)
- upload: manifests
artifact: manifests
- stage: Deploy
displayName: Deploy stage
dependsOn: Build
jobs:
- deployment: Deploy
displayName: Deploy
pool:
vmImage: $(vmImageName)
environment: 'cicdcloudmanagement-6322.persys'
strategy:
runOnce:
deploy:
steps:
- task: KubernetesManifest@0
displayName: Create imagePullSecret
inputs:
action: createSecret
secretName: $(imagePullSecret)
dockerRegistryEndpoint: $(dockerRegistryServiceConnection)
- task: KubernetesManifest@0
displayName: Deploy to Kubernetes cluster
inputs:
action: deploy
manifests: |
$(Pipeline.Workspace)/manifests/deployment.yml
$(Pipeline.Workspace)/manifests/service.yml
containers: |
fingreg.azurecr.io/$(imageRepositoryApi):$(Build.BuildId)
fingreg.azurecr.io/$(imageRepositoryEvent):$(Build.BuildId)
fingreg.azurecr.io/$(imageRepositoryCi):$(Build.BuildId)
imagePullSecrets: |
$(imagePullSecret)