POOL_ID=$(ceph osd pool ls detail | grep $POOL | awk '{print$2}')
$DEDUP_TOOL --op get-chunk-ref --chunk-pool $CHUNK_POOL --object $CHUNK_OID --target-ref bar --target-ref-pool-id $POOL_ID
- RESULT=$($DEDUP_TOOL --op get-chunk-ref --chunk-pool $CHUNK_POOL --object $CHUNK_OID)
+ RESULT=$($DEDUP_TOOL --op dump-chunk-refs --chunk-pool $CHUNK_POOL --object $CHUNK_OID)
$DEDUP_TOOL --op chunk-scrub --chunk-pool $CHUNK_POOL
- RESULT=$($DEDUP_TOOL --op get-chunk-ref --chunk-pool $CHUNK_POOL --object $CHUNK_OID | grep bar)
+ RESULT=$($DEDUP_TOOL --op dump-chunk-refs --chunk-pool $CHUNK_POOL --object $CHUNK_OID | grep bar)
if [ -n "$RESULT" ] ; then
$CEPH_TOOL osd pool delete $POOL $POOL --yes-i-really-really-mean-it
$CEPH_TOOL osd pool delete $CHUNK_POOL $CHUNK_POOL --yes-i-really-really-mean-it
#include "tools/RadosDump.h"
#include "cls/cas/cls_cas_client.h"
+#include "cls/cas/cls_cas_internal.h"
#include "include/stringify.h"
#include "global/signal_handler.h"
#include "common/CDC.h"
void usage()
{
- cout << " usage: [--op <estimate|chunk_scrub|add_chunk_ref|get_chunk_ref>] [--pool <pool_name> ] " << std::endl;
+ cout << " usage: [--op <estimate|chunk-scrub|chunk-get-ref|chunk-put-ref|dump-chunk-refs>] [--pool <pool_name> ] " << std::endl;
cout << " --object <object_name> " << std::endl;
cout << " --chunk-size <size> chunk-size (byte) " << std::endl;
cout << " --chunk-algorithm <fixed|fastcdc> " << std::endl;
if (i != opts.end()) {
chunk_pool_name = i->second.c_str();
} else {
- cerr << "must specify pool" << std::endl;
+ cerr << "must specify --chunk-pool" << std::endl;
exit(1);
}
i = opts.find("max-thread");
return ret;
- } else if (op_name == "get-chunk-ref") {
+ } else if (op_name == "dump-chunk-refs") {
i = opts.find("object");
if (i != opts.end()) {
object_name = i->second.c_str();
cerr << "must specify object" << std::endl;
exit(1);
}
- set<hobject_t> refs;
- cout << " refs: " << std::endl;
- ret = cls_cas_chunk_read_refs(chunk_io_ctx, object_name, &refs);
- for (auto p : refs) {
- cout << " " << p.oid.name << " ";
+ bufferlist t;
+ ret = chunk_io_ctx.getxattr(object_name, CHUNK_REFCOUNT_ATTR, t);
+ if (ret < 0) {
+ return ret;
}
- cout << std::endl;
- return ret;
+ chunk_obj_refcount refs;
+ auto p = t.cbegin();
+ decode(refs, p);
+ auto f = Formatter::create("json-pretty");
+ f->dump_object("refs", refs);
+ f->flush(cout);
+ return 0;
}
-
+
glock.lock();
begin = chunk_io_ctx.object_list_begin();
end = chunk_io_ctx.object_list_end();
} else if (op_name == "chunk-get-ref" ||
op_name == "chunk-put-ref") {
return chunk_scrub_common(opts, args);
- } else if (op_name == "get-chunk-ref") {
+ } else if (op_name == "dump-chunk-refs") {
return chunk_scrub_common(opts, args);
} else {
- usage();
- exit(0);
+ cerr << "unrecognized op " << op_name << std::endl;
+ exit(1);
}
unregister_async_signal_handler(SIGINT, handle_signal);