Skip to content

Commit

Permalink
Update README.md
Browse files Browse the repository at this point in the history
  • Loading branch information
DharshiBalasubramaniyam authored Jun 28, 2024
1 parent 7ab81d2 commit db1a531
Showing 1 changed file with 103 additions and 1 deletion.
104 changes: 103 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1 +1,103 @@
# Spring Boot CI/CD Pipeline with GitHub Actions, Docker and AWS EC2
# Spring Boot CI/CD Pipeline

<p align="center">
<img alt="Static Badge" src="https://img.shields.io/badge/Spring%20Boot-green?style=for-the-badge">
<img alt="Static Badge" src="https://img.shields.io/badge/GitHub%20Actions-purple?style=for-the-badge">
<img alt="Static Badge" src="https://img.shields.io/badge/Docker-blue?style=for-the-badge">
<img alt="Static Badge" src="https://img.shields.io/badge/AWS-red?style=for-the-badge">
</p>

## 🌟 Description

This project demonstrates a complete CI/CD pipeline for a Spring Boot application using GitHub Actions, Docker, and AWS.

The pipeline automates the build, test, Dockerization, and deployment processes to ensure consistent and reliable delivery of the application.

The main features of this project include:

1. **Spring Boot Application**: A sample Spring Boot application that serves as the base for demonstrating the CI/CD pipeline.

2. **Dockerization**: The application is packaged into a Docker container to ensure it runs consistently across different environments.

3. **Continuous Integration with GitHub Actions**: Automated build, test, and Dockerization of the Spring Boot application using GitHub Actions. Every push to the main branch triggers the CI pipeline.

4. **AWS Deployment**

## Dockerization

Docker is a tool designed to make it easy to build, test, deploy and run applications by using containers.

Containers are lightweight, self-contained units that package an application and all its dependencies together.

Each Docker container runs in its own isolated environment, which means that the dependencies of one application won't interfere with another.

Docker ensures that our application runs the same way on any machine. This eliminates the `it works on my machine` problem.

### Docker architecture components

1. **Docker Client**: The Docker client is the way that users interact with Docker by using commands. The client sends these commands to the Docker daemon.

2. **Docker Daemon**: The Docker daemon runs on the host machine. It listens for Docker API requests and manages Docker objects such as images, containers, networks, and volumes.

3. **Docker Images**: The Docker images are read-only templates that contain the application and all the dependencies needed to run it. Images are used to create Docker containers. They can be created from a Dockerfile or pulled from a Docker registry.

4. **Docker Containers**: The Containers are runnable instances of Docker images. They contain everything needed to run the application, including the code, runtime, libraries, and settings.

5. **Docker Registries**: The Docker registries store Docker images. The default registry is Docker Hub.

6. **Dockerfile**: The Dockerfile is a text file that contains a set of instructions on how to build a Docker image.

### Docker workflow

1. Create a Dockerfile.
```
# Specify the base image for your Docker image
# Eg., for JAVA 17, use openjdk:17-jdk-slim
FROM {YOUR_BASE_IMAGE}
# Expose the application port
EXPOSE {YOUR_PORT}
# Add the JAR file to the container
ADD target/{YOUR_JAR_NAME}.jar {YOUR_JAR_NAME}.jar
# Run the JAR file
ENTRYPOINT ["java","-jar","/{YOUR_JAR_NAME}.jar"]
```

2. Build Docker image.
```
docker build -t yourusername/yourjarname .
```

3. Login to Dockerhub.
```
docker login -u yourusername -p yourpassword
```

4. Push the image to Dockerhub.
```
docker push yourusername/yourjarname:yourtagname
```

5. Pull and run the image. (By others)
```
docker pull yourusername/yourjarname:yourtagname
docker run -p 8080:8080 yourusername/yourjarname:yourtagname
```

### Automate Dockerization with GitHub Actions

- Traditionally, if we're using Docker without automation tools like GitHub Actions, we would indeed need to manually build our application, create a Docker image, and push it to a Docker registry (like Docker Hub) every time we make changes to our code.

- GitHub Actions automates this process.

- With GitHub Actions, we can define workflows in YAML files that specify what actions to take when certain events happen (e.g., pushing to a specific branch).

- By this way, we can automate tasks like building our application, running tests, building Docker images, pushing them to Docker Hub, and even deploying to a server or cloud platform.

- Automating Tasks with GitHub Actions saves time, reduces manual effort and ensures that every code change triggers a consistent build and deployment process.

- Refer <a href="./.github/workflows/ci-cd.yml">ci-cd.yml</a> file to refer how to automate dockarization with GA.


0 comments on commit db1a531

Please sign in to comment.