From 03870476d7481e7b198522f21faa9c9d0abcd1a0 Mon Sep 17 00:00:00 2001 From: congyi wang <58715567+wcy-fdu@users.noreply.github.com> Date: Wed, 15 Nov 2023 15:13:16 +0800 Subject: [PATCH] fix(object store): make lifecycle expiration rule more reasonable (#13436) --- src/object_store/src/object/s3.rs | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/src/object_store/src/object/s3.rs b/src/object_store/src/object/s3.rs index 899d1dc128ee2..3cca6cd2aef9c 100644 --- a/src/object_store/src/object/s3.rs +++ b/src/object_store/src/object/s3.rs @@ -723,14 +723,15 @@ impl S3ObjectStore { if let Ok(config) = &get_config_result { for rule in config.rules() { - // When both of the conditions are met, it is considered that there is a risk of data deletion. - // - // 1. expiration status rule is enabled - // 2. (a) prefix filter is not set - // or (b) prefix filter is set to the data directory of RisingWave. - // - // P.S. 1 && (2a || 2b) - is_expiration_configured |= rule.status == ExpirationStatus::Enabled // 1 + if rule.expiration().is_some() { + // When both of the conditions are met, it is considered that there is a risk of data deletion. + // + // 1. expiration status rule is enabled + // 2. (a) prefix filter is not set + // or (b) prefix filter is set to the data directory of RisingWave. + // + // P.S. 1 && (2a || 2b) + is_expiration_configured |= rule.status == ExpirationStatus::Enabled // 1 && match rule.filter().as_ref() { // 2a None => true, @@ -743,10 +744,11 @@ impl S3ObjectStore { _ => false, }; - if matches!(rule.status(), ExpirationStatus::Enabled) - && rule.abort_incomplete_multipart_upload().is_some() - { - configured_rules.push(rule); + if matches!(rule.status(), ExpirationStatus::Enabled) + && rule.abort_incomplete_multipart_upload().is_some() + { + configured_rules.push(rule); + } } } }