-
Notifications
You must be signed in to change notification settings - Fork 4
/
Jenkinsfile
73 lines (73 loc) · 1.81 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
pipeline {
environment {
registry = "rcmelendez/cats"
registryCredential = 'dockerhub'
dockerImage = ''
}
agent any
stages {
stage('Lint Dockerfile') {
steps {
sh "hadolint Dockerfile"
}
}
stage('Security Scan') {
steps {
aquaMicroscanner imageName: 'alpine:latest', notCompliesCmd: 'exit 1', onDisallowed: 'fail', outputFormat: 'html'
}
}
stage('Build Docker image') {
steps {
script {
dockerImage = docker.build registry + ":$BUILD_NUMBER"
}
}
}
stage('Test Container') {
steps {
sh "docker run -d --rm --name cats -p 8888:5000 $registry:$BUILD_NUMBER"
script {
final String url = "http://0.0.0.0:8888"
final String response = sh(script: "curl -s $url", returnStdout: true).trim()
echo response
}
sh "docker stop cats"
}
}
stage('Deploy image to Docker Hub') {
steps {
script {
docker.withRegistry( '', registryCredential ) {
dockerImage.push()
dockerImage.push("latest")
}
}
}
}
stage('Remove Docker image') {
steps {
sh "docker rmi $registry:$BUILD_NUMBER $registry:latest"
}
}
stage('Deploy to AWS EKS cluster') {
steps {
sh '''
kubectl apply -f k8s/namespace.yml
kubectl apply -f k8s/deployment.yml
kubectl apply -f k8s/service.yml
echo "View all resources"
kubectl get all -o wide -n udacity
'''
}
}
stage('Rollout Deployment') {
steps {
sh '''
kubectl rollout restart deployment/cats -n udacity
echo "View all resources"
kubectl get all -o wide -n udacity
'''
}
}
}
}