From d29e1b249b118d55e59c675fd2ec226ade2afb40 Mon Sep 17 00:00:00 2001 From: Alan Bishop Date: Fri, 16 Apr 2021 12:22:19 -0700 Subject: [PATCH] Add CinderBackupCompressionAlgorithm parameter The CinderBackupCompressionAlgorithm supports specifying the compression algorithm for cinder backup drivers that support the feature (most of the drivers do, but the ceph backup driver doesn't). Change-Id: Icbdee2a30e2bc6fcf0dc7774e622e27b5cc15270 --- .../cinder/cinder-backup-container-puppet.yaml | 17 +++++++++++++++++ ...-compression-algorithm-337a6708264cb84a.yaml | 7 +++++++ 2 files changed, 24 insertions(+) create mode 100644 releasenotes/notes/cinder-backup-compression-algorithm-337a6708264cb84a.yaml diff --git a/deployment/cinder/cinder-backup-container-puppet.yaml b/deployment/cinder/cinder-backup-container-puppet.yaml index 76525eb01c..7b2da05d9b 100644 --- a/deployment/cinder/cinder-backup-container-puppet.yaml +++ b/deployment/cinder/cinder-backup-container-puppet.yaml @@ -65,6 +65,15 @@ parameters: default: 15 description: The maximum number of concurrent cinder backup/restore operations (0 means unlimited). + CinderBackupCompressionAlgorithm: + default: zlib + description: The compression algorithm used by Cinder Backup backends that + are based on Cinder's "chunked" backup driver. This includes + the swift, nfs, gcs and s3 backends. The ceph backend does not + support the feature. + type: string + constraints: + - allowed_values: ['none', 'zlib', 'bzip2', 'zstd'] CinderBackupRbdClusterName: type: string default: '' @@ -178,23 +187,31 @@ outputs: - if: - {equals: [{get_param: CinderBackupBackend}, 'swift']} - cinder::backup::swift::backup_swift_container: volumebackups + cinder::backup::swift::backup_compression_algorithm: {get_param: CinderBackupCompressionAlgorithm} cinder::backup::swift::swift_catalog_info: 'object-store:swift:internalURL' - if: - {equals: [{get_param: CinderBackupBackend}, 'nfs']} - cinder::backup::nfs::backup_share: {get_param: CinderBackupNfsShare} cinder::backup::nfs::backup_mount_options: {get_param: CinderBackupNfsMountOptions} + cinder::backup::nfs::backup_compression_algorithm: {get_param: CinderBackupCompressionAlgorithm} - if: - {equals: [{get_param: CinderBackupBackend}, 'gcs']} - tripleo::profile::base::cinder::backup::gcs::credentials: {get_param: CinderBackupGcsCredentials} cinder::backup::google::backup_gcs_project_id: {get_param: CinderBackupGcsProjectId} cinder::backup::google::backup_gcs_bucket: {get_param: CinderBackupGcsBucket} cinder::backup::google::backup_gcs_bucket_location: {get_param: CinderBackupGcsBucketLocation} + # cinder::backup::google does not support configuring the compression + # algorithm, so use cinder::config::cinder_config + cinder::config::cinder_config: + DEFAULT/backup_compression_algorithm: + value: {get_param: CinderBackupCompressionAlgorithm} - if: - {equals: [{get_param: CinderBackupBackend}, 's3']} - cinder::backup::s3::backup_s3_endpoint_url: {get_param: CinderBackupS3EndpointUrl} cinder::backup::s3::backup_s3_store_access_key: {get_param: CinderBackupS3AccessKey} cinder::backup::s3::backup_s3_store_secret_key: {get_param: CinderBackupS3SecretKey} cinder::backup::s3::backup_s3_store_bucket: {get_param: CinderBackupS3Bucket} + cinder::backup::s3::backup_compression_algorithm: {get_param: CinderBackupCompressionAlgorithm} service_config_settings: rsyslog: tripleo_logging_sources_cinder_backup: diff --git a/releasenotes/notes/cinder-backup-compression-algorithm-337a6708264cb84a.yaml b/releasenotes/notes/cinder-backup-compression-algorithm-337a6708264cb84a.yaml new file mode 100644 index 0000000000..921cf6d6a8 --- /dev/null +++ b/releasenotes/notes/cinder-backup-compression-algorithm-337a6708264cb84a.yaml @@ -0,0 +1,7 @@ +--- +features: + - | + A new ``CinderBackupCompressionAlgorithm`` parameter supports specifying + the compression algorithm used by Cinder Backup backends that support the + feature. The parameter defaults to ``zlib,`` which is Cinder's default + value.