Skip to content

yonadev/jnlp-slave-k8s-helm

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 

Repository files navigation

Jenkins JNLP Agent Docker image with kubectl and helm

Docker Stars Docker Pulls Docker Automated build

This image allows for a slave deployed into a k8s cluster to be able to run kubectl and helm commands

We use it for CD actions from Jenkins

Based on Jenkins official jnlp-slave image https://hub.docker.com/r/jenkinsci/jnlp-slave/ kubectl and helm are added in.

Running

To run a Docker container

docker run yonadev/jnlp-slave-k8s-helm -url http://jenkins-server:port <secret> <agent name>

To run a Docker container with Work Directory:

docker run yonadev/jnlp-slave-k8s-helm -url http://jenkins-server:port -workDir=/home/jenkins/agent <secret> <agent name>

Optional environment variables:

  • JENKINS_URL: url for the Jenkins server, can be used as a replacement to -url option, or to set alternate jenkins URL
  • JENKINS_TUNNEL: (HOST:PORT) connect to this agent host and port instead of Jenkins server, assuming this one do route TCP traffic to Jenkins master. Useful when when Jenkins runs behind a load balancer, reverse proxy, etc.
  • JENKINS_SECRET: agent secret, if not set as an argument
  • JENKINS_AGENT_NAME: agent name, if not set as an argument

Issues

  • Error from server (Forbidden): User "system:serviceaccount:somenamespace:default" cannot list pods in the namespace "default". (get pods) If you get this error, the container does not have enough rights (through K8S)

The simple answer is to grant admin permissions to that role with something like this : kubectl create clusterrolebinding --user system:serviceaccount:somenamespace:default kube-system-cluster-admin --clusterrole cluster-admin

You will have to change the user to match the user account that the container is running as.

  • Error: UPGRADE FAILED: incompatible versions client[v2.7.2] server[v2.6.1]

Helm is installed in this container as Client mode only using the latest version of Helm at container build time. The server component (tiller) needs to be at a compatible version. kubectl exec into the container, and run helm init --upgrade to upgrade the tiller component.

Enabled JNLP protocols

By default, the JNLP3-connect 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 (the protocol should be enabled on the master side as well).

In Jenkins versions starting from 2.27 there is a JNLP4-connect protocol. If you use Jenkins 2.32.x LTS, it is recommended to enable the protocol on your instance.

Amazon ECS

Make sure your ECS container agent is updated before running. Older versions do not properly handle the entryPoint parameter. See the entryPoint definition for more information.

About

Jenkins JNLP slave with Kubernetes kubectl and Helm

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •