Skip to content

byteknacker/jenkins-formula

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Salt Formula for Setting Up Jenkins

Available States

jenkins
jenkins.agent
jenkins.cli
jenkins.config
jenkins.jobs
jenkins.nginx
jenkins.plugins

State: jenkins

The sls file of init.sls runs for this state.

  1. Create the group and user of jenkins.
  2. Update the package manager's correct repository depending on the OS family.
  3. Install Jenkins from the updated package repository.

State: jenkins.agent

The sls file of agent.sls runs for this state.

  1. Create the appropriate settings for Jenkins agent without installing a Jenkins master. This can be separately used by any independent Jenkins agent setup.
  2. Install the public key so that the Jenkins master can connect to this agent.

Please read on the section on jenkins.master to understand the connection between that and this state.

State: jenkins.cli

The sls file of cli.sls runs for this state.

It is rarely used on its own but as a help for plugins.sls and jobs.sls.

Due to differences in the scope of functionality of netcat between RedHat and Debian/other Linux distributions, nc -z does not work on RedHat since the option -z simply does not exist. Hence by default, RedHat distro will use curl instead. If you are on Debian distro, please feel free to use a custom versin of netcat. You can define that in your pillar file as netcat_pkg: your_nc_package.

  1. Listen to Jenkins server.
  2. Find out if it is serving data.
  3. Download the Jenkins CLI jar file.
  4. Login with the pre-configured admin user and password.
  5. Find out if Jenkins is responding with Jenkins CLI.

State: jenkins.config

The sls file of config.sls runs for this state.

  1. Get all Jenkins master configurations and settings from a remote git repository.
  2. Change the ownership of JENKINS_HOME since the git repo is forcibly copied over the old configuration files by the root user.
  3. Restart the Jenkins service.

State: jenkins.jobs

The sls file of jobs.sls runs for this state.

  1. Programmatically add states for jobs that you define in the pillar file.

State: jenkins.master

The sls file of master.sls runs for this state.

  1. Create the .ssh directory to store the private key.
  2. Deploy the private key so that connection with agent is possible.

You still need to connect the node for the Jenkins agent within the Jenkins master your self via the Web GUI but the difficult part of setting up the keys and making things work with a simple setup is done with this state.

State: jenkins.nginx

The sls file of nginx.sls runs for this state.

This state is designed for Redhat OS family as a default. If you are on Debian, please change the nginx_user and nginx_group to www-data in your pillar. There are two sets of different nginx configuration files in jenkins/files. Each one is designed specifically for an OS family. Currently, only Debian and Redhat OS families are supported, although the Debian version would work for most other Linux OS distributions.

  1. Installation of nginx.
  2. Add a jenkins nginx entry for reverse proxy.
  3. Restart nginx.

State: jenkins.plugins

The sls file of plugins.sls runs for this state.

  1. Update the plugins list of versioning from the Jenkins server.
  2. Programmatically generate states depending on the entries in pillar for plugins to be installed or disabled.
  3. Restart Jenkins service after the last plugin installation.

Pillar Customisations

Put your pillar settings to the directory /srv/salt/pillar on your salt-master machine. Inspect the pillar.example file to see the structure of the pillar. Inspect map.jinja to see what variables are there to customise with pillar.

jenkins:
  lookup:
    port: 80
    home: /usr/local/jenkins
    user: jenkins
    group: www-data
    server_name: ci.example.com

Contributing to This Project

  1. Fork this repository.
  2. If you need to include this repo in a git superproject, then make your fork a git submodule.
  3. Submit Pull Request when you have developed a new feature or made a fix.

Releases

No releases published

Packages

No packages published

Languages

  • SaltStack 87.3%
  • HTML 12.7%