👋 Welcome to the CI/CD world!
CI- Continuos Integration
CD - Continuos Deployment
CD - Continuos Delivery
Continuous Integration (CI) is the practice where developers regularly merge their code changes into a shared repository using a version control system (VCS) like GitHub. The primary goal is to detect bugs early and ensure seamless code integration.
Continuous Deployment (CD) refers to the automated process of deploying code changes directly to various environments, such as development, staging, and production after successful integration and testing , Jenkins handles the process to make it smooth and fast.
Continuous Delivery (CD) means the application is always ready to be deployed to the production environment. The code is tested and prepared, so it can be released anytime.
When developers push their code to a shared repository, a CI/CD pipeline automatically performs a series of actions.
🚀 Developer writes code → 🛠 Pushes to **GitHub** → 🤖 CI/CD
Several tools can create CI/CD pipelines, including Jenkins, GitLab, and Travis CI. Jenkins, being the most widely used, will be our focus.
Jenkins monitors the GitHub repository continuously. When it detects changes, it automatically triggers a pipeline that fetches code, installs dependencies, runs tests, builds the application, and deploys it. This workflow is standard across most organizations.
🚀 Developer writes code → 🛠 Pushes changes to **GitHub** → 🤖 **Jenkins (CI/CD Tool)**
Let's explore how this works with a React application using Jenkins, going through it step by step.
- Imagine you're working at an organization with a React-based e-commerce project. Your manager assigns you to implement new functionality requested by the client.
- After updating the functionality and pushing the code to GitHub, Jenkins—which continuously monitors for GitHub changes—automatically initiates its pipeline. When code changes are detected, Jenkins executes a series of staged actions: **
fetching the code, install the dependencies, run the tests, builds , deploys it *
.***While these are the standard stages most organizations follow, the number and type of stages can be customized based on specific requirements. - Usually Jenkins deploys the application to three environments
-
Dev Environment
Development environment where the application undergoes testing. If all tests pass successfully, the application is deployed to the staging environment.
-
Staging Environment
This is a pre-production environment where the application is deployed for final testing and validation before moving to production. It serves as the last verification stage before the production release.
-
Production Environment
This is the live environment where end users or clients interact with and access the application
🚀 App → 🛠 GitHub → 🤖 Jenkins → 🖥 Dev → 🧪 Staging → 🌐 Production
- App: User interacts with the application.
- GitHub: Source code is managed in repositories.
- Jenkins: CI/CD pipeline automates builds.
- Dev: Development environment testing.
- Staging: Pre-production validation.
- Production: Live environment for users.
Let’s see how actually it done in practical in step by step manner,
-
Step 1: Create EC2 instance
- Go to AWS Management Console and create a account on AWS, select root user and sign in to AWS
- After sign in to AWS, it shows a dashboard where you can see the services like
EC2, Cloud Watch, S3
etc.., - Click on
EC2
- On top right corner you see
Launch Instance
click on it - After that you see
Names and tags
under that it hasName
write a name of your instane that you want to create - After that you see **
Application and OS Images (Amazon Machine Image)**
under that you seeRecents and Quick Start
select Ubuntu ( in my case i select ubuntu, you can select according to your choice) - Under that you have **
Key pair (login)**
clickCreate new key pair
and enter name as you want to name the key according to your choice and in below you seePrivate key file format
by default it has.pem
keep it as it before and next ClickCreate Key Pair
andLaunch Instance
- Click instances after few seconds you will see the Instance is running , if you not see you will
All State
toggle button click on it and then clickRunning
. - After click the instance you will see a dashboard in which you will see all the details regarding to instances like
Public IP address and Private IP address
-
Step 2: SSH into the EC2 Instance
- Go to your terminal and run the below commands
ssh -i /Users/username/Downloads/key-pair.pem ubuntu@instance-public-ip-address
( i use mac, so in mac it looks like this, you have apple id in which you give user name, that will be username, key-pair.pem will be in step 1 we create a key pair write name of that file .pem is a extension of that, i select ubuntu machine and paste your public ip address, it will look as,ssh -i /Users/abc/Downloads/jenkins.pem ubuntu@100.23.45.6
- after that it asks for yes/no, type yes, and then it shows permission denied, to grant permission you will run this
chmod 600 /Users/username/Downloads/key-pair.pem
and after thatssh -i /Users/username/Downloads/key-pair.pem ubuntu@instance-public-ip-address
now you will see the the ip address likeubuntu@172.870.990.000
-
Step 3: Install Jenkins on the EC2 Instance
Install Java (Jenkins requires Java to run)
sudo apt update sudo apt install openjdk-11-jdk -y # For Ubuntu
Verify Java Installed
sudo apt update sudo apt install openjdk-11-jdk -y # For Ubuntu
Install Jenkins
curl -fsSL https://pkg.jenkins.io/debian/jenkins.io-2023.key | sudo tee \ /usr/share/keyrings/jenkins-keyring.asc > /dev/null echo deb [signed-by=/usr/share/keyrings/jenkins-keyring.asc] \ https://pkg.jenkins.io/debian binary/ | sudo tee \ /etc/apt/sources.list.d/jenkins.list > /dev/null sudo apt-get update sudo apt-get install jenkins
Verify Jenkins running on which port, usually it runs on port 8080
ps -ef | grep jenkins # you will see jenkin 8080 after running above command
-
Step 4: Create Security group on EC2 Instance and Login to Jenkins
- Click on EC2 Instance and after that you will see all the information related to instance, under that you will
security groups tab
, click on it click on the security group you will navigate to the tab where you seeAdd inbound traffic rule
, clickAdd rule
and inbound traffic rule to only allowcustom TCP
port8080
- After that copy
EC2 Public IP Address
and go to browser and paste the public ip address like below, always use http not https it looks likehttp:public-ip-address:8080
- After that you will see on browser like
Getting started
andUnlock Jenkins
- After that you will see like this
/var/lib/jenkins/secrets/initialAdminPassword
copy that and run on terminal - Like
sudo cat /var/lib/jenkins/secrets/initialAdminPassword
you will see a password after running this copy it and paste it in aAdministrator password
tab
- Click on EC2 Instance and after that you will see all the information related to instance, under that you will
-
Step 5: Install the Plugins
- click on Install suggested plugins and Wait for the Jenkins to Install suggested plugins
- After that Create First Admin User and remember the name and password that your type in
- After that you will see
Jenkins is Ready
clickstart using jenkins
-
Step 6: Install the Docker Pipeline plugin in Jenkins
- Go to Manage Jenkins > Manage Plugins
- In the Available tab, search for "Docker Pipeline".
- Select the plugin and click the Install button.
- Restart Jenkins after the plugin is installed.
-
Step 7: Docker Slave Configuration
- In terminal run this commands
sudo apt update sudo apt install docker.io sudo su - usermod -aG docker jenkins usermod -aG docker ubuntu systemctl restart docker // output: root@ip-172-54-67-8-9-9 su - jenkins // output: jenkins@ip-172-54-67-8-9 docker run hello-world // output: permission denied logout // output: root@ip-172-54-67-8-9-9 usermod -aG docker jenkins su - jenkins // output: jenkins@ip-172-54-67-8-9 docker run hello-world // run succesfully
Let’s see how to create in step by step manner.
- On Jenkins dashboard Click +
New Item
- It shows the options like
free style project, pipeline, folder etc..,
- Click on pipeline and give the job name the pipeline that you want to give
- After that it shows Description in which you can give information about the pipeline, now scroll to bottom you will see
pipeline with script, pipeline scm
this is your choice if we want to define stages on jenkins tool it self then clickpipeline with script
and write the stages - Instead of writing the stages on tool, you can select
pipeline scm
- If you select
Pipeline scm
just below you will see a dropdown which containsnone and Git
selectGit
- After selecting
Git
it showsrepository URL
, branchmaster or main
initially it hasmaster
, below pathJenkinsfile
- Now, if you select
Pipeline scm
you have to write stages on your project directory like create Jenkinsfile and write stages according to your project requirements, here stages nothing but set of actions that we see above - After creating a Jenkinsfile and define stages on it on project directory, paste the repo URL on
repository URL
- Select branch if your branch is master write master if its main then write main
- After that if you create a seperate folder for jenkins file then click on folder on github and copy the folder name from the url and add it before the
Jenkinsfile
in the path below likemy-first-ci-cd-pipeline/Jenkinsfile
it should be look like this - Click Save to apply the changes.
- Click Build Now in the job dashboard to manually start the pipeline.
- Under you will build is creating, click on
…
three dots you will see the options and click onconsole output
you will see how it fetches and executes, if all good you will seeFinish Success
if any thing fails you will seeFailed
- After if you go to dashboard you will see the pipelines that you have created on jenkins and you can all the details there like time, status etc..,
This is how we can create a pipeline on Jenkins
Above we have seen how to create the pipeline, now we will see how to write stages in jenkinsfile
The basic syntax for writing stages is
Declarative Jenkins Pipeline with SCM (GitHub):
pipeline {
agent any // Use any available agent
environment {
REPO_URL = 'https://github.com/yourusername/your-repository.git' // Replace with your GitHub repo URL
BRANCH_NAME = 'main' // The branch to checkout (e.g., 'main')
}
stages {
stage('Checkout or fetches code') {
steps {
// Checkout code from GitHub repository
git url: REPO_URL, branch: BRANCH_NAME
}
}
stage('Install Dependencies') {
steps {
// Install project dependencies
sh 'npm install'
}
}
stage('Build') {
steps {
// Build the React app
sh 'npm run build'
}
}
stage('Test') {
steps {
// Run tests (optional)
sh 'npm test'
}
}
stage('Deploy') {
steps {
// Deploy the app (replace with your actual deployment step)
echo 'Deploying the app...'
}
}
}
post {
always {
// Actions that always run after the pipeline
echo 'Pipeline execution completed.'
}
success {
// Actions on success
echo 'Pipeline executed successfully!'
}
failure {
// Actions on failure
echo 'Pipeline failed!'
}
}
}
If we use agent as docker then,
pipeline {
agent {
docker { image 'node:16-alpine' }
}
stages {
stage('Install Dependencies') {
steps {
sh 'npm install'
}
}
stage('Build') {
steps {
sh 'npm run build'
}
}
stage('Test') {
steps {
sh 'npm test'
}
}
}
post {
failure {
echo 'Build failed. Please check the console output for errors.'
}
}
}
The stages may increase or decrease but it should be like above, the scripting might chnage
for project to project but syntax should be like this, these are just examples.
Jenkins is one of the best and most useful tools in DevOps pipelines ⚙️. By automating tasks like building 🔨, testing 🧪, and deploying 🚀, it helps teams deliver software faster, more reliably, and with fewer mistakes. Learning Jenkins will improve your CI/CD skills 💡 and make your development process smoother 🌱.
If you’re new to Jenkins, start by trying simple pipelines 🛠️. As you get more comfortable, try using Jenkins with other tools like Docker 🐳, Kubernetes ☸️, or AWS ☁️. Jenkins also has many helpful plugins 🔌 to add more features.