Skip to content

A Docker Image which has a capability to run docker inside that is compatible with the Jenkins Kubernetes Plugin

License

Notifications You must be signed in to change notification settings

billyteves/jenkinslave-dind-kubernetes

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

jenkinslave-dind-kubernetes

docker pull billyteves/jenkinslave-dind-kubernetes:<tag>

A Docker Image which has a capability to run docker inside and is compatible with the Jenkins Kubernetes Plugin. This Docker Image can be used as a Jenkins slave or a simple development container image.

The jenkins-slave script used is a mash-up of carlossg/jenkins-slave-docker and jenkinsci/docker-jnlp-slave

Docker-in-Docker: Credits to Jerome Petazzoni jpetazzo/dind

Docker Hub: https://hub.docker.com/r/billyteves/jenkinslave-dind-kubernetes

Purpose

The main purpose of the creation of this image is to be able to create a jenkins slave on-demand triggered by the Jenkins Kubernetes Plugin. The kubernetes plugin will create multiple kubernetes environment variables that will be use by the Jenkins Remoting Tool and connect to Jenkins Master via JNLP connection.

Docker-in-Docker

As a jenkins-slave, SCM is part of the process. Each code repositories should be able to build images. Based on their Jenkinsfile or on the Pipeline script, the ability to build and test the image before pushing to a private/public docker registry.

Kubectl

If the build image passed the testing and deployed to docker registry, the jenkinslave-dind-kubernetes should be able to deploy the created image using the kubectl command line interface (if invoked in Jenkinsfile or in Pipeline script).

Operating System

  • Ubuntu 16.04

Additional Tools Included

  • Jenkins Remoting Tool 3.14
  • Git 2.7.4
  • Kubectl v1.9.0
  • Docker CE 17.11.0-ce, build 1caf76c (with multi-stage support)
  • Docker Compose 1.18.0, build 8dd22a9
  • Java with OpenJDK 9
  • AWS CLI Tool 1.14.14
  • Python 2.7.12
  • Pip 9.0.1

Configuration Specifics

By default, JnlpProtocol3 is disabled due to the known stability and scalability issues. You can enable this protocol on your own risk using the JNLP_PROTOCOL_OPTS=-Dorg.jenkinsci.remoting.engine.JnlpProtocol3.disabled=false property.

Running

To run a Docker container

docker run --privileged billyteves/jenkinslave-dind-kubernetes -url http://jenkins-server:port <secret> <slave name>

If the command line options are not set it will try to use environment variables, including Kubernetes set variables for services jenkins and jenkins-slave.

  • JENKINS_URL: url for the Jenkins server
  • JENKINS_SERVICE_HOST and JENKINS_SERVICE_PORT: will be used to compose the url if the previous is not present.
  • JENKINS_TUNNEL: (HOST:PORT) connect to this slave host and port instead of Jenkins server
  • JENKINS_SLAVE_SERVICE_HOST and JENKINS_SLAVE_SERVICE_PORT: will be used to compose the tunnel argument if the previous is not present.

To run a Docker container as develoment bash with no establishment of jenkins-slave connection:

docker run --privileged billyteves/jenkinslave-dind-kubernetes:<tag> bash

Using Jenkins Kubernetes Plugin Configuration

to be followed ...

Building

docker build -t billyteves/jenkinslave-dind-kubernetes .

About

A Docker Image which has a capability to run docker inside that is compatible with the Jenkins Kubernetes Plugin

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages