12 Commits

Author SHA1 Message Date
Nana Janashia
d7e9360e2c fix 2020-11-08 17:28:39 +01:00
Nana Janashia
6b1d998791 add library def inside Jenkinsfile 2020-11-08 17:25:26 +01:00
Nana Janashia
922c8df4c6 add ind commands 2020-11-08 17:12:58 +01:00
Nana Janashia
946909a1b0 add param to dockerbuild 2020-11-08 16:41:07 +01:00
Nana Janashia
5aab8caed6 fix lib call 2020-11-08 16:30:28 +01:00
Nana Janashia
63a5e576a8 fix lib call 2020-11-08 16:27:28 +01:00
Nana Janashia
aa6f394e65 fix lib call 2020-11-08 16:20:19 +01:00
Nana Janashia
15a05dc886 Update Jenkinsfile 2020-11-08 15:15:26 +00:00
Nana Janashia
81b557f424 Update Jenkinsfile 2020-11-08 15:14:14 +00:00
Nana Janashia
6e6e1fdcb6 Update Jenkinsfile 2020-11-08 15:12:19 +00:00
Nana Janashia
75f780bd0c fix lib call 2020-11-08 16:05:48 +01:00
Nana Janashia
6a5572a5f7 call library functions in jenkinsfile 2020-11-08 15:58:31 +01:00
8 changed files with 25 additions and 113 deletions

View File

@@ -2,7 +2,7 @@ FROM openjdk:8-jre-alpine
EXPOSE 8080 EXPOSE 8080
COPY ./target/java-maven-app-*.jar /usr/app/ COPY ./target/java-maven-app-1.0-SNAPSHOT.jar /usr/app/
WORKDIR /usr/app WORKDIR /usr/app
CMD java -jar java-maven-app-*.jar ENTRYPOINT ["java", "-jar", "java-maven-app-1.0-SNAPSHOT.jar"]

61
Jenkinsfile vendored
View File

@@ -1,69 +1,48 @@
#!/usr/bin/env groovy #!/usr/bin/env groovy
library identifier: 'jenkins-shared-library@master', retriever: modernSCM(
[$class: 'GitSCMSource',
remote: 'https://gitlab.com/nanuchi/jenkins-shared-library.git',
credentialsId: 'gitlab-credentials'
]
)
def gv
pipeline { pipeline {
agent any agent any
tools { tools {
maven 'Maven' maven 'Maven'
} }
stages { stages {
stage('increment version') { stage("init") {
steps { steps {
script { script {
echo 'incrementing app version...' gv = load "script.groovy"
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 app') { stage("build jar") {
steps { steps {
script { script {
echo "building the application..." buildJar()
sh 'mvn clean package'
} }
} }
} }
stage('build image') { stage("build and push image") {
steps { steps {
script { script {
echo "building the docker image..." buildImage 'nanajanashia/demo-app:jma-3.0'
withCredentials([usernamePassword(credentialsId: 'docker-hub', passwordVariable: 'PASS', usernameVariable: 'USER')]) { dockerLogin()
sh "docker build -t nanajanashia/demo-app:${IMAGE_NAME} ." dockerPush 'nanajanashia/demo-app:jma-3.0'
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 {
withKubeConfig([credentialsId: 'k8s-credentials', serverUrl: 'https://7293fae4-4c9d-4629-bc82-262d0a2b8e3c.eu-central-2.linodelke.net']) { gv.deployApp()
withCredentials([usernamePassword(credentialsId: 'docker-hub', passwordVariable: 'PASS', usernameVariable: 'USER')]) {
sh "kubectl create secret docker-registry my-registry-key --docker-server=docker.io --docker-username=$USER --docker-password=$PASS"
}
sh 'envsubst < kubernetes/deployment.yaml | kubectl apply -f -'
}
}
}
}
stage('commit version update') {
steps {
script {
withCredentials([usernamePassword(credentialsId: 'gitlab-credentials', passwordVariable: 'PASS', usernameVariable: 'USER')]) {
// git config here for the first time run
sh 'git config --global user.email "jenkins@example.com"'
sh 'git config --global user.name "jenkins"'
sh "git remote set-url origin https://${USER}:${PASS}@gitlab.com/nanuchi/java-maven-app.git"
sh 'git add .'
sh 'git commit -m "ci: version bump"'
sh 'git push origin HEAD:jenkins-jobs'
}
} }
} }
} }

View File

@@ -1,25 +0,0 @@
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:
imagePullSecrets:
- name: my-registry-key
containers:
- name: java-maven-app
image: nanajanashia/demo-app:$IMAGE_NAME
imagePullPolicy: Always
ports:
- containerPort: 8080

View File

@@ -1,11 +0,0 @@
apiVersion: v1
kind: Service
metadata:
name: java-maven-app
spec:
selector:
app: java-maven-app
ports:
- protocol: TCP
port: 80
targetPort: 8080

19
pom.xml
View File

@@ -6,24 +6,7 @@
<groupId>com.example</groupId> <groupId>com.example</groupId>
<artifactId>java-maven-app</artifactId> <artifactId>java-maven-app</artifactId>
<version>1.1.0-SNAPSHOT</version> <version>1.0-SNAPSHOT</version>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>2.3.5.RELEASE</version>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
<dependencies> <dependencies>
<dependency> <dependency>

View File

@@ -1,17 +1,3 @@
def buildJar() {
echo "building the application..."
sh 'mvn package'
}
def buildImage() {
echo "building the docker image..."
withCredentials([usernamePassword(credentialsId: 'docker-hub-repo', passwordVariable: 'PASS', usernameVariable: 'USER')]) {
sh 'docker build -t nanajanashia/demo-app:jma-2.0 .'
sh "echo $PASS | docker login -u $USER --password-stdin"
sh 'docker push nanajanashia/demo-app:jma-2.0'
}
}
def deployApp() { def deployApp() {
echo 'deploying the application...' echo 'deploying the application...'
} }

Binary file not shown.