 5a7d18975f
			
		
	
	5a7d18975f
	
	
	
		
			
			The 'swiftinit' provider is a custom provider of the service type that manages swift services using swift-init. Use of the swiftinit service provider is optional, the default is to use service providers specified in params file. This provider also manages swift services starting at boot by adding or removing a templated init or services file and making systemctl calls. See README for more detail. A wrapper defined type 'swift::service' has been created to simplify use of the swiftinit provider without adding logic to every class. this wrapper also aids in input validation and testing of the swiftinit provider. Two extra runs of apply_manifest have been added to the basic_swift_spec acceptance test. The service_provider is set to "swiftinit". The first run catches any errors upgrading to the swiftinit service provider and the second run tests idempotency. This patch is an initial step towards using swift-init to manage multiple swift services out of different configuration files such as is needed to run a separate replication network. Change-Id: I2f71c82c7a6c463f8c76a193409c0a17daa15bda
		
			
				
	
	
		
			126 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Puppet
		
	
	
	
	
	
			
		
		
	
	
			126 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Puppet
		
	
	
	
	
	
| # Class swift::objectexpirer
 | |
| #
 | |
| # == Parameters
 | |
| #  [*enabled*]
 | |
| #    (optional) Should the service be enabled.
 | |
| #    Defaults to true
 | |
| #
 | |
| #  [*manage_service*]
 | |
| #    (optional) Whether the service should be managed by Puppet.
 | |
| #    Defaults to true.
 | |
| #
 | |
| #  [*package_ensure*]
 | |
| #    (optional) Value of package resource parameter 'ensure'.
 | |
| #    Defaults to 'present'.
 | |
| #
 | |
| #  [*pipeline*]
 | |
| #    (optional) The list of elements of the object expirer pipeline.
 | |
| #    Defaults to ['catch_errors', 'cache', 'proxy-server']
 | |
| #
 | |
| #  [*auto_create_account_prefix*]
 | |
| #    (optional) Prefix to use when automatically creating accounts.
 | |
| #    Defaults to '.'.
 | |
| #
 | |
| #  [*concurrency*]
 | |
| #    (optional) Number of replication workers to spawn.
 | |
| #    Defaults to 1.
 | |
| #
 | |
| #  [*expiring_objects_account_name*]
 | |
| #    (optional) Account name used for expiring objects.
 | |
| #    Defaults to 'expiring_objects'.
 | |
| #
 | |
| #  [*interval*]
 | |
| #    (optional) Minimum time for a pass to take, in seconds.
 | |
| #    Defaults to 300.
 | |
| #
 | |
| #  [*process*]
 | |
| #    (optional) Which part of the work defined by $processes
 | |
| #    will this instance take.
 | |
| #    Defaults to 0.
 | |
| #
 | |
| #  [*processes*]
 | |
| #    (optional) How many parts to divide the work into, one part per
 | |
| #    process. 0 means a single process will do all work.
 | |
| #    Defaults to 0.
 | |
| #
 | |
| #  [*reclaim_age*]
 | |
| #    (optional) Time elapsed in seconds before an object can be
 | |
| #    reclaimed.
 | |
| #    Defaults to 604800 (1 week).
 | |
| #
 | |
| #  [*recon_cache_path*]
 | |
| #    (optional) Directory where stats for a few items will be stored.
 | |
| #    Defaults to '/var/cache/swift'.
 | |
| #
 | |
| #  [*report_interval*]
 | |
| #    (optional) Report interval, in seconds.
 | |
| #    Defaults to 300.
 | |
| #
 | |
| #  [*service_provider*]
 | |
| #    (optional)
 | |
| #    To use the swiftinit service provider to manage swift services, set
 | |
| #    service_provider to "swiftinit".  When enable is true the provider
 | |
| #    will populate boot files that start swift using swift-init at boot.
 | |
| #    See README for more details.
 | |
| #    Defaults to $::swift::params::service_provider.
 | |
| #
 | |
| class swift::objectexpirer(
 | |
|   $manage_service                = true,
 | |
|   $enabled                       = true,
 | |
|   $package_ensure                = 'present',
 | |
|   $pipeline                      = ['catch_errors', 'cache', 'proxy-server'],
 | |
|   $auto_create_account_prefix    = '.',
 | |
|   $concurrency                   = 1,
 | |
|   $expiring_objects_account_name = 'expiring_objects',
 | |
|   $interval                      = 300,
 | |
|   $process                       = 0,
 | |
|   $processes                     = 0,
 | |
|   $reclaim_age                   = 604800,
 | |
|   $recon_cache_path              = '/var/cache/swift',
 | |
|   $report_interval               = 300,
 | |
|   $service_provider              = $::swift::params::service_provider
 | |
| ) inherits ::swift::params {
 | |
| 
 | |
|   Swift_config<| |> ~> Service['swift-object-expirer']
 | |
|   Swift_object_expirer_config<||> ~> Service['swift-object-expirer']
 | |
| 
 | |
|   # On Red Hat platforms, it may be defined already,
 | |
|   # because it is part of openstack-swift-proxy
 | |
|   if $::swift::params::object_expirer_package_name != $::swift::params::proxy_package_name {
 | |
|     package { 'swift-object-expirer':
 | |
|       ensure => $package_ensure,
 | |
|       name   => $::swift::params::object_expirer_package_name,
 | |
|       tag    => ['openstack', 'swift-package'],
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   swift_object_expirer_config {
 | |
|     'pipeline:main/pipeline':                       value => join($pipeline, ' ');
 | |
|     'object-expirer/auto_create_account_prefix':    value => $auto_create_account_prefix;
 | |
|     'object-expirer/concurrency':                   value => $concurrency;
 | |
|     'object-expirer/expiring_objects_account_name': value => $expiring_objects_account_name;
 | |
|     'object-expirer/interval':                      value => $interval;
 | |
|     'object-expirer/process':                       value => $process;
 | |
|     'object-expirer/processes':                     value => $processes;
 | |
|     'object-expirer/reclaim_age':                   value => $reclaim_age;
 | |
|     'object-expirer/recon_cache_path':              value => $recon_cache_path;
 | |
|     'object-expirer/report_interval':               value => $report_interval;
 | |
|   }
 | |
| 
 | |
|   if $manage_service {
 | |
|     if $enabled {
 | |
|       $service_ensure = 'running'
 | |
|     } else {
 | |
|       $service_ensure = 'stopped'
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   swift::service { 'swift-object-expirer':
 | |
|     os_family_service_name => $::swift::params::object_expirer_service_name,
 | |
|     service_ensure         => $service_ensure,
 | |
|     enabled                => $enabled,
 | |
|     config_file_name       => 'object-expirer.conf',
 | |
|     service_provider       => $service_provider,
 | |
|   }
 | |
| }
 |