Honor rgw_enable and mon_enable for systemd units

Consume rgw_enable and mon_enable parameters to set the 'enable'
state for the systemd units.

Also removes support for sysvinit as we don't support Hammer
in the master branch so we can default to systemd.

Change-Id: I1e0415f0b7f640b1b2d05abcc2e7781ad5bb35a3
Closes-Bug: 1622825
Co-Authored-By: Alex Schultz <aschultz@redhat.com>
This commit is contained in:
Giulio Fidente 2016-09-13 15:40:31 +02:00 committed by Alex Schultz
parent d4cc06688c
commit 16889b71e9
6 changed files with 37 additions and 50 deletions

View File

@ -33,6 +33,9 @@
# If set to absent, it will stop the MON service and remove # If set to absent, it will stop the MON service and remove
# the associated data directory. # the associated data directory.
# #
# [*mon_enable*] Whether to enable ceph-mon instance on boot.
# Optional. Default is true.
#
# [*public_addr*] The bind IP address. # [*public_addr*] The bind IP address.
# Optional. The IPv(4|6) address on which MON binds itself. # Optional. The IPv(4|6) address on which MON binds itself.
# #
@ -56,6 +59,7 @@
# #
define ceph::mon ( define ceph::mon (
$ensure = present, $ensure = present,
$mon_enable = true,
$public_addr = undef, $public_addr = undef,
$cluster = undef, $cluster = undef,
$authentication_type = 'cephx', $authentication_type = 'cephx',
@ -76,37 +80,27 @@ define ceph::mon (
$cluster_name = 'ceph' $cluster_name = 'ceph'
} }
# NOTE(aschultz): this is the service title for the mon service. It may be
# different than the actual service name.
$mon_service = "ceph-mon-${id}" $mon_service = "ceph-mon-${id}"
# For Ubuntu Trusty system # For Ubuntu Trusty system
if $::service_provider == 'upstart' { if $::service_provider == 'upstart' {
$init = 'upstart' $init = 'upstart'
Service { Service {
name => $mon_service, name => "ceph-mon-${id}",
provider => $::ceph::params::service_provider, provider => $::ceph::params::service_provider,
start => "start ceph-mon id=${id}", start => "start ceph-mon id=${id}",
stop => "stop ceph-mon id=${id}", stop => "stop ceph-mon id=${id}",
status => "status ceph-mon id=${id}", status => "status ceph-mon id=${id}",
enable => $mon_enable,
} }
} # Everything else that is supported by puppet-ceph should run systemd.
elsif $::service_provider == 'systemd' { } else {
$init = 'systemd' $init = 'systemd'
Service { Service {
name => $mon_service, name => "ceph-mon@${id}",
provider => $::ceph::params::service_provider, enable => $mon_enable,
start => "systemctl start ceph-mon@${id}",
stop => "systemctl stop ceph-mon@${id}",
status => "systemctl status ceph-mon@${id}",
}
# For Red Hat systems (not supporting Jewel now, only Hammer)
} else {
$init = 'sysvinit'
Service {
name => $mon_service,
provider => $::ceph::params::service_provider,
start => "service ceph start mon.${id}",
stop => "service ceph stop mon.${id}",
status => "service ceph status mon.${id}",
} }
} }

View File

@ -63,7 +63,7 @@ class ceph::params (
$user_radosgw = 'apache' $user_radosgw = 'apache'
$pkg_fastcgi = 'mod_fastcgi' $pkg_fastcgi = 'mod_fastcgi'
$pkg_nsstools = 'nss-tools' $pkg_nsstools = 'nss-tools'
$service_provider = 'redhat' $service_provider = 'systemd'
$pkg_policycoreutils = 'policycoreutils-python' $pkg_policycoreutils = 'policycoreutils-python'
} }

View File

@ -155,13 +155,17 @@ define ceph::rgw (
selinux_ignore_defaults => true, selinux_ignore_defaults => true,
} }
# NOTE(aschultz): this is the radowsgw service title, it may be different
# than the actual service name
$rgw_service = "radosgw-${name}"
# service definition # service definition
# if Ubuntu does not use systemd # if Ubuntu does not use systemd
if $::service_provider == 'upstart' { if $::service_provider == 'upstart' {
if $rgw_enable { if $rgw_enable {
file { "${rgw_data}/done": file { "${rgw_data}/done":
ensure => present, ensure => present,
before => Service["radosgw-${name}"], before => Service[$rgw_service],
} }
} }
@ -173,41 +177,24 @@ define ceph::rgw (
provider => $::ceph::params::service_provider, provider => $::ceph::params::service_provider,
} }
# Everything else that is supported by puppet-ceph should run systemd. # Everything else that is supported by puppet-ceph should run systemd.
} elsif $::service_provider == 'systemd' {
Service {
name => "radosgw-${name}",
start => "systemctl start ceph-radosgw@${name}",
stop => "systemctl stop ceph-radosgw@${name}",
status => "systemctl status ceph-radosgw@${name}",
provider => $::ceph::params::service_provider,
}
} else { } else {
if $rgw_enable {
file { "${rgw_data}/sysvinit":
ensure => present,
before => Service["radosgw-${name}"],
}
}
Service { Service {
name => "radosgw-${name}", name => "ceph-radosgw@${name}",
start => 'service radosgw start', enable => $rgw_enable,
stop => 'service radosgw stop',
status => 'service radosgw status',
provider => $::ceph::params::service_provider,
} }
} }
service { "radosgw-${name}": service { $rgw_service:
ensure => $rgw_ensure, ensure => $rgw_ensure,
tag => ['ceph-radowsgw']
} }
Ceph_config<||> -> Service["radosgw-${name}"] Ceph_config<||> -> Service<| tag == 'ceph-radosgw' |>
Package<| tag == 'ceph' |> -> File['/var/lib/ceph/radosgw'] Package<| tag == 'ceph' |> -> File['/var/lib/ceph/radosgw']
Package<| tag == 'ceph' |> -> File[$log_file] Package<| tag == 'ceph' |> -> File[$log_file]
File['/var/lib/ceph/radosgw'] File['/var/lib/ceph/radosgw']
-> File[$rgw_data] -> File[$rgw_data]
-> Service["radosgw-${name}"] -> Service<| tag == 'ceph-radosgw' |>
File[$log_file] -> Service["radosgw-${name}"] File[$log_file] -> Service<| tag == 'ceph-radosgw' |>
Ceph::Pool<||> -> Service["radosgw-${name}"] Ceph::Pool<||> -> Service<| tag == 'ceph-radosgw' |>
} }

View File

@ -176,7 +176,7 @@ certutil -d ${nss_db_path} -L | grep ^signing_cert
-> File[$nss_db_path] -> File[$nss_db_path]
-> Exec["${name}-nssdb-ca"] -> Exec["${name}-nssdb-ca"]
-> Exec["${name}-nssdb-signing"] -> Exec["${name}-nssdb-signing"]
~> Service["radosgw-${name}"] ~> Service<| tag == 'ceph-radosgw' |>
} else { } else {
ceph_config { ceph_config {
"client.${name}/nss_db_path": ensure => absent; "client.${name}/nss_db_path": ensure => absent;

View File

@ -0,0 +1,10 @@
---
features:
- use mon_enable and rgw_enable to manage services on
boot.
other:
- removal of support for sysv service management for
ceph-mon and ceph-radosgw since master currently only supports
jewel and the current recommended ceph platforms are either systemd
or upstart based.
http://docs.ceph.com/docs/jewel/start/os-recommendations/#platforms

View File

@ -260,8 +260,6 @@ describe 'ceph::rgw' do
'selinux_ignore_defaults' => true, 'selinux_ignore_defaults' => true,
})} })}
it { is_expected.to contain_file('/var/lib/ceph/radosgw/ceph-radosgw.gateway/sysvinit') }
it { is_expected.to contain_service('radosgw-radosgw.gateway') } it { is_expected.to contain_service('radosgw-radosgw.gateway') }
end end
@ -308,8 +306,6 @@ describe 'ceph::rgw' do
'selinux_ignore_defaults' => true, 'selinux_ignore_defaults' => true,
} ) } } ) }
it { is_expected.to_not contain_file('/var/lib/ceph/radosgw/ceph-radosgw.gateway/sysvinit') }
it { is_expected.to contain_service('radosgw-radosgw.custom').with('ensure' => 'stopped' ) } it { is_expected.to contain_service('radosgw-radosgw.custom').with('ensure' => 'stopped' ) }
end end