Compare commits
9 Commits
woodpecker
...
cc3991ad6d
Author | SHA1 | Date | |
---|---|---|---|
cc3991ad6d | |||
c72cc0b40f | |||
a7aaf4e98a | |||
e7bc2a962d | |||
698fa9e1d1 | |||
edc669507c | |||
87994b727f | |||
ebbad36f96 | |||
9f9086b0d6 |
41
.woodpecker/build.yaml
Normal file
41
.woodpecker/build.yaml
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
when:
|
||||||
|
- event: push
|
||||||
|
branch: woodpecker-deploy
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: 'Deploy user microservice'
|
||||||
|
image: marcin00.azurecr.io/azure-cli-kubectl:latest
|
||||||
|
environment:
|
||||||
|
CLIENT_ID: 'c302726f-fafb-4143-94c1-67a70975574a'
|
||||||
|
CLUSTER_NAME: 'build'
|
||||||
|
DEPLOY_FILES: 'namespace.yaml secret-store.yaml deploy.yaml ingress.yaml'
|
||||||
|
DEPLOYMENT: 'api'
|
||||||
|
HEALTHCHECK_URL: 'https://user-microservice.marcin00.pl/health'
|
||||||
|
NAMESPACE: 'user-microservice'
|
||||||
|
RESOURCE_GROUP: 'tst-aks-rg'
|
||||||
|
commands:
|
||||||
|
# Login to Azure & Get Kubeconfig
|
||||||
|
- az login --identity --client-id $CLIENT_ID
|
||||||
|
- az aks get-credentials --resource-group $RESOURCE_GROUP --name $CLUSTER_NAME --overwrite-existing
|
||||||
|
- kubelogin convert-kubeconfig -l azurecli
|
||||||
|
|
||||||
|
# Apply Kubernetes Resources
|
||||||
|
- for file in $DEPLOY_FILES; do kubectl apply -f "$file"; done
|
||||||
|
|
||||||
|
# Verify Deployment (waiting until all pods reach "ready" status)
|
||||||
|
- echo "Waiting for deployment rollout..."
|
||||||
|
- kubectl rollout status deployment/$DEPLOYMENT -n $NAMESPACE --timeout=60s
|
||||||
|
|
||||||
|
# Health Check
|
||||||
|
- echo "Checking app health $HEALTHCHECK_URL..."
|
||||||
|
for i in {1..30}; do
|
||||||
|
if curl -sf $HEALTHCHECK_URL; then
|
||||||
|
echo "Health check OK"
|
||||||
|
exit 0
|
||||||
|
else
|
||||||
|
echo "Health check failed. Retry \$i..."
|
||||||
|
sleep 5
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
echo "Health check failed."
|
||||||
|
exit 1
|
34
Jenkinsfile
vendored
34
Jenkinsfile
vendored
@ -1,34 +0,0 @@
|
|||||||
pipeline {
|
|
||||||
agent any
|
|
||||||
stages {
|
|
||||||
stage('Checkout') {
|
|
||||||
steps {
|
|
||||||
checkout scm
|
|
||||||
}
|
|
||||||
}
|
|
||||||
stage('Get credentials to Cluster') {
|
|
||||||
steps {
|
|
||||||
sh '''
|
|
||||||
az login --identity
|
|
||||||
az aks get-credentials --resource-group tst-aks-rg --name edu
|
|
||||||
kubelogin convert-kubeconfig -l azurecli
|
|
||||||
'''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
stage('Apply to Cluster') {
|
|
||||||
steps {
|
|
||||||
sh '''
|
|
||||||
kubectl apply -f namespace.yaml
|
|
||||||
kubectl apply -f secret-store.yaml
|
|
||||||
kubectl apply -f deploy.yaml
|
|
||||||
kubectl apply -f ingress.yaml
|
|
||||||
'''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
post {
|
|
||||||
cleanup {
|
|
||||||
sh 'rm -f ~/.kube/config || true'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -81,7 +81,7 @@ spec:
|
|||||||
spec:
|
spec:
|
||||||
containers:
|
containers:
|
||||||
- name: api
|
- name: api
|
||||||
image: marcin00.azurecr.io/user-microservice:76a351710fffe2be1ae10471bc1a2f511f481126
|
image: marcin00.azurecr.io/user-microservice:70726715642d9120a9cdc130a2625a398f777e4b
|
||||||
ports:
|
ports:
|
||||||
- containerPort: 80
|
- containerPort: 80
|
||||||
env:
|
env:
|
||||||
|
@ -4,7 +4,7 @@ metadata:
|
|||||||
name: deployer-binding
|
name: deployer-binding
|
||||||
subjects:
|
subjects:
|
||||||
- kind: User
|
- kind: User
|
||||||
name: daabce80-f745-413f-8377-00472517521c
|
name: f91aef65-7d2a-4df8-a884-e33b05d54a31
|
||||||
apiGroup: rbac.authorization.k8s.io
|
apiGroup: rbac.authorization.k8s.io
|
||||||
roleRef:
|
roleRef:
|
||||||
kind: ClusterRole
|
kind: ClusterRole
|
||||||
|
@ -24,8 +24,8 @@ spec:
|
|||||||
parameters:
|
parameters:
|
||||||
usePodIdentity: "false"
|
usePodIdentity: "false"
|
||||||
useVMManagedIdentity: "true"
|
useVMManagedIdentity: "true"
|
||||||
userAssignedIdentityID: "0c2780e4-8594-4aab-8f1a-8a19f71924bd" # client_id of the user-assigned managed identity
|
userAssignedIdentityID: "f91aef65-7d2a-4df8-a884-e33b05d54a31" # client_id of the user-assigned managed identity
|
||||||
clientID: "0c2780e4-8594-4aab-8f1a-8a19f71924bd" # client_id of the user-assigned managed identity
|
clientID: "f91aef65-7d2a-4df8-a884-e33b05d54a31" # client_id of the user-assigned managed identity
|
||||||
keyvaultName: "dev-aks"
|
keyvaultName: "dev-aks"
|
||||||
objects: |
|
objects: |
|
||||||
array:
|
array:
|
||||||
|
Reference in New Issue
Block a user