pipeline {
agent { docker { image 'maven:3.8.4-openjdk-11-slim' } }
stages {
stage('build') {
steps {
sh 'mvn --version'
}
}
}
}
Jenkins Pipeline (or simply "Pipeline") is a suite of plugins which supports implementing and integrating continuous delivery pipelines into Jenkins.
A continuous delivery pipeline is an automated expression of your process for getting software from version control right through to your users and customers.
Jenkins Pipeline provides an extensible set of tools for modeling
simple-to-complex delivery pipelines "as code". The definition of a Jenkins
Pipeline is typically written into a text file (called a Jenkinsfile
) which in
turn is checked into a project’s source control repository.
[1]
For more information about Pipeline and what a Jenkinsfile
is, refer to the
respective Pipeline and
Using a Jenkinsfile sections of the User
Handbook.
To get started quickly with Pipeline:
Copy one of the examples below into your repository and name it Jenkinsfile
Click the New Item menu within Jenkins
Provide a name for your new item (e.g. My-Pipeline) and select Multibranch Pipeline
Click the Add Source button, choose the type of repository you want to use and fill in the details.
Click the Save button and watch your first Pipeline run!
You may need to modify one of the example Jenkinsfile
's to make it run with your project. Try modifying the sh
command to run the same command you would run on your local machine.
After you have setup your Pipeline, Jenkins will automatically detect any new Branches or Pull Requests that are created in your repository and start running Pipelines for them.
Below are some easily copied and pasted examples of a simple Pipeline with various languages.
pipeline {
agent { docker { image 'maven:3.8.4-openjdk-11-slim' } }
stages {
stage('build') {
steps {
sh 'mvn --version'
}
}
}
}
pipeline {
agent { docker { image 'node:16.13.1-alpine' } }
stages {
stage('build') {
steps {
sh 'node --version'
}
}
}
}
pipeline {
agent { docker { image 'ruby:3.0.3-alpine' } }
stages {
stage('build') {
steps {
sh 'ruby --version'
}
}
}
}
pipeline {
agent { docker { image 'python:3.10.1-alpine' } }
stages {
stage('build') {
steps {
sh 'python --version'
}
}
}
}
pipeline {
agent { docker { image 'php:8.1.0-alpine' } }
stages {
stage('build') {
steps {
sh 'php --version'
}
}
}
}
pipeline {
agent { docker { image 'golang:1.17.5-alpine' } }
stages {
stage('build') {
steps {
sh 'go version'
}
}
}
}
Please submit your feedback about this page through this quick form.
Alternatively, if you don't wish to complete the quick form, you can simply indicate if you found this page helpful?
See existing feedback here.