Cloud Native Jenkins: How Ephermeral Masters and Pluggable Storage Works

Written by: Oleg Nenashev

5 min read

A few months ago, I published a blog post about the Cloud Native Special Interest Group (SIG) and ongoing projects related to cloud native Jenkins. This month, I will be presenting at DevOps World | Jenkins World in Europe with Carlos Sanchez and Jesse Glick, so I would like to provide a heads up for our talk: “A Cloud Native Jenkins.”

Our talk focuses on the following topics: pluggable storage, our ephemeral Jenkins controllers experiments and tools which may be used to implement single-shot controllers.

Pluggable storage

Pluggable storage is one of the major areas we have been working on over the last few months. There are a number of parallel stories which are summarized on this page . There has been significant progress in the areas of artifact storage, build logging and configuration storage. A number of Jenkins Enhancement Proposals were submitted and accepted, and there are plugin releases and prototypes for these stories.

During our talk we will discuss the current status of these stories and future plans. In particular, we will cover the following areas and reference implementations:

  • Storing all your artifacts transparently, e.g. in a cloud service blob store like AWS S3.

  • Providing credentials from an external location.

  • Sending and retrieving the build logs from a cloud service.

  • Storing configuration data in external storage like Kubernetes Resources and SQL database.

  • Storing test results externally, e.g. in an SQL database or a specialized Test Management System.

There are existing plugins for the areas above, but there is a difference in approach we have taken. Instead of creating new custom steps we extend Jenkins architecture in a way that the storage becomes transparent to users. For example, with Artifact Manager for S3 Plugin common, Archive Artifacts steps work transparently with Remote storage, as well as Jenkins Pipeline’s stash() /unstash() steps.

The reference implementations intentionally use different technologies so that we cover more scenarios. We regularly discuss the implementations in the Cloud Native SIG, and we would appreciate your feedback.

Ephemeral Jenkins controllers research

Want something new? Kohsuke Kawaguchi, the creator of Jenkins, posted the Jenkins: Shifting Gears article to summarize the plan for Jenkins evolution. cloud native Jenkins is a critical part of this plan, and it is not “just Jenkins X.” There are various architectural changes in Jenkins required to make this vision happen, and we plan to work on these changes in the Cloud Native SIG.

In our presentation, we will talk about our experiment with ephemeral Jenkins and single-shot controllers. In this story we are creating a headless single-shot controller which starts in a container, executes a Pipeline build and pushes all the results to remote storage so that the container can just be deleted after completion. Such a controller bundles plugins and self-configuration logic using configuration as code, so that it can start executing pipelines in just a few seconds. Once packaged, it can be invoked from the command line interface as simply as…​

docker run --rm -v $PWD/demo/Jenkinsfile:/workspace/Jenkinsfile onenashev/cwp-jenkinsfile-runner-demo

or, in Kubernetes:

kubectl create configmap jenkinsfile --from-file=demo/Jenkinsfile
kubectl create -f demo/kubernetes.yaml

Such a single-shot controller could also be made a part of a cloud native Jenkins system. Standard event handlers like Prow can invoke the builds on webhooks and report results back, so that the single-shot controller can be used to build pull requests or to run continuous delivery flows. Extra agents could also be connected to the controller on-demand, using the Kubernetes plugin or sidecar containers.

Tools

In order to make this experiment possible, we used a toolchain based on Docker, Jenkinsfile Runner , Jenkins Configuration as Code Plugin (JCasC), and a Custom WAR Packager tool which glues all the things together.

Custom WAR Packager is a new tool which takes various configurations (YAML specification defining core version, list of plugins, system properties, Groovy Hooks, JCasC YAMLs)…​ and then bundles everything as a ready-to-fly WAR file or Docker image. Starting from version 1.2, Custom WAR Packager also supports packaging Jenkinsfile Runner images as an experimental feature. I will do a separate blogpost about this new tool later, but there is already some documentation a number of demos in the project’s repo.

Our demo

Yes, we will have a demo! We will show a single-shot controller running with Pluggable storage implementations for AWS environments (Amazon S3, AWS CloudWatch, EKS, etc.), which executes Jenkins pipelines for Maven projects and provisions agents in Kubernetes on-demand.

The demo has to be published yes, but you can already find a more simple Jenkinsfile Runner demo here .

Want to know more?

The upcoming DevOps World | Jenkins World conferences are heavily packed with talks related to cloud native Jenkins, including war stories and presentations on projects like Jenkins X and Jenkins Evergreen. It is a great chance to get more information about using Jenkins in cloud environments.

If you are a Jenkins contributor or just want to become a contributor, also join us at the Contributor Summit on Oct 23 in Nice or visit the Jenkins community booth in the exhibition hall.

Come meet Carlos, myself and other Cloud Native SIG members at DevOps World | Jenkins World Europe in Nice on October 22-25. If you haven't registered yet, there's still time to do so. Use registration code JWFOSS and get 30% off!

Stay up to date

We'll never share your email address and you can opt out at any time, we promise.