add kubectl command exec in jenkinsfile
This commit is contained in:
38
Jenkinsfile
vendored
38
Jenkinsfile
vendored
@@ -1,36 +1,50 @@
|
|||||||
def gv
|
#!/usr/bin/env groovy
|
||||||
|
|
||||||
pipeline {
|
pipeline {
|
||||||
agent any
|
agent any
|
||||||
|
tools {
|
||||||
|
maven 'Maven'
|
||||||
|
}
|
||||||
stages {
|
stages {
|
||||||
stage("init") {
|
stage('increment version') {
|
||||||
steps {
|
steps {
|
||||||
script {
|
script {
|
||||||
gv = load "script.groovy"
|
echo 'incrementing app version...'
|
||||||
|
sh 'mvn build-helper:parse-version versions:set \
|
||||||
|
-DnewVersion=\\\${parsedVersion.majorVersion}.\\\${parsedVersion.minorVersion}.\\\${parsedVersion.nextIncrementalVersion} \
|
||||||
|
versions:commit'
|
||||||
|
def matcher = readFile('pom.xml') =~ '<version>(.+)</version>'
|
||||||
|
def version = matcher[0][1]
|
||||||
|
env.IMAGE_NAME = "$version-$BUILD_NUMBER"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stage("build jar") {
|
stage('build app') {
|
||||||
steps {
|
steps {
|
||||||
script {
|
script {
|
||||||
echo "building jar"
|
echo "building the application..."
|
||||||
//gv.buildJar()
|
sh 'mvn clean package'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stage("build image") {
|
stage('build image') {
|
||||||
steps {
|
steps {
|
||||||
script {
|
script {
|
||||||
echo "building image"
|
echo "building the docker image..."
|
||||||
//gv.buildImage()
|
withCredentials([usernamePassword(credentialsId: 'docker-hub-repo', passwordVariable: 'PASS', usernameVariable: 'USER')]) {
|
||||||
|
sh "docker build -t nanajanashia/demo-app:${IMAGE_NAME} ."
|
||||||
|
sh "echo $PASS | docker login -u $USER --password-stdin"
|
||||||
|
sh "docker push nanajanashia/demo-app:${IMAGE_NAME}"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stage("deploy") {
|
}
|
||||||
|
stage('deploy') {
|
||||||
steps {
|
steps {
|
||||||
script {
|
script {
|
||||||
echo "deploying"
|
withKubeConfig([credentialsId: 'k8s-credentials', serverUrl: 'https://7293fae4-4c9d-4629-bc82-262d0a2b8e3c.eu-central-2.linodelke.net']) {
|
||||||
//gv.deployApp()
|
sh 'envsubst < kubernetes/deployment.yaml | kubectl apply -f -'
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
22
kubernetes/deployment.yaml
Normal file
22
kubernetes/deployment.yaml
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: java-maven-app
|
||||||
|
labels:
|
||||||
|
app: java-maven-app
|
||||||
|
spec:
|
||||||
|
replicas: 2
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: java-maven-app
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: java-maven-app
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: java-maven-app
|
||||||
|
image: nanajanashia/demo-app:$IMAGE_NAME
|
||||||
|
ports:
|
||||||
|
- containerPort: 8080
|
||||||
|
|
||||||
11
kubernetes/service.yaml
Normal file
11
kubernetes/service.yaml
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: java-maven-app
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
app: java-maven-app
|
||||||
|
ports:
|
||||||
|
- protocol: TCP
|
||||||
|
port: 80
|
||||||
|
targetPort: 8080
|
||||||
BIN
target/java-maven-app-1.1.1.jar
Normal file
BIN
target/java-maven-app-1.1.1.jar
Normal file
Binary file not shown.
BIN
target/java-maven-app-1.1.1.jar.original
Normal file
BIN
target/java-maven-app-1.1.1.jar.original
Normal file
Binary file not shown.
Reference in New Issue
Block a user