diff options
author | Yehuda Sadeh <yehuda@inktank.com> | 2013-04-22 12:48:56 -0700 |
---|---|---|
committer | Yehuda Sadeh <yehuda@inktank.com> | 2013-04-22 13:44:19 -0700 |
commit | de5d1da810732ee48f41e8be18257053d862301b (patch) | |
tree | 25884faae19f1785976f52d79c54d75dc99fd81c | |
parent | cec5282b2a6e25401b728f8997a1ad435c540d46 (diff) | |
download | ceph-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.cc | 5 | ||||
-rw-r--r-- | src/rgw/rgw_rados.h | 3 |
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); |