Implementation of new vars configtest_enable and service_restart and their respective optional arguments.

Argument configtest_enable / params.pp $nx_configtest_enable
* Default false
* If true will set service[nginx] restart with contents of nx_service_restart.

Argument service_restart / params.pp $nx_service_restart
* Default '/etc/init.d/nginx configtest && /etc/init.d/nginx restart'
* Since nginx 0.7.53 nginx supports '-s HUP' which will reload testing configuration first, to be backwards compatible above default was choosen.

Many distributions of nginx already implement a configtest before restart, however many doesn't, and many
even don't provide restart but a stop/start combination. If configtest_enable is true then puppet will force
nginx to do a configtest no matter if it was going or not to do it itself.
This commit is contained in:
Guzmán Brasó 2012-09-30 17:29:55 -03:00
parent e9d984eaaf
commit 197ad06bce
3 changed files with 22 additions and 2 deletions

View file

@ -33,6 +33,8 @@ class nginx (
$worker_connections = $nginx::params::nx_worker_connections, $worker_connections = $nginx::params::nx_worker_connections,
$proxy_set_header = $nginx::params::nx_proxy_set_header, $proxy_set_header = $nginx::params::nx_proxy_set_header,
$confd_purge = $nginx::params::nx_confd_purge, $confd_purge = $nginx::params::nx_confd_purge,
$configtest_enable = $nginx::params::nx_configtest_enable,
$service_restart = $nginx::params::nx_service_restrart,
) inherits nginx::params { ) inherits nginx::params {
include stdlib include stdlib
@ -50,7 +52,10 @@ class nginx (
notify => Class['nginx::service'], notify => Class['nginx::service'],
} }
class { 'nginx::service': } class { 'nginx::service':
configtest_enable => $configtest_enable,
service_restart => $service_restart,
}
# Allow the end user to establish relationships to the "main" class # Allow the end user to establish relationships to the "main" class
# and preserve the relationship to the implementation classes through # and preserve the relationship to the implementation classes through

View file

@ -54,4 +54,11 @@ class nginx::params {
/(?i-mx:debian|ubuntu)/ => 'www-data', /(?i-mx:debian|ubuntu)/ => 'www-data',
/(?i-mx:fedora|rhel|redhat|centos|suse|opensuse)/ => 'nginx', /(?i-mx:fedora|rhel|redhat|centos|suse|opensuse)/ => 'nginx',
} }
# Service restart after Nginx 0.7.53 could also be just "/path/to/nginx/bin -s HUP"
# Some init scripts do a configtest, some don't. If configtest_enable it's true
# then service restart will take $nx_service_restart value, forcing configtest.
$nx_configtest_enable = false
$nx_service_restart = "/etc/init.d/nginx configtest && /etc/init.d/nginx restart"
} }

View file

@ -13,7 +13,10 @@
# Sample Usage: # Sample Usage:
# #
# This class file is not called directly # This class file is not called directly
class nginx::service { class nginx::service(
$configtest_enable = $nginx::params::nx_configtest_enable,
$service_restart = $nginx::params::nx_service_restart,
) {
exec { 'rebuild-nginx-vhosts': exec { 'rebuild-nginx-vhosts':
command => "/bin/cat ${nginx::params::nx_temp_dir}/nginx.d/* > ${nginx::params::nx_conf_dir}/conf.d/vhost_autogen.conf", command => "/bin/cat ${nginx::params::nx_temp_dir}/nginx.d/* > ${nginx::params::nx_conf_dir}/conf.d/vhost_autogen.conf",
refreshonly => true, refreshonly => true,
@ -27,4 +30,9 @@ class nginx::service {
hasrestart => true, hasrestart => true,
subscribe => Exec['rebuild-nginx-vhosts'], subscribe => Exec['rebuild-nginx-vhosts'],
} }
if $configtest_enable == true {
Service["nginx"] {
restart => $service_restart,
}
}
} }