33 Commits

Author SHA1 Message Date
c1a800ee84 JENKINS: Changed deployed version to 36e7486726ac886225eac8299e472d36bccb671a 2025-07-09 20:33:21 +00:00
d26b6b39a5 JENKINS: Changed deployed version to 050916003f77e7dee9a4f9446540557bfe1f544b 2025-07-09 20:29:08 +00:00
59287c30b7 JENKINS: Changed deployed version to 6da6ea634ecddac129c12d89cf72889cc2e6e1ec 2025-07-09 20:24:53 +00:00
f7f06d3943 JENKINS: Changed deployed version to 3fadc63726d10f56ad0cef58153572633251ce20 2025-07-09 20:01:56 +00:00
105b6e1132 JENKINS: Changed deployed version to d7da79d1d267cfecfa3987015a3ac506c33216b8 2025-07-09 19:59:31 +00:00
a95d2dffd7 JENKINS: Changed deployed version to 4fbb54f44697388b246246fad4a61b8b59fc4960 2025-07-09 19:57:09 +00:00
89fdbc59f3 JENKINS: Changed deployed version to 7034bf3dce0bd6e19682f266c6f7adaa29501d3f 2025-07-09 19:54:41 +00:00
402a26769b JENKINS: Changed deployed version to 9ac5ca85bd096b7700ac00a431e7402f3c93057b 2025-07-09 19:52:18 +00:00
acb0fe1513 JENKINS: Changed deployed version to a514f374edae343be3eec096470158b895afd292 2025-07-09 19:49:56 +00:00
e5dfaaf827 JENKINS: Changed deployed version to 5041f290fa62150518ca106f914647b7fe5d21d5 2025-07-09 19:47:29 +00:00
668d2521c1 JENKINS: Changed deployed version to f364694af8b979ef6c9ac519250879504329c955 2025-07-09 19:44:56 +00:00
bbc2fd73b6 JENKINS: Changed deployed version to d20a83431bdbbde0b6580ae9c12697de631809b6 2025-07-09 19:42:34 +00:00
a11cc61082 JENKINS: Changed deployed version to f845f5d7c2fc2596f5c76de1668be4a4f8beab42 2025-07-09 19:40:13 +00:00
3c2b308f80 JENKINS: Changed deployed version to 44ad02e6aeeec1822bbe0a2e26dfe8c22d280a76 2025-07-09 19:32:09 +00:00
abe9d34a91 JENKINS: Changed deployed version to 745e9b5bac3599e8607de32d3199f2818b0ac017 2025-07-09 19:29:40 +00:00
3016038d8a JENKINS: Changed deployed version to 225f998a8c167c49c8b3b1e21488b4de78e0f8c0 2025-07-09 19:23:33 +00:00
7ab2516080 JENKINS: Changed deployed version to 84c57feb8498d7a798de802aa1b76606a0c7275e 2025-07-09 19:20:32 +00:00
974576f6c0 JENKINS: Changed deployed version to de405308bb0ebe73a9dc23d5b4c06f1352d14f97 2025-07-09 19:18:00 +00:00
57d3b50a89 JENKINS: Changed deployed version to 9c2848df4ac4676bcb86893713b03f4805d4e7d2 2025-07-09 19:14:57 +00:00
04771de20f JENKINS: Changed deployed version to a7c605199544711718607cb2a6a83bab24662ca9 2025-07-09 19:10:39 +00:00
84c1abdf11 JENKINS: Changed deployed version to cbd6be779c886418e65643ebf102f8b26e3f076e 2025-07-09 19:05:15 +00:00
1449d3186c JENKINS: Changed deployed version to 32e993da4de79836d4cbf0613bd87371103322ad 2025-07-09 19:01:01 +00:00
3012d6c624 JENKINS: Changed deployed version to 32b9580a8209b81bc2c29ff32cbac002ce036205 2025-07-09 18:57:44 +00:00
801da6d0df JENKINS: Changed deployed version to abeb0e52718a6718134b8000bc7fa616e920206a 2025-07-09 18:53:36 +00:00
a76cf0e18c JENKINS: Changed deployed version to b7920e3644e2affc983e5ee2e25bdfd8afcc8a8a 2025-07-08 19:44:09 +00:00
531144e383 JENKINS: Changed deployed version to e573c573bf6c27ec22f02d189b44d9100ef24020 2025-07-08 19:32:43 +00:00
fe8babda8d JENKINS: Changed deployed version to 23814bef0c064cf3b776601e63f979b3cf452239 2025-07-08 17:46:01 +00:00
f7e9b0bd90 Updated image - added wait_for_db and healthcheck to app 2025-06-13 18:25:41 +00:00
bcfb0897bf Add client id of managed identity 2025-06-12 21:37:56 +00:00
c09d7c448f Merged tasks for both containers 2025-06-12 21:35:07 +00:00
cbd77b8bb1 Prepared Docker image to run for pod agent 2025-06-12 21:31:45 +00:00
4901890d0e Created pipeline for Jenkins in Kubernetes cluster 2025-06-12 19:02:29 +00:00
f55776916e Updated managed identity 2025-06-11 18:42:21 +00:00
7 changed files with 146 additions and 38 deletions

32
.jenkins/Dockerfile Normal file
View File

@ -0,0 +1,32 @@
FROM debian:bookworm-slim
# Zapobiega interaktywnym promptom
ENV DEBIAN_FRONTEND=noninteractive
# Instalacja zależności systemowych
RUN apt-get update && apt-get install -y \
ca-certificates \
curl \
gnupg \
lsb-release \
apt-transport-https \
software-properties-common \
unzip \
bash \
&& rm -rf /var/lib/apt/lists/*
# Instalacja Azure CLI
RUN curl -sL https://aka.ms/InstallAzureCLIDeb | bash
# Instalacja kubectl (najświeższa stabilna wersja)
RUN curl -sLo /usr/local/bin/kubectl https://dl.k8s.io/release/v1.33.1/bin/linux/amd64/kubectl \
&& chmod +x /usr/local/bin/kubectl
# Instalacja kubelogin
RUN curl -sLo /tmp/kubelogin.zip https://github.com/Azure/kubelogin/releases/latest/download/kubelogin-linux-amd64.zip \
&& unzip -j /tmp/kubelogin.zip -d /usr/local/bin \
&& chmod +x /usr/local/bin/kubelogin \
&& rm /tmp/kubelogin.zip
# Domyślna komenda po starcie kontenera
CMD ["bash"]

86
.jenkins/Jenkinsfile vendored Normal file
View File

@ -0,0 +1,86 @@
pipeline {
agent {
kubernetes {
yamlFile '.jenkins/podTemplate.yaml'
}
}
environment {
RESOURCE_GROUP = 'tst-aks-rg'
CLUSTER_NAME = 'build'
DEPLOY_FILES = 'namespace.yaml secret-store.yaml deploy.yaml ingress.yaml'
NAMESPACE = 'user-microservice'
DEPLOYMENT = 'api'
CLIENT_ID = 'c302726f-fafb-4143-94c1-67a70975574a'
}
stages {
stage('Checkout') {
steps {
container('kubectl') {
checkout scm
}
}
}
stage('Login to Azure & Get Kubeconfig') {
steps {
container('kubectl') {
sh '''
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
'''
}
}
}
stage('Apply Kubernetes Resources') {
steps {
container('kubectl') {
script {
def files = DEPLOY_FILES.tokenize()
for (file in files) {
sh "kubectl apply -f ${file}"
}
}
}
}
}
stage('Verify Deployment') {
steps {
container('kubectl') {
script {
// Waiting until all pods reach "ready" status
sh '''
echo "Waiting for deployment rollout..."
kubectl rollout status deployment/$DEPLOYMENT -n $NAMESPACE --timeout=60s
'''
}
}
}
}
stage('Health Check') {
steps {
container('kubectl') {
script {
// Check if app is healthy
def ingressUrl = "https://user-microservice.marcin00.pl/health"
sh """
echo "Checking app health ${ingressUrl}..."
for i in {1..30}; do
if curl -sf $ingressUrl; then
echo "Health check OK"
exit 0
else
echo "Health check failed. Retry \$i..."
sleep 5
fi
done
echo "Health check failed."
exit 1
"""
}
}
}
}
}
}

24
.jenkins/podTemplate.yaml Normal file
View File

@ -0,0 +1,24 @@
apiVersion: v1
kind: Pod
metadata:
labels:
some-label: jenkins-agent
spec:
containers:
- name: kubectl
image: marcin00.azurecr.io/azure-cli-kubectl:latest
command:
- cat
tty: true
volumeMounts:
- name: workspace-volume
mountPath: /home/jenkins/agent
volumes:
- name: workspace-volume
emptyDir: {}
nodeSelector:
kubernetes.io/os: linux
restartPolicy: Never

34
Jenkinsfile vendored
View File

@ -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'
}
}
}

View File

@ -81,7 +81,7 @@ spec:
spec:
containers:
- name: api
image: marcin00.azurecr.io/user-microservice:76a351710fffe2be1ae10471bc1a2f511f481126
image: marcin00.azurecr.io/user-microservice:36e7486726ac886225eac8299e472d36bccb671a
ports:
- containerPort: 80
env:

View File

@ -4,7 +4,7 @@ metadata:
name: deployer-binding
subjects:
- kind: User
name: daabce80-f745-413f-8377-00472517521c
name: f91aef65-7d2a-4df8-a884-e33b05d54a31
apiGroup: rbac.authorization.k8s.io
roleRef:
kind: ClusterRole

View File

@ -24,8 +24,8 @@ spec:
parameters:
usePodIdentity: "false"
useVMManagedIdentity: "true"
userAssignedIdentityID: "0c2780e4-8594-4aab-8f1a-8a19f71924bd" # client_id of the user-assigned managed identity
clientID: "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: "f91aef65-7d2a-4df8-a884-e33b05d54a31" # client_id of the user-assigned managed identity
keyvaultName: "dev-aks"
objects: |
array: