Introduction.
In today’s fast-paced software development world, automation is a crucial part of improving efficiency and reducing errors. Jenkins, a popular open-source automation server, plays a significant role in this by providing continuous integration and continuous delivery (CI/CD) services. To further enhance its capabilities, Jenkins offers a powerful REST API that allows developers to integrate Jenkins with other applications, monitor jobs, trigger builds, and manage configurations programmatically. In this blog, we’ll dive into the concept of the Jenkins REST API, explore its key features, and discuss how you can leverage it to automate workflows and improve your DevOps practices. Whether you’re looking to build custom integrations or automate repetitive tasks, understanding Jenkins’ REST API is a valuable skill for modern developers.
STEP 1: Go to jenkins dashboard.
data:image/s3,"s3://crabby-images/32d21/32d21fb8d1b129e47e803ac84b1f349fdc7009a2" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 1 Screenshot 2025 02 21 144345"
STEP 2: Click on your user name.
- Select security create API Token.
- Click on Add new token.
- Enter the name and click on generate.
- Copy your token.
data:image/s3,"s3://crabby-images/7c532/7c532c5380742b4c55a7676e56266af96e0fa3b7" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 2 Screenshot 2025 02 21 144613"
data:image/s3,"s3://crabby-images/93b99/93b99038dad36a0a082169804f989f7e34123f60" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 3 Screenshot 2025 02 21 144636"
STEP 3: Next, Go to dashboard create new item.
- Enter the Job name and select the freestyle project.
- Click on ok.
- Configure the Job.
- Scroll down Click on Add build and select execute shell.
- Enter the ls -l command.
- Apply and save.
data:image/s3,"s3://crabby-images/7761a/7761a6f3e2572e4037d50bbf0d5042004346eadb" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 4 Screenshot 2025 02 21 144929"
data:image/s3,"s3://crabby-images/88b81/88b81f09dcb8405418e23eecd250de704f3df096" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 5 Screenshot 2025 02 21 145007"
data:image/s3,"s3://crabby-images/d56b9/d56b9da39f7c36d5de0bc742709071605fec32d5" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 6 Screenshot 2025 02 21 145035"
STEP 4: Accessing the SSH Connection.
- Enter the following command.
echo "<API_TOKEN>" > APITOKEN
cat APITOKEN
data:image/s3,"s3://crabby-images/901d5/901d57a64711780c0fefa34d06cd78d6fb95ac0a" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 7 Screenshot 2025 02 21 145326"
STEP 5: Go to jenkins dashboard.
- Re-write the URL of Jenkins by adding /crumbIssuer/api/xml then hit Enter:
data:image/s3,"s3://crabby-images/52e0a/52e0ad3766719e47abec58d9a12a3a75f9345b54" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 8 Screenshot 2025 02 21 145417"
data:image/s3,"s3://crabby-images/02136/02136e193297c0c4802502e76838d645e24492ac" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 9 Screenshot 2025 02 21 145602"
STEP 6: Execute the following command in the shell to retrieve the Jenkins crumb token. Replace username and password with the credentials Used in SSH Connection, and <jenkins-server-url> with the public IPv4 address of the EC2 instance.
crumb=$(curl -u "username:password" -s "http://<jenkins-server-url>/crumbIssuer/api/xml?xpath=concat(//crumbRequestField,\":\",//crumb)")
echo $crumb
cat APITOKEN
data:image/s3,"s3://crabby-images/89cb5/89cb5c599f26d0166a07eb7a56a0fe42d84b5480" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 10 Screenshot 2025 02 21 152318"
STEP 7: Run below command to start the build on Job1, replace “USERNAME:APITOKEN” with the username that you set initially and APITOKEN from previous step.
curl -X POST -u USERNAME:APITOKEN "JOB_URL/build" -H "crumb"
STEP 8: Go to dashboard and verify the job build.
data:image/s3,"s3://crabby-images/f9eb1/f9eb12ed982fb34e57fc1fb59a4f233ce5ac84fe" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 11 Screenshot 2025 02 21 151450"
data:image/s3,"s3://crabby-images/a60a3/a60a37fd7749f04174138d6acd1ab15e1898863d" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 12 Screenshot 2025 02 21 151509"
STEP 9: Run the below command to retrieve the configuration of a Jenkins job and save it locally, replace JobURL with the URL of Job1 from previous step, USER_NAME.
curl -X GET JobURL/config.xml -u USER_NAME:API_TOKEN -o mylocalconfig.xml
ls -l
curl -s -XPOST 'JENKINS_HOST/createItem?name=JOB_NAME' -u USERNAME:API_TOKEN --data-binary @mylocalconfig.xml -H "$crumb" -H "Content-type:text/xml"
data:image/s3,"s3://crabby-images/da5f4/da5f487d35d7e2f4c355600384f493f2cb8c7569" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 13 Screenshot 2025 02 21 153013"
data:image/s3,"s3://crabby-images/f0c37/f0c378f76da7ab2060fa9efdc420978fa214bf8f" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 14 Screenshot 2025 02 21 153446"
STEP 10: Go to jenkins dashboard and verify the created the job2 like job1.
data:image/s3,"s3://crabby-images/b3191/b3191887e74b657bac646b37e15ae70f09b41c96" alt="Understanding the Jenkins REST API: A Comprehensive Guide. 15 Screenshot 2025 02 21 153636"
Conclusion.
In conclusion, the Jenkins REST API enhances the flexibility of Jenkins by providing a means for developers and system administrators to automate processes, monitor builds, and manage Jenkins configurations without directly interacting with the Jenkins UI. It’s a valuable resource for DevOps teams looking to streamline their workflows and integrate Jenkins into a broader automation pipeline.
Add a Comment