Skip to content

A Chef cookbook that installs and configures consul-template

License

Notifications You must be signed in to change notification settings

leaprail/consul-template-cookbook

 
 

Repository files navigation

consul-template-cookbook

Build Status Cookbook Version

Installs and configures consul-template.

This is a fork of https://github.com/adamkrone/chef-consul-template with the following changes:

  • Drop support for Windows
  • No longer use libarchive as it causes a lot of problems.
  • Use the tgz packages instead of the zip ones.
  • Use a more modern style of defining resources.
  • Collapse all the recipes into default.
  • Only define the checksums for the 0.24.1, 0.23.0, and 0.22.1. Or in other words, just for the latest 3 minor versions.
  • Support the arm architecture.
  • Only support the linux OS.

Supported Platforms

  • Ubuntu 18.04
  • Debian 9.8
  • Centos 7.6

Attributes

  • node['consul_template']['base_url'] - Base URL for consul-template binary files
  • node['consul_template']['version'] - Version of consul-template to install. Used to determine which binary to grab from the base_url.
  • 'node['consul_template']['install_dir'] - Directory where consul-template should be installed.
  • node['consul_template']['checksums'] - Contains a hash of checksums where the key is the file for a given OS/architecture, and the value is the associated checksum. For example, consul-template_0.3.1_linux_amd64.
  • node['consul_template']['config_dir'] - The directory that contains the configuration files for consul-template.
  • node['consul_template']['service_user'] - Defines the user that should be used for the consul-template service.
  • node['consul_template']['service_group'] - Defines the group that should be used for the consul-template service.
  • node['consul_template']['template_mode'] - File permissions mode for all consul-template configuration files.
  • node['consul_template']['consul_addr'] - Name:port to access consul (default: 127.0.0.1:8500)
  • node['consul_template']['vault_addr'] - URL to access Vault (default: https://127.0.0.1:8200)

Additionally, the contents of the node['consul_template']['config'] hash will be reflected into the default configuration file -- /etc/consul-template.d/default.json.

Recipes

default

Installs and configures consul-template.

LWRP

consul_template_config

Creates configuration files in node['consul_template']['config_dir'], and reloads the configuration.

For example, if you want to generate HAProxy's config using consul-template, you may include something like this in your recipe:

consul_template_config 'haproxy' do
  templates [{
    source: '/etc/haproxy/haproxy.cfg.ctmpl',
    destination: '/etc/haproxy/haproxy.cfg',
    command: 'service haproxy restart'
  }]
  notifies :reload, 'service[consul-template]', :delayed
end

About

A Chef cookbook that installs and configures consul-template

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Ruby 89.6%
  • Shell 6.1%
  • HTML 4.3%