def remote = [:] remote.name = 'workstation' remote.host = 'workstation' remote.user = 'dany' remote.identityFile = '/var/jenkins_home/.ssh/id_rsa' remote.allowAnyHosts = true remote.agent = false remote.logLevel = 'INFO' def build_test(text) { sh''' printenv echo $text echo "Hello ${params.text}" echo $WORKSPACE ls -al $WORKSPACE find /var/jenkins_home -name "Jenkinsfile" ''' } pipeline{ agent { node{ label'master' }} options { // Limit build history with buildDiscarder option: // daysToKeepStr: history is only kept up to this many days. // numToKeepStr: only this many build logs are kept. // artifactDaysToKeepStr: artifacts are only kept up to this many days. // artifactNumToKeepStr: only this many builds have their artifacts kept. buildDiscarder(logRotator(numToKeepStr: "1")) // Enable timestamps in build log console timestamps() // Maximum time to run the whole pipeline before canceling it timeout(time: 1, unit: 'HOURS') // Use Jenkins ANSI Color Plugin for log console ansiColor('xterm') // Limit build concurrency to 1 per branch disableConcurrentBuilds() } stages { stage('Test') { steps { build_test("world") } } stage('Remote SSH') { steps { sshCommand remote: remote, command: ''' set -e echo $WORKSPACE pwd export WORKSPACE="jenkins/workspace/test" cd $WORKSPACE bash test.sh ''' sshCommand remote: remote, command: ''' for i in {1..5}; do echo -n "Loop $i "; date ; sleep 1; done ''' } } } }