 e82583f39e
			
		
	
	e82583f39e
	
	
	
		
			
			It was added as a deprecated parameter a long ago. Change-Id: I29ef2981c69e24429014026a051fe8aff266efc7
		
			
				
	
	
		
			235 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Puppet
		
	
	
	
	
	
			
		
		
	
	
			235 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Puppet
		
	
	
	
	
	
| #   Copyright (C) 2013, 2014 iWeb Technologies Inc.
 | |
| #   Copyright (C) 2014 Nine Internet Solutions AG
 | |
| #
 | |
| #   Licensed under the Apache License, Version 2.0 (the "License");
 | |
| #   you may not use this file except in compliance with the License.
 | |
| #   You may obtain a copy of the License at
 | |
| #
 | |
| #       http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| #   Unless required by applicable law or agreed to in writing, software
 | |
| #   distributed under the License is distributed on an "AS IS" BASIS,
 | |
| #   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| #   See the License for the specific language governing permissions and
 | |
| #   limitations under the License.
 | |
| #
 | |
| # Author: David Moreau Simard <dmsimard@iweb.com>
 | |
| # Author: David Gurtner <aldavud@crimson.ch>
 | |
| #
 | |
| # == Class: ceph
 | |
| #
 | |
| # init takes care of installing/configuring the common dependencies across classes
 | |
| # it also takes care of the global configuration values
 | |
| #
 | |
| # === Parameters:
 | |
| #
 | |
| # [*fsid*] The cluster's fsid.
 | |
| #   Mandatory. Get one with `uuidgen -r`.
 | |
| #
 | |
| # [*ensure*] Installs ( present ) or removes ( absent ) ceph.
 | |
| #   Optional. Defaults to present.
 | |
| #
 | |
| # [*authentication_type*] Authentication type.
 | |
| #   Optional. none or 'cephx'. Defaults to 'cephx'.
 | |
| #
 | |
| # [*keyring*] The location of the keyring retrieved by default
 | |
| #   Optional. Defaults to /etc/ceph/keyring.
 | |
| #
 | |
| # [*osd_journal_size*] The size of the journal file/device.
 | |
| #   Optional. Integer. Default provided by Ceph.
 | |
| #
 | |
| # [*osd_max_object_name_len*] The length of the objects name
 | |
| #   Optional. Integer. Default to undef
 | |
| #
 | |
| # [*osd_max_object_namespace_len*] The length of the objects namespace name
 | |
| #   Optional. Integer. Default to undef
 | |
| #
 | |
| # [*osd_pool_default_pg_num*] The default number of PGs per pool.
 | |
| #   Optional. Integer. Default provided by Ceph.
 | |
| #
 | |
| # [*osd_pool_default_pgp_num*] The default flags for new pools.
 | |
| #   Optional. Integer. Default provided by Ceph.
 | |
| #
 | |
| # [*osd_pool_default_size*] Number of replicas for objects in the pool
 | |
| #   Optional. Integer. Default provided by Ceph.
 | |
| #
 | |
| # [*osd_pool_default_min_size*] The default minimum num of replicas.
 | |
| #   Optional. Integer. Default provided by Ceph.
 | |
| #
 | |
| # [*osd_pool_default_crush_rule*] The default CRUSH ruleset to use
 | |
| #   when creating a pool.
 | |
| #   Optional. Integer. Default provided by Ceph.
 | |
| #
 | |
| # [*osd_crush_update_on_start*] The default OSDs behaviour on start when
 | |
| #   it comes to registering their location in the CRUSH map.
 | |
| #   Optional. Boolean. Defaults to undef.
 | |
| #
 | |
| # [*mon_osd_full_ratio*] Percentage of disk space used before
 | |
| #   an OSD considered full
 | |
| #   Optional. Integer e.g. 95, NOTE: ends in config as .95
 | |
| #   Default provided by Ceph.
 | |
| #
 | |
| # [*mon_osd_nearfull_ratio*] Percentage of disk space used before
 | |
| #   an OSD considered nearfull
 | |
| #   Optional. Float e.g. 90, NOTE: ends in config as .90
 | |
| #   Default provided by Ceph.
 | |
| #
 | |
| # [*mon_initial_members*] The IDs of initial MONs in the cluster during startup.
 | |
| #   Optional. String like e.g. 'a, b, c'.
 | |
| #
 | |
| # [*mon_host*] The fqdn of MONs in the cluster. They can also be declared
 | |
| #   individually through ceph::mon.
 | |
| #   Optional. String like e.g. 'a, b, c'.
 | |
| #
 | |
| # [*ms_bind_ipv4*] Enables Ceph daemons to bind to IPv4 addresses.
 | |
| #   Optional. Boolean. Default provided by Ceph.
 | |
| #
 | |
| # [*ms_bind_ipv6*] Enables Ceph daemons to bind to IPv6 addresses.
 | |
| #   Optional. Boolean. Default provided by Ceph.
 | |
| #
 | |
| # [*require_signatures*] If Ceph requires signatures on all
 | |
| #   message traffic (client<->cluster and between cluster daemons).
 | |
| #   Optional. Boolean. Default provided by Ceph.
 | |
| #
 | |
| # [*cluster_require_signatures*] If Ceph requires signatures on all
 | |
| #   message traffic between the cluster daemons.
 | |
| #   Optional. Boolean. Default provided by Ceph.
 | |
| #
 | |
| # [*service_require_signatures*] If Ceph requires signatures on all
 | |
| #   message traffic between clients and the cluster.
 | |
| #   Optional. Boolean. Default provided by Ceph.
 | |
| #
 | |
| # [*sign_messages*] If all ceph messages should be signed.
 | |
| #   Optional. Boolean. Default provided by Ceph.
 | |
| #
 | |
| # [*cluster_network*] The address of the cluster network.
 | |
| #   Optional. {cluster-network-ip/netmask}
 | |
| #
 | |
| # [*public_network*] The address of the public network.
 | |
| #   Optional. {public-network-ip/netmask}
 | |
| #
 | |
| # [*public_addr*] The address of the node (on public network.)
 | |
| #   Optional. {public-network-ip}
 | |
| #
 | |
| # [*osd_max_backfills*] The maximum number of backfills allowed to or from a single OSD.
 | |
| #   Optional. Default provided by Ceph
 | |
| #
 | |
| # [*osd_recovery_max_active*] The number of active recovery requests per OSD at one time.
 | |
| #   Optional.  Default provided by Ceph
 | |
| #
 | |
| # [*osd_recovery_op_priority*] The priority set for recovery operations.
 | |
| #   Optional.  Default provided by Ceph
 | |
| #
 | |
| # [*osd_recovery_max_single_start*] The maximum number of recovery operations that will be
 | |
| #   newly started per PG that the OSD is recovering.
 | |
| #   Optional.  Default provided by Ceph
 | |
| #
 | |
| # [*osd_max_scrubs*] The maximum number of simultaneous scrub operations for a Ceph OSD Daemon.
 | |
| #   Optional.  Default provided by Ceph
 | |
| #
 | |
| # [*osd_op_threads*] The number of threads to service Ceph OSD Daemon operations.
 | |
| #   Set to 0 to disable it.
 | |
| #   Optional. Default provided by Ceph
 | |
| #
 | |
| # [*rbd_default_features*] Set RBD features configuration.
 | |
| #   Optional. String. Defaults to undef.
 | |
| #
 | |
| class ceph (
 | |
|   $fsid,
 | |
|   $ensure                                    = present,
 | |
|   Enum['cephx', 'none'] $authentication_type = 'cephx',
 | |
|   $keyring                                   = undef,
 | |
|   $osd_journal_size                          = undef,
 | |
|   $osd_max_object_name_len                   = undef,
 | |
|   $osd_max_object_namespace_len              = undef,
 | |
|   $osd_pool_default_pg_num                   = undef,
 | |
|   $osd_pool_default_pgp_num                  = undef,
 | |
|   $osd_pool_default_size                     = undef,
 | |
|   $osd_pool_default_min_size                 = undef,
 | |
|   $osd_pool_default_crush_rule               = undef,
 | |
|   $osd_crush_update_on_start                 = undef,
 | |
|   $mon_osd_full_ratio                        = undef,
 | |
|   $mon_osd_nearfull_ratio                    = undef,
 | |
|   $mon_initial_members                       = undef,
 | |
|   $mon_host                                  = undef,
 | |
|   $ms_bind_ipv4                              = undef,
 | |
|   $ms_bind_ipv6                              = undef,
 | |
|   $require_signatures                        = undef,
 | |
|   $cluster_require_signatures                = undef,
 | |
|   $service_require_signatures                = undef,
 | |
|   $sign_messages                             = undef,
 | |
|   $cluster_network                           = undef,
 | |
|   $public_network                            = undef,
 | |
|   $public_addr                               = undef,
 | |
|   $osd_max_backfills                         = undef,
 | |
|   $osd_recovery_max_active                   = undef,
 | |
|   $osd_recovery_op_priority                  = undef,
 | |
|   $osd_recovery_max_single_start             = undef,
 | |
|   $osd_max_scrubs                            = undef,
 | |
|   $osd_op_threads                            = undef,
 | |
|   $rbd_default_features                      = undef,
 | |
| ) {
 | |
| 
 | |
|   include ceph::params
 | |
| 
 | |
|   package { $ceph::params::packages :
 | |
|     ensure => $ensure,
 | |
|     tag    => 'ceph'
 | |
|   }
 | |
| 
 | |
|   if $ensure !~ /(absent|purged)/ {
 | |
|     # Make sure ceph is installed before managing the configuration
 | |
|     Package<| tag == 'ceph' |> -> Ceph_config<| |>
 | |
|     # [global]
 | |
|     ceph_config {
 | |
|       'global/fsid':                         value => $fsid;
 | |
|       'global/keyring':                      value => $keyring;
 | |
|       'global/osd_max_object_name_len':      value => $osd_max_object_name_len;
 | |
|       'global/osd_max_object_namespace_len': value => $osd_max_object_namespace_len;
 | |
|       'global/osd_pool_default_pg_num':      value => $osd_pool_default_pg_num;
 | |
|       'global/osd_pool_default_pgp_num':     value => $osd_pool_default_pgp_num;
 | |
|       'global/osd_pool_default_size':        value => $osd_pool_default_size;
 | |
|       'global/osd_pool_default_min_size':    value => $osd_pool_default_min_size;
 | |
|       'global/osd_pool_default_crush_rule':  value => $osd_pool_default_crush_rule;
 | |
|       'global/osd_crush_update_on_start':    value => $osd_crush_update_on_start;
 | |
|       'global/mon_osd_full_ratio':           value => $mon_osd_full_ratio;
 | |
|       'global/mon_osd_nearfull_ratio':       value => $mon_osd_nearfull_ratio;
 | |
|       'global/mon_initial_members':          value => $mon_initial_members;
 | |
|       'global/mon_host':                     value => $mon_host;
 | |
|       'global/ms_bind_ipv4':                 value => $ms_bind_ipv4;
 | |
|       'global/ms_bind_ipv6':                 value => $ms_bind_ipv6;
 | |
|       'global/require_signatures':           value => $require_signatures;
 | |
|       'global/cluster_require_signatures':   value => $cluster_require_signatures;
 | |
|       'global/service_require_signatures':   value => $service_require_signatures;
 | |
|       'global/sign_messages':                value => $sign_messages;
 | |
|       'global/cluster_network':              value => $cluster_network;
 | |
|       'global/public_network':               value => $public_network;
 | |
|       'global/public_addr':                  value => $public_addr;
 | |
|       'osd/osd_journal_size':                value => $osd_journal_size;
 | |
|       'osd/osd_max_backfills':               value => $osd_max_backfills;
 | |
|       'osd/osd_recovery_max_active':         value => $osd_recovery_max_active;
 | |
|       'osd/osd_recovery_op_priority':        value => $osd_recovery_op_priority;
 | |
|       'osd/osd_recovery_max_single_start':   value => $osd_recovery_max_single_start;
 | |
|       'osd/osd_max_scrubs':                  value => $osd_max_scrubs;
 | |
|       'osd/osd_op_threads':                  value => $osd_op_threads;
 | |
|       'client/rbd_default_features':         value => $rbd_default_features;
 | |
|     }
 | |
| 
 | |
|     if $authentication_type == 'cephx' {
 | |
|       ceph_config {
 | |
|         'global/auth_cluster_required': value => 'cephx';
 | |
|         'global/auth_service_required': value => 'cephx';
 | |
|         'global/auth_client_required':  value => 'cephx';
 | |
|         'global/auth_supported':        value => 'cephx';
 | |
|       }
 | |
|     } else {
 | |
|       ceph_config {
 | |
|         'global/auth_cluster_required': value => 'none';
 | |
|         'global/auth_service_required': value => 'none';
 | |
|         'global/auth_client_required':  value => 'none';
 | |
|         'global/auth_supported':        value => 'none';
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 |