Compare commits
115 Commits
feature/de
...
feature/ek
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
c03467bfdd | ||
|
|
ec25c85f9d | ||
|
|
8bde0dae7d | ||
|
|
8a5eca28bd | ||
|
|
808024df04 | ||
|
|
c754ff2d60 | ||
|
|
92835a5b54 | ||
|
|
386fde3774 | ||
|
|
9f96f5fac1 | ||
|
|
165bd326cb | ||
|
|
6566e1b821 | ||
|
|
70fb6f1f11 | ||
|
|
8c32984bfa | ||
|
|
86b41c173d | ||
|
|
ec07045f5b | ||
|
|
a9ad429d59 | ||
|
|
69c20e807e | ||
|
|
1c35a7f6c3 | ||
|
|
c22ccead98 | ||
|
|
d2bb88b269 | ||
|
|
14af7f6928 | ||
|
|
0f16440c51 | ||
|
|
9e0883d626 | ||
|
|
ad517593dd | ||
|
|
96a0f80bec | ||
|
|
0972181e49 | ||
|
|
a24c7c6f15 | ||
|
|
0907a4a9f6 | ||
|
|
7e3d309037 | ||
|
|
f83a7744b9 | ||
|
|
d8a20f2ac9 | ||
|
|
ab509b3b3c | ||
|
|
6123875bc8 | ||
|
|
1f54931484 | ||
|
|
18ecdca204 | ||
|
|
e1dbd4d042 | ||
|
|
36b85d75cc | ||
|
|
c120554c74 | ||
|
|
3e1d99e8d0 | ||
|
|
e71aab1655 | ||
|
|
762a6a9ffb | ||
|
|
e14b7b7012 | ||
|
|
106a7e447e | ||
|
|
b28d6ff9d9 | ||
|
|
4e33b70b24 | ||
|
|
d41bcec12b | ||
|
|
9dadc24128 | ||
|
|
12f88937ab | ||
|
|
8b1aa75d8e | ||
|
|
339109ec86 | ||
|
|
63f6c3d5bb | ||
|
|
ba9f0882ca | ||
|
|
0b043899f9 | ||
|
|
f31394abe3 | ||
|
|
e2633b0888 | ||
|
|
a1b5946b6d | ||
|
|
45817d153a | ||
|
|
0576e0033b | ||
|
|
44cf4ac38c | ||
|
|
04f35ad918 | ||
|
|
686259038b | ||
|
|
1978bd1fc9 | ||
|
|
b262ce98c8 | ||
|
|
24fdad6aaa | ||
|
|
e41eb6433d | ||
|
|
1ce128d916 | ||
|
|
2c6295012f | ||
|
|
48b35c0308 | ||
|
|
80ed88f4be | ||
|
|
f8698fee42 | ||
|
|
eea2109d66 | ||
|
|
a71dd16df8 | ||
|
|
8e3382a0ef | ||
|
|
1d4aac4b5a | ||
|
|
f65d9eb00e | ||
|
|
a026af6e2f | ||
|
|
02aef32659 | ||
|
|
e68743b02d | ||
|
|
ce28529588 | ||
|
|
a0deb05e4e | ||
|
|
126336f79e | ||
|
|
19eeb818ca | ||
|
|
ff51c37f0a | ||
|
|
948fbb8f12 | ||
|
|
679d67b80a | ||
|
|
661a008faa | ||
|
|
9cc6d90fe8 | ||
|
|
61821c6ef7 | ||
|
|
1fa470771d | ||
|
|
9c56ddc553 | ||
|
|
056eca7cf6 | ||
|
|
e637047b84 | ||
|
|
845783dbc6 | ||
|
|
cdacbeeec4 | ||
|
|
1228821c74 | ||
|
|
650570153a | ||
|
|
e5f3bc546b | ||
|
|
99d992ee76 | ||
|
|
273c10f041 | ||
|
|
e0be3b5f9d | ||
|
|
c4cba3ddc6 | ||
|
|
8fb1d04fa8 | ||
|
|
48aa2427b3 | ||
|
|
ed870a0c6b | ||
|
|
28932727d1 | ||
|
|
2ef267a3fb | ||
|
|
05f3e19201 | ||
|
|
5d8d48709e | ||
|
|
fa5460fa44 | ||
|
|
ae9b87113d | ||
|
|
86350ca4e1 | ||
|
|
51edfc3d66 | ||
|
|
c8da404d8b | ||
|
|
18a24797ed | ||
|
|
710e1151f8 |
3
.gitignore
vendored
3
.gitignore
vendored
@@ -1,2 +1,5 @@
|
|||||||
.idea/*
|
.idea/*
|
||||||
target
|
target
|
||||||
|
terraform/.terraform/*
|
||||||
|
terraform/terraform.tfstate*
|
||||||
|
terraform/kubeconfig*
|
||||||
8
Dockerfile
Normal file
8
Dockerfile
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
FROM openjdk:8-jre-alpine
|
||||||
|
|
||||||
|
EXPOSE 8080
|
||||||
|
|
||||||
|
COPY ./target/java-maven-app-*.jar /usr/app/
|
||||||
|
WORKDIR /usr/app
|
||||||
|
|
||||||
|
CMD java -jar java-maven-app-*.jar
|
||||||
104
Jenkinsfile
vendored
Normal file
104
Jenkinsfile
vendored
Normal file
@@ -0,0 +1,104 @@
|
|||||||
|
#!/usr/bin/env groovy
|
||||||
|
|
||||||
|
pipeline {
|
||||||
|
agent any
|
||||||
|
tools {
|
||||||
|
maven 'Maven'
|
||||||
|
}
|
||||||
|
environment {
|
||||||
|
AWS_ACCESS_KEY_ID = credentials('jenkins_aws_access_key_id')
|
||||||
|
AWS_SECRET_ACCESS_KEY = credentials('jenkins_aws_secret_access_key')
|
||||||
|
}
|
||||||
|
stages {
|
||||||
|
stage('provision cluster') {
|
||||||
|
environment {
|
||||||
|
TF_VAR_env_prefix = "test"
|
||||||
|
TF_VAR_k8s_version = "1.18"
|
||||||
|
}
|
||||||
|
steps {
|
||||||
|
script {
|
||||||
|
dir('terraform') {
|
||||||
|
echo "creating ECR repository and EKS cluster"
|
||||||
|
sh "terraform init"
|
||||||
|
sh "terraform apply --auto-approve"
|
||||||
|
env.DOCKER_REPO_URL = sh(
|
||||||
|
script: "terraform output repo_url",
|
||||||
|
returnStdout: true
|
||||||
|
).trim()
|
||||||
|
env.K8S_CLUSTER_URL = sh(
|
||||||
|
script: "terraform output cluster_url",
|
||||||
|
returnStdout: true
|
||||||
|
).trim()
|
||||||
|
env.REPO_USER = sh(
|
||||||
|
script: "terraform output ecr_user_name",
|
||||||
|
returnStdout: true
|
||||||
|
).trim()
|
||||||
|
env.REPO_PWD = sh(
|
||||||
|
script: "terraform output ecr_user_password",
|
||||||
|
returnStdout: true
|
||||||
|
).trim()
|
||||||
|
}
|
||||||
|
env.KUBECONFIG="terraform/kubeconfig.yaml"
|
||||||
|
sh "kubectl get node"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
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 the application..."
|
||||||
|
sh 'mvn clean package'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('build image') {
|
||||||
|
steps {
|
||||||
|
script {
|
||||||
|
echo "building the docker image..."
|
||||||
|
sh "docker build -t ${DOCKER_REPO_URL}:${IMAGE_NAME} ."
|
||||||
|
sh "echo ${REPO_PWD} | docker login -u ${REPO_USER} --password-stdin ${DOCKER_REPO_URL}"
|
||||||
|
sh "docker push ${DOCKER_REPO_URL}:${IMAGE_NAME}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('deploy') {
|
||||||
|
environment {
|
||||||
|
APP_NAME = 'java-maven-app'
|
||||||
|
}
|
||||||
|
steps {
|
||||||
|
script {
|
||||||
|
echo 'deploying docker image...'
|
||||||
|
sh 'envsubst < kubernetes/deployment.yaml | kubectl apply -f -'
|
||||||
|
sh 'envsubst < kubernetes/service.yaml | kubectl apply -f -'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('commit version update') {
|
||||||
|
steps {
|
||||||
|
script {
|
||||||
|
withCredentials([usernamePassword(credentialsId: 'gitlab-credentials', passwordVariable: 'PASS', usernameVariable: 'USER')]) {
|
||||||
|
sh 'git config user.email "jenkins@example.com"'
|
||||||
|
sh 'git config 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:${BRANCH_NAME}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
24
kubernetes/deployment.yaml
Normal file
24
kubernetes/deployment.yaml
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: $APP_NAME
|
||||||
|
labels:
|
||||||
|
app: $APP_NAME
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: $APP_NAME
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: $APP_NAME
|
||||||
|
spec:
|
||||||
|
imagePullSecrets:
|
||||||
|
- name: aws-registry-key
|
||||||
|
containers:
|
||||||
|
- name: $APP_NAME
|
||||||
|
image: $DOCKER_REPO:$IMAGE_NAME
|
||||||
|
imagePullPolicy: Always
|
||||||
|
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: $APP_NAME
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
app: $APP_NAME
|
||||||
|
ports:
|
||||||
|
- protocol: TCP
|
||||||
|
port: 80
|
||||||
|
targetPort: 8080
|
||||||
31
pom.xml
31
pom.xml
@@ -6,34 +6,25 @@
|
|||||||
|
|
||||||
<groupId>com.example</groupId>
|
<groupId>com.example</groupId>
|
||||||
<artifactId>java-maven-app</artifactId>
|
<artifactId>java-maven-app</artifactId>
|
||||||
<version>1.0-SNAPSHOT</version>
|
<version>1.1.7</version>
|
||||||
|
|
||||||
<build>
|
<build>
|
||||||
<pluginManagement>
|
|
||||||
<plugins>
|
<plugins>
|
||||||
<plugin>
|
<plugin>
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
<artifactId>maven-deploy-plugin</artifactId>
|
<artifactId>spring-boot-maven-plugin</artifactId>
|
||||||
<version>2.8.2</version>
|
<version>2.3.5.RELEASE</version>
|
||||||
</plugin>
|
<executions>
|
||||||
</plugins>
|
<execution>
|
||||||
</pluginManagement>
|
<goals>
|
||||||
|
<goal>repackage</goal>
|
||||||
<plugins>
|
</goals>
|
||||||
<plugin>
|
</execution>
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
</executions>
|
||||||
<artifactId>maven-deploy-plugin</artifactId>
|
|
||||||
</plugin>
|
</plugin>
|
||||||
</plugins>
|
</plugins>
|
||||||
</build>
|
</build>
|
||||||
|
|
||||||
<distributionManagement>
|
|
||||||
<snapshotRepository>
|
|
||||||
<id>nexus-snapshots</id>
|
|
||||||
<url>http://167.99.248.163:8081/repository/maven-snapshots/</url>
|
|
||||||
</snapshotRepository>
|
|
||||||
</distributionManagement>
|
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
|||||||
@@ -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>
|
|
||||||
16
src/test/java/AppTest.java
Normal file
16
src/test/java/AppTest.java
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
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);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
5
target/maven-archiver/pom.properties
Normal file
5
target/maven-archiver/pom.properties
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
#Generated by Maven
|
||||||
|
#Sun Dec 20 16:52:05 UTC 2020
|
||||||
|
version=1.1.7
|
||||||
|
groupId=com.example
|
||||||
|
artifactId=java-maven-app
|
||||||
4
target/surefire-reports/AppTest.txt
Normal file
4
target/surefire-reports/AppTest.txt
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
-------------------------------------------------------------------------------
|
||||||
|
Test set: AppTest
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
Tests run: 1, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 0.07 sec
|
||||||
64
target/surefire-reports/TEST-AppTest.xml
Normal file
64
target/surefire-reports/TEST-AppTest.xml
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
|
<testsuite tests="1" failures="0" name="AppTest" time="0.005" errors="0" skipped="0">
|
||||||
|
<properties>
|
||||||
|
<property name="java.runtime.name" value="OpenJDK Runtime Environment"/>
|
||||||
|
<property name="sun.boot.library.path" value="/usr/local/openjdk-8/jre/lib/amd64"/>
|
||||||
|
<property name="java.vm.version" value="25.242-b08"/>
|
||||||
|
<property name="java.vm.vendor" value="Oracle Corporation"/>
|
||||||
|
<property name="maven.multiModuleProjectDirectory" value="/var/jenkins_home/workspace/va-maven-app_feature_eks-tf-prep"/>
|
||||||
|
<property name="java.vendor.url" value="http://java.oracle.com/"/>
|
||||||
|
<property name="path.separator" value=":"/>
|
||||||
|
<property name="guice.disable.misplaced.annotation.check" value="true"/>
|
||||||
|
<property name="java.vm.name" value="OpenJDK 64-Bit Server VM"/>
|
||||||
|
<property name="file.encoding.pkg" value="sun.io"/>
|
||||||
|
<property name="sun.java.launcher" value="SUN_STANDARD"/>
|
||||||
|
<property name="sun.os.patch.level" value="unknown"/>
|
||||||
|
<property name="java.vm.specification.name" value="Java Virtual Machine Specification"/>
|
||||||
|
<property name="user.dir" value="/var/jenkins_home/workspace/va-maven-app_feature_eks-tf-prep"/>
|
||||||
|
<property name="java.runtime.version" value="1.8.0_242-b08"/>
|
||||||
|
<property name="java.awt.graphicsenv" value="sun.awt.X11GraphicsEnvironment"/>
|
||||||
|
<property name="java.endorsed.dirs" value="/usr/local/openjdk-8/jre/lib/endorsed"/>
|
||||||
|
<property name="os.arch" value="amd64"/>
|
||||||
|
<property name="java.io.tmpdir" value="/tmp"/>
|
||||||
|
<property name="line.separator" value="
|
||||||
|
"/>
|
||||||
|
<property name="java.vm.specification.vendor" value="Oracle Corporation"/>
|
||||||
|
<property name="os.name" value="Linux"/>
|
||||||
|
<property name="classworlds.conf" value="/var/jenkins_home/tools/hudson.tasks.Maven_MavenInstallation/Maven/bin/m2.conf"/>
|
||||||
|
<property name="sun.jnu.encoding" value="UTF-8"/>
|
||||||
|
<property name="java.library.path" value="/usr/java/packages/lib/amd64:/usr/lib64:/lib64:/lib:/usr/lib"/>
|
||||||
|
<property name="maven.conf" value="/var/jenkins_home/tools/hudson.tasks.Maven_MavenInstallation/Maven/conf"/>
|
||||||
|
<property name="java.specification.name" value="Java Platform API Specification"/>
|
||||||
|
<property name="java.class.version" value="52.0"/>
|
||||||
|
<property name="sun.management.compiler" value="HotSpot 64-Bit Tiered Compilers"/>
|
||||||
|
<property name="os.version" value="5.4.0-51-generic"/>
|
||||||
|
<property name="library.jansi.path" value="/var/jenkins_home/tools/hudson.tasks.Maven_MavenInstallation/Maven/lib/jansi-native"/>
|
||||||
|
<property name="user.home" value="/var/jenkins_home"/>
|
||||||
|
<property name="user.timezone" value="Etc/UTC"/>
|
||||||
|
<property name="java.awt.printerjob" value="sun.print.PSPrinterJob"/>
|
||||||
|
<property name="java.specification.version" value="1.8"/>
|
||||||
|
<property name="file.encoding" value="UTF-8"/>
|
||||||
|
<property name="user.name" value="jenkins"/>
|
||||||
|
<property name="java.class.path" value="/var/jenkins_home/tools/hudson.tasks.Maven_MavenInstallation/Maven/boot/plexus-classworlds-2.6.0.jar"/>
|
||||||
|
<property name="java.vm.specification.version" value="1.8"/>
|
||||||
|
<property name="sun.arch.data.model" value="64"/>
|
||||||
|
<property name="java.home" value="/usr/local/openjdk-8/jre"/>
|
||||||
|
<property name="sun.java.command" value="org.codehaus.plexus.classworlds.launcher.Launcher clean package"/>
|
||||||
|
<property name="java.specification.vendor" value="Oracle Corporation"/>
|
||||||
|
<property name="user.language" value="en"/>
|
||||||
|
<property name="awt.toolkit" value="sun.awt.X11.XToolkit"/>
|
||||||
|
<property name="java.vm.info" value="mixed mode"/>
|
||||||
|
<property name="java.version" value="1.8.0_242"/>
|
||||||
|
<property name="java.ext.dirs" value="/usr/local/openjdk-8/jre/lib/ext:/usr/java/packages/lib/ext"/>
|
||||||
|
<property name="securerandom.source" value="file:/dev/./urandom"/>
|
||||||
|
<property name="sun.boot.class.path" value="/usr/local/openjdk-8/jre/lib/resources.jar:/usr/local/openjdk-8/jre/lib/rt.jar:/usr/local/openjdk-8/jre/lib/sunrsasign.jar:/usr/local/openjdk-8/jre/lib/jsse.jar:/usr/local/openjdk-8/jre/lib/jce.jar:/usr/local/openjdk-8/jre/lib/charsets.jar:/usr/local/openjdk-8/jre/lib/jfr.jar:/usr/local/openjdk-8/jre/classes"/>
|
||||||
|
<property name="java.vendor" value="Oracle Corporation"/>
|
||||||
|
<property name="maven.home" value="/var/jenkins_home/tools/hudson.tasks.Maven_MavenInstallation/Maven"/>
|
||||||
|
<property name="file.separator" value="/"/>
|
||||||
|
<property name="java.vendor.url.bug" value="http://bugreport.sun.com/bugreport/"/>
|
||||||
|
<property name="sun.cpu.endian" value="little"/>
|
||||||
|
<property name="sun.io.unicode.encoding" value="UnicodeLittle"/>
|
||||||
|
<property name="sun.cpu.isalist" value=""/>
|
||||||
|
</properties>
|
||||||
|
<testcase classname="AppTest" name="testApp" time="0.005"/>
|
||||||
|
</testsuite>
|
||||||
116
terraform/.terraform.lock.hcl
generated
Executable file
116
terraform/.terraform.lock.hcl
generated
Executable file
@@ -0,0 +1,116 @@
|
|||||||
|
# This file is maintained automatically by "terraform init".
|
||||||
|
# Manual edits may be lost in future updates.
|
||||||
|
|
||||||
|
provider "registry.terraform.io/hashicorp/aws" {
|
||||||
|
version = "3.22.0"
|
||||||
|
constraints = ">= 2.68.0, >= 3.3.0"
|
||||||
|
hashes = [
|
||||||
|
"h1:8aWXjFcmEi64P0TMHOCQXWws+/SmvJQrNvHlzdktKOM=",
|
||||||
|
"h1:f/Tz8zv1Zb78ZaiyJkQ0MGIViZwbYrLuQk3kojPM91c=",
|
||||||
|
"zh:4a9a66caf1964cdd3b61fb3ebb0da417195a5529cb8e496f266b0778335d11c8",
|
||||||
|
"zh:514f2f006ae68db715d86781673faf9483292deab235c7402ff306e0e92ea11a",
|
||||||
|
"zh:5277b61109fddb9011728f6650ef01a639a0590aeffe34ed7de7ba10d0c31803",
|
||||||
|
"zh:67784dc8c8375ab37103eea1258c3334ee92be6de033c2b37e3a2a65d0005142",
|
||||||
|
"zh:76d4c8be2ca4a3294fb51fb58de1fe03361d3bc403820270cc8e71a04c5fa806",
|
||||||
|
"zh:8f90b1cfdcf6e8fb1a9d0382ecaa5056a3a84c94e313fbf9e92c89de271cdede",
|
||||||
|
"zh:d0ac346519d0df124df89be2d803eb53f373434890f6ee3fb37112802f9eac59",
|
||||||
|
"zh:d6256feedada82cbfb3b1dd6dd9ad02048f23120ab50e6146a541cb11a108cc1",
|
||||||
|
"zh:db2fe0d2e77c02e9a74e1ed694aa352295a50283f9a1cf896e5be252af14e9f4",
|
||||||
|
"zh:eda61e889b579bd90046939a5b40cf5dc9031fb5a819fc3e4667a78bd432bdb2",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
provider "registry.terraform.io/hashicorp/kubernetes" {
|
||||||
|
version = "1.13.3"
|
||||||
|
constraints = ">= 1.11.1"
|
||||||
|
hashes = [
|
||||||
|
"h1:iV0RArGM0KJ3n0ctwpNzcTkTAnx5G4wV3V3kYkRpJXU=",
|
||||||
|
"h1:whoGs/NeucMF8U/urPaeXdQUb+ppaO1Ae4r5aJRhfrU=",
|
||||||
|
"zh:11fd58df9c297a4f3cab82ce8eb2f54f1be27f78fa23be2273ecd545ab254b91",
|
||||||
|
"zh:5b9e6f352c5666d791e2658a1d18bf0990f3ab70c99c916c393a2ee7f385364c",
|
||||||
|
"zh:5c94f1350471a5c8e8ee6675874608c506a0bfd3164bdd91b802842723547e2c",
|
||||||
|
"zh:5d9c5c44dba9addbb86491339012096e74778bb4ea93b70f12333bffba3d05e6",
|
||||||
|
"zh:6336f9cbb0b580f247cebb97fb7d4cc5e7fe9cc734d8d958d84c4ea3f1e24041",
|
||||||
|
"zh:bca3b9d4dcbe6f804f5611a83add371dc03b5aa92271f60ebdc2216bfedfab28",
|
||||||
|
"zh:cbcdc87a593090f490f7899f4f2d302e0c7023155591fcf65e6fadd69f5452f0",
|
||||||
|
"zh:ec2886a1adbfe3c861b2deb9446369111b9c6116701ae73ef372dc7df5bb3c9e",
|
||||||
|
"zh:edb5b4172610672bb4d7425511961fda2047b8a00675b99ae6887cd2ece4bda9",
|
||||||
|
"zh:ff7ea7743246181ea739643d7751c37041c4016eb6bbc39beb1e3b4e99629112",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
provider "registry.terraform.io/hashicorp/local" {
|
||||||
|
version = "2.0.0"
|
||||||
|
constraints = ">= 1.4.0"
|
||||||
|
hashes = [
|
||||||
|
"h1:EC6eh7avwx1rF56h3RZcxgEp/14ihi7Sk/4J3Hn4nIE=",
|
||||||
|
"h1:pO1ANXtOCRfecKsY9Hn4UsXoPBLv6LFiDIEiS1MZ09E=",
|
||||||
|
"zh:34ce8b79493ace8333d094752b579ccc907fa9392a2c1d6933a6c95d0786d3f1",
|
||||||
|
"zh:5c5a19c4f614a4ffb68bae0b0563f3860115cf7539b8adc21108324cfdc10092",
|
||||||
|
"zh:67ddb1ca2cd3e1a8f948302597ceb967f19d2eeb2d125303493667388fe6330e",
|
||||||
|
"zh:68e6b16f3a8e180fcba1a99754118deb2d82331b51f6cca39f04518339bfdfa6",
|
||||||
|
"zh:8393a12eb11598b2799d51c9b0a922a3d9fadda5a626b94a1b4914086d53120e",
|
||||||
|
"zh:90daea4b2010a86f2aca1e3a9590e0b3ddcab229c2bd3685fae76a832e9e836f",
|
||||||
|
"zh:99308edc734a0ac9149b44f8e316ca879b2670a1cae387a8ae754c180b57cdb4",
|
||||||
|
"zh:c76594db07a9d1a73372a073888b672df64adb455d483c2426cc220eda7e092e",
|
||||||
|
"zh:dc09c1fb36c6a706bdac96cce338952888c8423978426a09f5df93031aa88b84",
|
||||||
|
"zh:deda88134e9780319e8de91b3745520be48ead6ec38cb662694d09185c3dac70",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
provider "registry.terraform.io/hashicorp/null" {
|
||||||
|
version = "3.0.0"
|
||||||
|
constraints = ">= 2.1.0"
|
||||||
|
hashes = [
|
||||||
|
"h1:V1tzrSG6t3e7zWvUwRbGbhsWU2Jd/anrJpOl9XM+R/8=",
|
||||||
|
"h1:ysHGBhBNkIiJLEpthB/IVCLpA1Qoncp3KbCTFGFZTO0=",
|
||||||
|
"zh:05fb7eab469324c97e9b73a61d2ece6f91de4e9b493e573bfeda0f2077bc3a4c",
|
||||||
|
"zh:1688aa91885a395c4ae67636d411475d0b831e422e005dcf02eedacaafac3bb4",
|
||||||
|
"zh:24a0b1292e3a474f57c483a7a4512d797e041bc9c2fbaac42fe12e86a7fb5a3c",
|
||||||
|
"zh:2fc951bd0d1b9b23427acc93be09b6909d72871e464088171da60fbee4fdde03",
|
||||||
|
"zh:6db825759425599a326385a68acc6be2d9ba0d7d6ef587191d0cdc6daef9ac63",
|
||||||
|
"zh:85985763d02618993c32c294072cc6ec51f1692b803cb506fcfedca9d40eaec9",
|
||||||
|
"zh:a53186599c57058be1509f904da512342cfdc5d808efdaf02dec15f0f3cb039a",
|
||||||
|
"zh:c2e07b49b6efa676bdc7b00c06333ea1792a983a5720f9e2233db27323d2707c",
|
||||||
|
"zh:cdc8fe1096103cf5374751e2e8408ec4abd2eb67d5a1c5151fe2c7ecfd525bef",
|
||||||
|
"zh:dbdef21df0c012b0d08776f3d4f34eb0f2f229adfde07ff252a119e52c0f65b7",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
provider "registry.terraform.io/hashicorp/random" {
|
||||||
|
version = "3.0.0"
|
||||||
|
constraints = ">= 2.1.0"
|
||||||
|
hashes = [
|
||||||
|
"h1:grDzxfnOdFXi90FRIIwP/ZrCzirJ/SfsGBe6cE0Shg4=",
|
||||||
|
"h1:yhHJpb4IfQQfuio7qjUXuUFTU/s+ensuEpm23A+VWz0=",
|
||||||
|
"zh:0fcb00ff8b87dcac1b0ee10831e47e0203a6c46aafd76cb140ba2bab81f02c6b",
|
||||||
|
"zh:123c984c0e04bad910c421028d18aa2ca4af25a153264aef747521f4e7c36a17",
|
||||||
|
"zh:287443bc6fd7fa9a4341dec235589293cbcc6e467a042ae225fd5d161e4e68dc",
|
||||||
|
"zh:2c1be5596dd3cca4859466885eaedf0345c8e7628503872610629e275d71b0d2",
|
||||||
|
"zh:684a2ef6f415287944a3d966c4c8cee82c20e393e096e2f7cdcb4b2528407f6b",
|
||||||
|
"zh:7625ccbc6ff17c2d5360ff2af7f9261c3f213765642dcd84e84ae02a3768fd51",
|
||||||
|
"zh:9a60811ab9e6a5bfa6352fbb943bb530acb6198282a49373283a8fa3aa2b43fc",
|
||||||
|
"zh:c73e0eaeea6c65b1cf5098b101d51a2789b054201ce7986a6d206a9e2dacaefd",
|
||||||
|
"zh:e8f9ed41ac83dbe407de9f0206ef1148204a0d51ba240318af801ffb3ee5f578",
|
||||||
|
"zh:fbdd0684e62563d3ac33425b0ac9439d543a3942465f4b26582bcfabcb149515",
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
provider "registry.terraform.io/hashicorp/template" {
|
||||||
|
version = "2.2.0"
|
||||||
|
constraints = ">= 2.1.0"
|
||||||
|
hashes = [
|
||||||
|
"h1:0wlehNaxBX7GJQnPfQwTNvvAf38Jm0Nv7ssKGMaG6Og=",
|
||||||
|
"h1:94qn780bi1qjrbC3uQtjJh3Wkfwd5+tTtJHOb7KTg9w=",
|
||||||
|
"zh:01702196f0a0492ec07917db7aaa595843d8f171dc195f4c988d2ffca2a06386",
|
||||||
|
"zh:09aae3da826ba3d7df69efeb25d146a1de0d03e951d35019a0f80e4f58c89b53",
|
||||||
|
"zh:09ba83c0625b6fe0a954da6fbd0c355ac0b7f07f86c91a2a97849140fea49603",
|
||||||
|
"zh:0e3a6c8e16f17f19010accd0844187d524580d9fdb0731f675ffcf4afba03d16",
|
||||||
|
"zh:45f2c594b6f2f34ea663704cc72048b212fe7d16fb4cfd959365fa997228a776",
|
||||||
|
"zh:77ea3e5a0446784d77114b5e851c970a3dde1e08fa6de38210b8385d7605d451",
|
||||||
|
"zh:8a154388f3708e3df5a69122a23bdfaf760a523788a5081976b3d5616f7d30ae",
|
||||||
|
"zh:992843002f2db5a11e626b3fc23dc0c87ad3729b3b3cff08e32ffb3df97edbde",
|
||||||
|
"zh:ad906f4cebd3ec5e43d5cd6dc8f4c5c9cc3b33d2243c89c5fc18f97f7277b51d",
|
||||||
|
"zh:c979425ddb256511137ecd093e23283234da0154b7fa8b21c2687182d9aea8b2",
|
||||||
|
]
|
||||||
|
}
|
||||||
11
terraform/ecr-repo.tf
Normal file
11
terraform/ecr-repo.tf
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
resource "aws_ecr_repository" "myapp-repo" {
|
||||||
|
name = "myapp"
|
||||||
|
|
||||||
|
# defaults
|
||||||
|
image_tag_mutability = "MUTABLE"
|
||||||
|
image_scanning_configuration {
|
||||||
|
scan_on_push = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
data "aws_ecr_authorization_token" "token" {}
|
||||||
57
terraform/eks-cluster.tf
Normal file
57
terraform/eks-cluster.tf
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
terraform {
|
||||||
|
backend "s3" {
|
||||||
|
bucket = "myapp-cluster-bucket-new"
|
||||||
|
key = "myapp/state.tfstate"
|
||||||
|
region = "eu-west-3"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
provider "kubernetes" {
|
||||||
|
load_config_file = "false"
|
||||||
|
host = data.aws_eks_cluster.myapp-cluster.endpoint
|
||||||
|
token = data.aws_eks_cluster_auth.myapp-cluster.token
|
||||||
|
cluster_ca_certificate = base64decode(data.aws_eks_cluster.myapp-cluster.certificate_authority.0.data)
|
||||||
|
}
|
||||||
|
|
||||||
|
data "aws_eks_cluster" "myapp-cluster" {
|
||||||
|
name = module.eks.cluster_id
|
||||||
|
}
|
||||||
|
|
||||||
|
data "aws_eks_cluster_auth" "myapp-cluster" {
|
||||||
|
name = module.eks.cluster_id
|
||||||
|
}
|
||||||
|
|
||||||
|
module "eks" {
|
||||||
|
source = "terraform-aws-modules/eks/aws"
|
||||||
|
version = "13.2.1"
|
||||||
|
|
||||||
|
cluster_name = var.cluster_name
|
||||||
|
cluster_version = var.k8s_version
|
||||||
|
|
||||||
|
subnets = module.myapp-vpc.private_subnets
|
||||||
|
vpc_id = module.myapp-vpc.vpc_id
|
||||||
|
|
||||||
|
tags = {
|
||||||
|
environment = var.env_prefix
|
||||||
|
application = "myapp"
|
||||||
|
}
|
||||||
|
|
||||||
|
worker_groups = [
|
||||||
|
{
|
||||||
|
instance_type = "t2.small"
|
||||||
|
name = "worker-group-1"
|
||||||
|
asg_desired_capacity = 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
instance_type = "t2.medium"
|
||||||
|
name = "worker-group-2"
|
||||||
|
asg_desired_capacity = 1
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "local_file" "kube_config_file" {
|
||||||
|
content = module.eks.kubeconfig
|
||||||
|
filename = "kubeconfig.yaml"
|
||||||
|
file_permission = "400"
|
||||||
|
}
|
||||||
20
terraform/outputs.tf
Normal file
20
terraform/outputs.tf
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
output repo_url {
|
||||||
|
value = aws_ecr_repository.myapp-repo.repository_url
|
||||||
|
}
|
||||||
|
|
||||||
|
output cluster_url {
|
||||||
|
value = module.eks.cluster_endpoint
|
||||||
|
}
|
||||||
|
|
||||||
|
output kubeconfig {
|
||||||
|
value = module.eks.kubeconfig
|
||||||
|
}
|
||||||
|
|
||||||
|
output ecr_user_name {
|
||||||
|
value = data.aws_ecr_authorization_token.token.user_name
|
||||||
|
}
|
||||||
|
|
||||||
|
output ecr_user_password {
|
||||||
|
value = data.aws_ecr_authorization_token.token.password
|
||||||
|
sensitive = true
|
||||||
|
}
|
||||||
27
terraform/variables.tf
Normal file
27
terraform/variables.tf
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
variable env_prefix {
|
||||||
|
default = "dev"
|
||||||
|
}
|
||||||
|
|
||||||
|
variable region {
|
||||||
|
default = "eu-west-3"
|
||||||
|
}
|
||||||
|
|
||||||
|
variable vpc_cidr_block {
|
||||||
|
default = "10.0.0.0/16"
|
||||||
|
}
|
||||||
|
|
||||||
|
variable private_subnet_cidr_blocks {
|
||||||
|
default = ["10.0.1.0/24", "10.0.2.0/24", "10.0.3.0/24"]
|
||||||
|
}
|
||||||
|
|
||||||
|
variable public_subnet_cidr_blocks {
|
||||||
|
default = ["10.0.4.0/24", "10.0.5.0/24", "10.0.6.0/24"]
|
||||||
|
}
|
||||||
|
|
||||||
|
variable k8s_version {
|
||||||
|
default = "1.17"
|
||||||
|
}
|
||||||
|
|
||||||
|
variable cluster_name {
|
||||||
|
default = "myapp-eks-cluster"
|
||||||
|
}
|
||||||
19
terraform/versions.tf
Normal file
19
terraform/versions.tf
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
terraform {
|
||||||
|
// pull latest version because of bug on destroy - aws_auth can't get removed
|
||||||
|
//required_version = ">= 0.12"
|
||||||
|
/*required_providers {
|
||||||
|
random = "~> 2.1"
|
||||||
|
local = "~> 1.2"
|
||||||
|
null = "~> 2.1"
|
||||||
|
template = "~> 2.1"
|
||||||
|
kubernetes = "~> 1.13"
|
||||||
|
}*/
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Defining provider versions inside provider block deprecated in Terraform 0.13 and above
|
||||||
|
**
|
||||||
|
provider "random" {
|
||||||
|
version = "~> 2.1"
|
||||||
|
}
|
||||||
|
*/
|
||||||
35
terraform/vpc.tf
Normal file
35
terraform/vpc.tf
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
provider "aws" {
|
||||||
|
region = var.region
|
||||||
|
}
|
||||||
|
|
||||||
|
data "aws_availability_zones" "available" {}
|
||||||
|
|
||||||
|
module "myapp-vpc" {
|
||||||
|
source = "terraform-aws-modules/vpc/aws"
|
||||||
|
version = "2.64.0"
|
||||||
|
|
||||||
|
name = "myapp-vpc"
|
||||||
|
cidr = var.vpc_cidr_block
|
||||||
|
private_subnets = var.private_subnet_cidr_blocks
|
||||||
|
public_subnets = var.public_subnet_cidr_blocks
|
||||||
|
azs = data.aws_availability_zones.available.names
|
||||||
|
|
||||||
|
enable_nat_gateway = true
|
||||||
|
single_nat_gateway = true
|
||||||
|
enable_dns_hostnames = true
|
||||||
|
|
||||||
|
tags = {
|
||||||
|
"kubernetes.io/cluster/${var.cluster_name}" = "shared"
|
||||||
|
}
|
||||||
|
|
||||||
|
public_subnet_tags = {
|
||||||
|
"kubernetes.io/cluster/${var.cluster_name}" = "shared"
|
||||||
|
"kubernetes.io/role/elb" = 1
|
||||||
|
}
|
||||||
|
|
||||||
|
private_subnet_tags = {
|
||||||
|
"kubernetes.io/cluster/${var.cluster_name}" = "shared"
|
||||||
|
"kubernetes.io/role/internal-elb" = 1
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user