-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathJenkinsfile
81 lines (74 loc) · 2.42 KB
/
Jenkinsfile
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
pipeline {
agent any
environment {
DOCKER_REGISTRY = ''
DOCKER_CREDENTIALS = ''
KUBECONFIG_CREDENTIALS = ''
NAMESPACE = ''
}
stages {
stage('Checkout Code') {
steps {
git branch: 'main', url: 'https://github.com/tu-repo/microservices-repo.git'
}
}
stage('Build and Test') {
steps {
sh 'mvn clean package -DskipTests'
}
}
stage('Build Docker Images') {
steps {
script {
def services = ['discovery-server', 'api-gateway', 'config-server']
for (service in services) {
sh """
docker build -t ${DOCKER_REGISTRY}/${service}:latest ./${service}
"""
}
}
}
}
stage('Push Docker Images') {
steps {
script {
docker.withRegistry("https://${DOCKER_REGISTRY}", DOCKER_CREDENTIALS) {
def services = ['discovery-server', 'api-gateway', 'config-server']
for (service in services) {
sh """
docker push ${DOCKER_REGISTRY}/${service}:latest
"""
}
}
}
}
}
stage('Deploy to Kubernetes') {
steps {
script {
withCredentials([file(credentialsId: KUBECONFIG_CREDENTIALS, variable: 'KUBECONFIG')]) {
sh """
export KUBECONFIG=${KUBECONFIG}
kubectl apply -f kubernetes/
kubectl rollout status deployment/discovery-server -n ${NAMESPACE}
kubectl rollout status deployment/api-gateway -n ${NAMESPACE}
kubectl rollout status deployment/config-server -n ${NAMESPACE}
"""
}
}
}
}
}
post {
always {
archiveArtifacts artifacts: '**/target/*.jar', allowEmptyArchive: true
cleanWs()
}
success {
echo 'Pipeline completed successfully.'
}
failure {
echo 'Pipeline failed. Check the logs.'
}
}
}