summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYehuda Sadeh <yehuda@inktank.com>2013-04-22 12:48:56 -0700
committerYehuda Sadeh <yehuda@inktank.com>2013-04-22 13:44:19 -0700
commitde5d1da810732ee48f41e8be18257053d862301b (patch)
tree25884faae19f1785976f52d79c54d75dc99fd81c
parentcec5282b2a6e25401b728f8997a1ad435c540d46 (diff)
downloadceph-de5d1da810732ee48f41e8be18257053d862301b.tar.gz
rgw: don't send tail to gc if copying object to itself
Fixes: #4776 Backport: bobtail Need to make sure that when copying an object into itself we don't send the tail to the garbage collection. Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
-rw-r--r--src/rgw/rgw_rados.cc5
-rw-r--r--src/rgw/rgw_rados.h3
2 files changed, 6 insertions, 2 deletions
diff --git a/src/rgw/rgw_rados.cc b/src/rgw/rgw_rados.cc
index e47e2e90e8e..ac7de637cb6 100644
--- a/src/rgw/rgw_rados.cc
+++ b/src/rgw/rgw_rados.cc
@@ -1396,6 +1396,9 @@ int RGWRados::copy_obj(void *ctx,
} else {
pmanifest = &astate->manifest;
tag = astate->obj_tag.c_str();
+
+ /* don't send the object's tail for garbage collection */
+ astate->keep_tail = true;
}
if (copy_first) {
@@ -1640,7 +1643,7 @@ int RGWRados::bucket_suspended(rgw_bucket& bucket, bool *suspended)
int RGWRados::complete_atomic_overwrite(RGWRadosCtx *rctx, RGWObjState *state, rgw_obj& obj)
{
- if (!state || !state->has_manifest)
+ if (!state || !state->has_manifest || state->keep_tail)
return 0;
cls_rgw_obj_chain chain;
diff --git a/src/rgw/rgw_rados.h b/src/rgw/rgw_rados.h
index bed481573bb..84a8d67b8ea 100644
--- a/src/rgw/rgw_rados.h
+++ b/src/rgw/rgw_rados.h
@@ -180,11 +180,12 @@ struct RGWObjState {
bool has_data;
bufferlist data;
bool prefetch_data;
+ bool keep_tail;
map<string, bufferlist> attrset;
RGWObjState() : is_atomic(false), has_attrs(0), exists(false),
size(0), mtime(0), epoch(0), fake_tag(false), has_manifest(false),
- has_data(false), prefetch_data(false) {}
+ has_data(false), prefetch_data(false), keep_tail(false) {}
bool get_attr(string name, bufferlist& dest) {
map<string, bufferlist>::iterator iter = attrset.find(name);