28 Commits

Author SHA1 Message Date
Nana Janashia
9904bca4f8 Update Jenkinsfile 2021-01-04 11:56:48 +00:00
Nana Janashia
ae5ce790f4 add private registry login for deplyoment 2020-12-04 13:41:04 +01:00
Nana Janashia
8decc9d40e add dockerfile 2020-12-04 13:11:51 +01:00
Nana Janashia
c204af2a10 fix repo cred id 2020-12-04 13:10:16 +01:00
Nana Janashia
9c7552b5c9 add kubectl command exec in jenkinsfile 2020-12-04 13:05:46 +01:00
Nana Janashia
31209ff01c Update Jenkinsfile 2020-12-04 09:06:55 +00:00
Nana Janashia
fd26c2e81b Update Jenkinsfile 2020-12-03 15:41:22 +00:00
Nana Janashia
4e6c3e791d Update Jenkinsfile 2020-12-03 15:25:12 +00:00
Nana Janashia
b9c23ee70d Update Jenkinsfile 2020-12-03 15:24:37 +00:00
Nana Janashia
2f9fd78922 Update Jenkinsfile 2020-12-03 15:23:58 +00:00
Nana Janashia
7848de66a2 add patch version to maven version 2020-11-28 11:34:52 +01:00
Nana Janashia
007c036d2a fixed building jar file 2020-11-22 11:33:45 +01:00
Nana Janashia
3da4e695d0 Update Jenkinsfile 2020-11-08 15:23:44 +00:00
Nana Janashia
b7f48cdd4a Update Jenkinsfile 2020-11-08 15:22:06 +00:00
Nana Janashia
d7839d4033 Update Jenkinsfile 2020-11-07 16:28:59 +00:00
Nana Janashia
af78bcdf1e Add new file 2020-11-07 15:45:27 +00:00
Nana Janashia
5a4e789475 Update Jenkinsfile 2020-11-07 15:44:58 +00:00
Nana Janashia
9969d8b2cf Update Jenkinsfile 2020-11-06 12:49:54 +00:00
Nana Janashia
3e129808aa Update Jenkinsfile 2020-11-06 12:40:11 +00:00
Nana Janashia
f03d95e413 Update Jenkinsfile 2020-11-06 12:38:49 +00:00
Nana Janashia
c8f9061ef6 Update Jenkinsfile 2020-11-06 12:38:24 +00:00
Nana Janashia
6804a58c01 Update Jenkinsfile 2020-11-06 12:36:28 +00:00
Nana Janashia
5ef50d2628 Update Jenkinsfile 2020-11-06 12:35:52 +00:00
Nana Janashia
1c02e35f97 Update Jenkinsfile 2020-11-06 12:33:08 +00:00
Nana Janashia
f298808592 Update Jenkinsfile 2020-11-06 12:32:13 +00:00
Nana Janashia
a14a9d4f9a Update Jenkinsfile 2020-11-06 12:24:57 +00:00
Nana Janashia
d267e0d112 Update Jenkinsfile 2020-10-31 15:31:43 +00:00
Nana Janashia
833dd401b3 Add new file 2020-10-31 15:27:05 +00:00
13 changed files with 103 additions and 80 deletions

1
.gitignore vendored
View File

@@ -1,2 +1 @@
.idea/*
target

View File

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

65
Jenkinsfile vendored
View File

@@ -1,51 +1,68 @@
#!/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'
]
)
pipeline {
agent any
tools {
maven 'Maven'
}
environment {
IMAGE_NAME = 'nanajanashia/demo-app:java-maven-2.0'
}
stages {
stage('increment version') {
steps {
script {
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 app') {
steps {
script {
echo 'building application jar...'
buildJar()
echo "building the application..."
sh 'mvn clean package'
}
}
}
stage('build image') {
steps {
script {
echo 'building docker image...'
buildImage(env.IMAGE_NAME)
dockerLogin()
dockerPush(env.IMAGE_NAME)
echo "building the docker image..."
withCredentials([usernamePassword(credentialsId: 'docker-hub', 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') {
steps {
script {
echo 'deploying docker image to EC2...'
withKubeConfig([credentialsId: 'k8s-credentials', serverUrl: 'https://7293fae4-4c9d-4629-bc82-262d0a2b8e3c.eu-central-2.linodelke.net']) {
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"'
def shellCmd = "bash ./server-cmds.sh ${IMAGE_NAME}"
def ec2Instance = "ec2-user@35.180.251.121"
sshagent(['ec2-server-key']) {
sh "scp -o StrictHostKeyChecking=no server-cmds.sh ${ec2Instance}:/home/ec2-user"
sh "scp -o StrictHostKeyChecking=no docker-compose.yaml ${ec2Instance}:/home/ec2-user"
sh "ssh -o StrictHostKeyChecking=no ${ec2Instance} ${shellCmd}"
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,12 +0,0 @@
version: '3.8'
services:
java-maven-app:
image: ${IMAGE}
ports:
- 8080:8080
postgres:
image: postgres:13
ports:
- 5432:5432
environment:
- POSTGRES_PASSWORD=my-pwd

View File

@@ -0,0 +1,25 @@
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

11
kubernetes/service.yaml Normal file
View 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

View File

@@ -6,7 +6,7 @@
<groupId>com.example</groupId>
<artifactId>java-maven-app</artifactId>
<version>1.0-SNAPSHOT</version>
<version>1.1.0-SNAPSHOT</version>
<build>
<plugins>
@@ -24,11 +24,7 @@
</plugin>
</plugins>
</build>
<properties>
<java.version>1.8</java.version>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>

19
script.groovy Normal file
View File

@@ -0,0 +1,19 @@
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() {
echo 'deploying the application...'
}
return this

View File

@@ -1,5 +0,0 @@
#!/usr/bin/env bash
export IMAGE=$1
docker-compose -f docker-compose.yaml up --detach
echo "success"

View File

@@ -1,11 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>MyApp</title>
</head>
<body>
<h1>Welcome to Java Maven Application</h1>
<!-- add image here <img src="" width="" /> -->
</body>
</html>

View File

@@ -1,16 +0,0 @@
import com.example.Application;
import org.junit.Test;
import static org.junit.Assert.*;
public class AppTest {
@Test
public void testApp() {
Application myApp = new Application();
String result = myApp.getStatus();
assertEquals("OK", result);
}
}

Binary file not shown.

Binary file not shown.