summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYehuda Sadeh <yehuda@inktank.com>2013-05-22 21:34:52 -0700
committerYehuda Sadeh <yehuda@inktank.com>2013-05-23 13:13:01 -0700
commita460e53ecac03e9c8f54c402a790e6d8cf75b38c (patch)
tree60b6fb4eb57c8d04a7f7e2c8b1e61bcc0a2c84aa
parent48e1b11bcbdbdf8661cb560c8563f91738034287 (diff)
downloadceph-a460e53ecac03e9c8f54c402a790e6d8cf75b38c.tar.gz
rgw: iterate usage entries from correct entry
Fixes: #5152 When iterating through usage entries, and when user id was provided, we started at the user's first entry and not from the entry indexed by the request start time. This commit fixes the issue. Backport: bobtail Signed-off-by: Yehuda Sadeh <yehuda@inktank.com> Reviewed-by: Greg Farnum <greg@inktank.com> (cherry picked from commit 8b3a04dec8be13559716667d4b16cde9e9543feb)
-rw-r--r--src/cls/rgw/cls_rgw.cc19
1 files changed, 16 insertions, 3 deletions
diff --git a/src/cls/rgw/cls_rgw.cc b/src/cls/rgw/cls_rgw.cc
index 15498ef0aa6..cf81440f7fb 100644
--- a/src/cls/rgw/cls_rgw.cc
+++ b/src/cls/rgw/cls_rgw.cc
@@ -586,6 +586,13 @@ static void usage_record_prefix_by_time(uint64_t epoch, string& key)
key = buf;
}
+static void usage_record_prefix_by_user(string& user, uint64_t epoch, string& key)
+{
+ char buf[user.size() + 32];
+ snprintf(buf, sizeof(buf), "%s_%011llu_", user.c_str(), (long long unsigned)epoch);
+ key = buf;
+}
+
static void usage_record_name_by_time(uint64_t epoch, string& user, string& bucket, string& key)
{
char buf[32 + user.size() + bucket.size()];
@@ -695,7 +702,7 @@ static int usage_iterate_range(cls_method_context_t hctx, uint64_t start, uint64
if (key_iter.empty()) {
if (by_user) {
- start_key = user;
+ usage_record_prefix_by_user(user, start, start_key);
} else {
usage_record_prefix_by_time(start, start_key);
}
@@ -704,6 +711,7 @@ static int usage_iterate_range(cls_method_context_t hctx, uint64_t start, uint64
}
do {
+ CLS_LOG(20, "usage_iterate_range start_key=%s", start_key.c_str());
int ret = cls_cxx_map_get_vals(hctx, start_key, filter_prefix, NUM_KEYS, &keys);
if (ret < 0)
return ret;
@@ -717,11 +725,15 @@ static int usage_iterate_range(cls_method_context_t hctx, uint64_t start, uint64
const string& key = iter->first;
rgw_usage_log_entry e;
- if (!by_user && key.compare(end_key) >= 0)
+ if (!by_user && key.compare(end_key) >= 0) {
+ CLS_LOG(20, "usage_iterate_range reached key=%s, done", key.c_str());
return 0;
+ }
- if (by_user && key.compare(0, user_key.size(), user_key) != 0)
+ if (by_user && key.compare(0, user_key.size(), user_key) != 0) {
+ CLS_LOG(20, "usage_iterate_range reached key=%s, done", key.c_str());
return 0;
+ }
ret = usage_record_decode(iter->second, e);
if (ret < 0)
@@ -741,6 +753,7 @@ static int usage_iterate_range(cls_method_context_t hctx, uint64_t start, uint64
i++;
if (max_entries && (i > max_entries)) {
+ CLS_LOG(20, "usage_iterate_range reached max_entries (%d), done", max_entries);
*truncated = true;
key_iter = key;
return 0;