forked from dfds/k8s-monitoring
-
Notifications
You must be signed in to change notification settings - Fork 2
/
azure-pipelines.yml
107 lines (95 loc) · 2.96 KB
/
azure-pipelines.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
# Pipeline deploying grafana dashboards as configmaps
trigger:
branches:
include:
- master
paths:
include:
- grafana/dashboards/*
pool:
vmImage: 'ubuntu-latest'
variables:
# all variable in the group library are loaded in the pipeline environment
- group: grafana-postgres-datasource
- group: grafana-deploy
steps:
### Add datasources and dashboards as configmaps
- task: replacetokens@3
# Using replace tokens for the postgres data source connections
inputs:
rootDirectory: "$(System.DefaultWorkingDirectory)/grafana/configmaps"
targetFiles: "datasource.yaml"
encoding: "auto"
writeBOM: true
actionOnMissing: "warn"
keepToken: false
tokenPrefix: "$("
tokenSuffix: ")"
useLegacyPattern: false
enableTransforms: false
enableTelemetry: false
- task: PowerShell@2
displayName: Converting json dashboards to configmaps
inputs:
targetType: 'filePath'
filePath: grafana/Convert-JSONToConfigmap.ps1
errorActionPreference: 'stop'
pwsh: true
workingDirectory: grafana/
- task: Kubernetes@1
displayName: kubectl apply configmaps
inputs:
connectionType: Kubernetes Service Connection
kubernetesServiceEndpoint: hellman-mlops-deploy
command: apply
arguments: -f grafana/configmaps
### Deploy grafana
- task: PowerShell@2
inputs:
targetType: 'inline'
script: |
kubectl --namespace $(NAMESPACE) create secret generic grafana-password --from-literal=admin-user=admin --from-literal=admin-password=$(ADMIN_PASSWORD) --dry-run=client -o yaml | Out-File k8s/secret.yaml
- task: Kubernetes@1
displayName: kubectl apply secret
inputs:
connectionType: Kubernetes Service Connection
kubernetesServiceEndpoint: hellman-mlops-deploy
command: apply
arguments: -f k8s/secret.yaml
- task: replacetokens@3
inputs:
targetFiles: "helm/values.yaml"
encoding: "auto"
writeBOM: true
actionOnMissing: "fail"
keepToken: false
tokenPrefix: "$("
tokenSuffix: ")"
- task: HelmDeploy@0
displayName: helm upgrade grafana
inputs:
connectionType: 'Kubernetes Service Connection'
kubernetesServiceEndpoint: hellman-mlops-deploy
command: upgrade
chartType: 'FilePath'
chartPath: 'helm/grafana-6.51.2.tgz'
namespace: $(NAMESPACE)
valueFile: helm/values.yaml
arguments: '--set admin.existingSecret=grafana-password'
releaseName: grafana
- task: replacetokens@3
inputs:
targetFiles: "k8s/ingressroute.yaml"
encoding: "auto"
writeBOM: true
actionOnMissing: "error"
keepToken: false
tokenPrefix: "$("
tokenSuffix: ")"
- task: Kubernetes@1
displayName: kubectl apply ingressroute
inputs:
connectionType: Kubernetes Service Connection
kubernetesServiceEndpoint: hellman-mlops-deploy
command: apply
arguments: -f k8s/ingressroute.yaml