Prerequisites:
- Ubuntu Machine
- GitLab account
- Node, NPM, Docker installed on Ubuntu Machine & Local Machine
Steps:
1. Project Folder
- Create a react app on your local machine using npx create-react-app react-app
- Create nginx.conf file with below content
http {
  include mime.types;
  set_real_ip_from        0.0.0.0/0;
  real_ip_recursive       on;
  real_ip_header          X-Forward-For;
  limit_req_zone          $binary_remote_addr zone=mylimit:10m rate=10r/s;
  server {
    listen 80;
    server_name localhost;
    root /proxy;
    limit_req zone=mylimit burst=70 nodelay;
    location / {
            root   /usr/share/nginx/html;
            index  index.html index.htm;
            try_files $uri /index.html;   
    }
  }
}
events {}
- Create a Dockerfile with below content
FROM nginx:latest
COPY ./build /usr/share/nginx/html
COPY nginx.conf /etc/nginx/nginx.conf  
EXPOSE 80/tcp 
CMD ["/usr/sbin/nginx", "-g", "daemon off;"]  
- Create a deploy.sh file
#!/bin/bash
# Pull the latest Docker image
docker pull <image-name>
# Stop and remove any existing container with the same name
docker stop <container-name> || true
docker rm <container-name> || true
# Run the Docker container
docker run -d --name <container-name> -p <host-port>:<container-port> <image-name>
- Add the .pem file, which will be require to SSH into our Ubuntu machine in same folder.
2. GitLab
- Create a GitLab account if you don't have
- Push code to GitLab
- Goto Setting -> CICD -> Variables
- Create a new variable with DNS of your ubuntu machine, Docker Image Name, Docker Hub Token(configure later on), Docker Hub username
  
- Create a cicd file in gitlab pipeline editor with below content
stages:
  - build
  - build image
  - deploy
Build:
  stage: build
  image: node:20-alpine
  script:
    - npm install
    - npm run build
  artifacts:
      paths:
        - build/
Push To DockerHub:
  stage: build image
  image: docker:stable
  services:
    - docker:dind
  script:
    - docker build -t $DH_IMAGE_NAME .
    - docker login -u $DH_USER_NAME -p $DH_TOKEN
    - docker push $DH_IMAGE_NAME
  dependencies:
    - Build
Deploy to EC2:
  stage: deploy
  image: alpine:3.19
  before_script:
    - apk update
    - apk add openssh-client
    - chmod 600 "Ubuntu1Key.pem" 
  script:
    - ssh -o StrictHostKeyChecking=no -i "Ubuntu1Key.pem" ubuntu@"$U1_EC2_DNS" 'bash -s' < deploy.sh  
Explantion:
This CI/CD file in GitLab has three stages:
- Build: Uses Node.js to install dependencies and build the project. The resulting artifacts are stored in the build/ directory.
- Push To DockerHub: Builds a Docker image using Docker's stable version, then pushes it to DockerHub after logging in with credentials.
- Deploy to EC2: Utilizes Alpine Linux to update packages and install SSH client. It sets permissions for SSH key usage, then deploys to an EC2 instance by executing a deployment script via SSH.
3. Docker Hub
- Create an account for Docker Hub
- Goto My Account -> Security -> Create A new Token (With Read and Write)
- Copy the token & paste it in the variable create earlier in GitLab name DH_TOKEN
4. Run the CICD Pipeline
- Commit once on the main branch, so our CICD will be triggered automatically.
- Goto the Build -> Pipelines
- After successful completion of CICD, it will look like this
Now open the Public IP of EC2 with host-port which you specified in the deploy.sh.
BYE 👋👋
 


 
    
Top comments (4)
Very informative!
❤️
from where is this Dockerfile executing?
You have to run it in your development device, and push the image to Dockerhub
I must have missed mentioning that in blog