Compare commits
8 Commits
feature/ss
...
bugfix/jen
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
39cd2b4274 | ||
|
|
97716be9e5 | ||
|
|
e7c31d0701 | ||
|
|
2702970ffc | ||
|
|
3610ff3f17 | ||
|
|
51a1618bf9 | ||
|
|
2f4822a421 | ||
|
|
57b5004ec8 |
80
Jenkinsfile
vendored
80
Jenkinsfile
vendored
@@ -1,80 +0,0 @@
|
|||||||
#!/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('build app') {
|
|
||||||
steps {
|
|
||||||
script {
|
|
||||||
echo 'building application jar...'
|
|
||||||
buildJar()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
stage('build image') {
|
|
||||||
steps {
|
|
||||||
script {
|
|
||||||
echo 'building docker image...'
|
|
||||||
buildImage(env.IMAGE_NAME)
|
|
||||||
dockerLogin()
|
|
||||||
dockerPush(env.IMAGE_NAME)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
stage('provision server') {
|
|
||||||
environment {
|
|
||||||
AWS_ACCESS_KEY_ID = credentials('jenkins_aws_access_key_id')
|
|
||||||
AWS_SECRET_ACCESS_KEY = credentials('jenkins_aws_secret_access_key')
|
|
||||||
TF_VAR_env_prefix = 'test'
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
script {
|
|
||||||
dir('terraform') {
|
|
||||||
sh "terraform init"
|
|
||||||
sh "terraform apply --auto-approve"
|
|
||||||
EC2_PUBLIC_IP = sh(
|
|
||||||
script: "terraform output ec2_public_ip",
|
|
||||||
returnStdout: true
|
|
||||||
).trim()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
stage('deploy') {
|
|
||||||
environment {
|
|
||||||
DOCKER_CREDS = credentials('docker-hub-repo')
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
script {
|
|
||||||
echo "waiting for EC2 server to initialize"
|
|
||||||
sleep(time: 90, unit: "SECONDS")
|
|
||||||
|
|
||||||
echo 'deploying docker image to EC2...'
|
|
||||||
echo "${EC2_PUBLIC_IP}"
|
|
||||||
|
|
||||||
def shellCmd = "bash ./server-cmds.sh ${IMAGE_NAME} ${DOCKER_CREDS_USR} ${DOCKER_CREDS_PSW}"
|
|
||||||
def ec2Instance = "ec2-user@${EC2_PUBLIC_IP}"
|
|
||||||
|
|
||||||
sshagent(['server-ssh-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}"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -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
|
|
||||||
2
freestyle-build.sh
Normal file
2
freestyle-build.sh
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
# npm --version
|
||||||
|
# docker --version
|
||||||
17
pom.xml
17
pom.xml
@@ -8,23 +8,6 @@
|
|||||||
<artifactId>java-maven-app</artifactId>
|
<artifactId>java-maven-app</artifactId>
|
||||||
<version>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>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
|||||||
@@ -1,8 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
export IMAGE=$1
|
|
||||||
export DOCKER_USER=$2
|
|
||||||
export DOCKER_PWD=$3
|
|
||||||
echo $DOCKER_PWD | docker login -u $DOCKER_USER --password-stdin
|
|
||||||
docker-compose -f docker-compose.yaml up --detach
|
|
||||||
echo "success"
|
|
||||||
BIN
target/classes/com/example/Application.class
Normal file
BIN
target/classes/com/example/Application.class
Normal file
Binary file not shown.
19
terraform/.terraform.lock.hcl
generated
19
terraform/.terraform.lock.hcl
generated
@@ -1,19 +0,0 @@
|
|||||||
# 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"
|
|
||||||
hashes = [
|
|
||||||
"h1:f/Tz8zv1Zb78ZaiyJkQ0MGIViZwbYrLuQk3kojPM91c=",
|
|
||||||
"zh:4a9a66caf1964cdd3b61fb3ebb0da417195a5529cb8e496f266b0778335d11c8",
|
|
||||||
"zh:514f2f006ae68db715d86781673faf9483292deab235c7402ff306e0e92ea11a",
|
|
||||||
"zh:5277b61109fddb9011728f6650ef01a639a0590aeffe34ed7de7ba10d0c31803",
|
|
||||||
"zh:67784dc8c8375ab37103eea1258c3334ee92be6de033c2b37e3a2a65d0005142",
|
|
||||||
"zh:76d4c8be2ca4a3294fb51fb58de1fe03361d3bc403820270cc8e71a04c5fa806",
|
|
||||||
"zh:8f90b1cfdcf6e8fb1a9d0382ecaa5056a3a84c94e313fbf9e92c89de271cdede",
|
|
||||||
"zh:d0ac346519d0df124df89be2d803eb53f373434890f6ee3fb37112802f9eac59",
|
|
||||||
"zh:d6256feedada82cbfb3b1dd6dd9ad02048f23120ab50e6146a541cb11a108cc1",
|
|
||||||
"zh:db2fe0d2e77c02e9a74e1ed694aa352295a50283f9a1cf896e5be252af14e9f4",
|
|
||||||
"zh:eda61e889b579bd90046939a5b40cf5dc9031fb5a819fc3e4667a78bd432bdb2",
|
|
||||||
]
|
|
||||||
}
|
|
||||||
Binary file not shown.
@@ -1,8 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
sudo yum update -y && sudo yum install -y docker
|
|
||||||
sudo systemctl start docker
|
|
||||||
sudo usermod -aG docker ec2-user
|
|
||||||
|
|
||||||
# install docker-compose
|
|
||||||
sudo curl -L "https://github.com/docker/compose/releases/download/1.27.4/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
|
|
||||||
sudo chmod +x /usr/local/bin/docker-compose
|
|
||||||
@@ -1,112 +0,0 @@
|
|||||||
terraform {
|
|
||||||
required_version = ">= 0.12"
|
|
||||||
backend "s3" {
|
|
||||||
bucket = "myapp-bucket"
|
|
||||||
key = "myapp/state.tfstate"
|
|
||||||
region = "eu-west-3"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
provider "aws" {
|
|
||||||
region = var.region
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_vpc" "myapp-vpc" {
|
|
||||||
cidr_block = var.vpc_cidr_block
|
|
||||||
tags = {
|
|
||||||
Name: "${var.env_prefix}-vpc"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_subnet" "myapp-subnet-1" {
|
|
||||||
vpc_id = aws_vpc.myapp-vpc.id
|
|
||||||
cidr_block = var.subnet_cidr_block
|
|
||||||
availability_zone = var.avail_zone
|
|
||||||
tags = {
|
|
||||||
Name: "${var.env_prefix}-subnet-1"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_internet_gateway" "myapp-igw" {
|
|
||||||
vpc_id = aws_vpc.myapp-vpc.id
|
|
||||||
tags = {
|
|
||||||
Name: "${var.env_prefix}-igw"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_default_route_table" "main-rtb" {
|
|
||||||
default_route_table_id = aws_vpc.myapp-vpc.default_route_table_id
|
|
||||||
|
|
||||||
route {
|
|
||||||
cidr_block = "0.0.0.0/0"
|
|
||||||
gateway_id = aws_internet_gateway.myapp-igw.id
|
|
||||||
}
|
|
||||||
tags = {
|
|
||||||
Name: "${var.env_prefix}-main-rtb"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_default_security_group" "default-sg" {
|
|
||||||
vpc_id = aws_vpc.myapp-vpc.id
|
|
||||||
|
|
||||||
ingress {
|
|
||||||
from_port = 22
|
|
||||||
to_port = 22
|
|
||||||
protocol = "tcp"
|
|
||||||
cidr_blocks = [var.my_ip, var.jenkins_ip]
|
|
||||||
}
|
|
||||||
|
|
||||||
ingress {
|
|
||||||
from_port = 8080
|
|
||||||
to_port = 8080
|
|
||||||
protocol = "tcp"
|
|
||||||
cidr_blocks = ["0.0.0.0/0"]
|
|
||||||
}
|
|
||||||
|
|
||||||
egress {
|
|
||||||
from_port = 0
|
|
||||||
to_port = 0
|
|
||||||
protocol = "-1"
|
|
||||||
cidr_blocks = ["0.0.0.0/0"]
|
|
||||||
prefix_list_ids = []
|
|
||||||
}
|
|
||||||
|
|
||||||
tags = {
|
|
||||||
Name: "${var.env_prefix}-default-sg"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
data "aws_ami" "latest-amazon-linux-image" {
|
|
||||||
most_recent = true
|
|
||||||
owners = ["amazon"]
|
|
||||||
filter {
|
|
||||||
name = "name"
|
|
||||||
values = ["amzn2-ami-hvm-*-x86_64-gp2"]
|
|
||||||
}
|
|
||||||
filter {
|
|
||||||
name = "virtualization-type"
|
|
||||||
values = ["hvm"]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
resource "aws_instance" "myapp-server" {
|
|
||||||
ami = data.aws_ami.latest-amazon-linux-image.id
|
|
||||||
instance_type = var.instance_type
|
|
||||||
|
|
||||||
subnet_id = aws_subnet.myapp-subnet-1.id
|
|
||||||
vpc_security_group_ids = [aws_default_security_group.default-sg.id]
|
|
||||||
availability_zone = var.avail_zone
|
|
||||||
|
|
||||||
associate_public_ip_address = true
|
|
||||||
key_name = "myapp-key-pair"
|
|
||||||
|
|
||||||
user_data = file("entry-script.sh")
|
|
||||||
|
|
||||||
tags = {
|
|
||||||
Name = "${var.env_prefix}-server"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
output "ec2_public_ip" {
|
|
||||||
value = aws_instance.myapp-server.public_ip
|
|
||||||
}
|
|
||||||
@@ -1,24 +0,0 @@
|
|||||||
variable vpc_cidr_block {
|
|
||||||
default = "10.0.0.0/16"
|
|
||||||
}
|
|
||||||
variable subnet_cidr_block {
|
|
||||||
default = "10.0.10.0/24"
|
|
||||||
}
|
|
||||||
variable avail_zone {
|
|
||||||
default = "eu-west-3a"
|
|
||||||
}
|
|
||||||
variable env_prefix {
|
|
||||||
default = "dev"
|
|
||||||
}
|
|
||||||
variable my_ip {
|
|
||||||
default = "212.124.154.110/32"
|
|
||||||
}
|
|
||||||
variable jenkins_ip {
|
|
||||||
default = "139.59.140.177/32"
|
|
||||||
}
|
|
||||||
variable instance_type {
|
|
||||||
default = "t2.micro"
|
|
||||||
}
|
|
||||||
variable region {
|
|
||||||
default = "eu-west-3"
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user