diff options
author | Yehuda Sadeh <yehuda@inktank.com> | 2013-02-21 17:46:24 -0800 |
---|---|---|
committer | Yehuda Sadeh <yehuda@inktank.com> | 2013-02-21 17:46:24 -0800 |
commit | 7d8a3b59a030ffb7572749f0039bcc906770b71b (patch) | |
tree | f13edbba1a1a25b2d791c576587dc7b62b676fd8 | |
parent | 1d947c1295e4c787c7ba6bb01b9c1a60df893bf0 (diff) | |
download | ceph-7d8a3b59a030ffb7572749f0039bcc906770b71b.tar.gz |
rgw: get/set region map
Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
-rw-r--r-- | src/rgw/rgw_admin.cc | 41 | ||||
-rw-r--r-- | src/rgw/rgw_rados.cc | 49 | ||||
-rw-r--r-- | src/rgw/rgw_rados.h | 4 |
3 files changed, 94 insertions, 0 deletions
diff --git a/src/rgw/rgw_admin.cc b/src/rgw/rgw_admin.cc index 791565443c3..8f8ded41fdb 100644 --- a/src/rgw/rgw_admin.cc +++ b/src/rgw/rgw_admin.cc @@ -62,6 +62,8 @@ void _usage() cerr << " regions list list all regions set on this cluster\n"; cerr << " region set set region info\n"; cerr << " region default set default region\n"; + cerr << " region-map show show region-map\n"; + cerr << " region-map set set region-map\n"; cerr << " zone info show zone cluster params\n"; cerr << " zone set set zone cluster params\n"; cerr << " zone list list all zones set on this cluster\n"; @@ -170,6 +172,8 @@ enum { OPT_REGION_LIST, OPT_REGION_SET, OPT_REGION_DEFAULT, + OPT_REGIONMAP_SHOW, + OPT_REGIONMAP_SET, OPT_ZONE_INFO, OPT_ZONE_SET, OPT_ZONE_LIST, @@ -207,6 +211,8 @@ static int get_cmd(const char *cmd, const char *prev_cmd, bool *need_more) strcmp(cmd, "object") == 0 || strcmp(cmd, "region") == 0 || strcmp(cmd, "regions") == 0 || + strcmp(cmd, "region-map") == 0 || + strcmp(cmd, "regionmap") == 0 || strcmp(cmd, "zone") == 0 || strcmp(cmd, "temp") == 0 || strcmp(cmd, "caps") == 0 || @@ -307,6 +313,12 @@ static int get_cmd(const char *cmd, const char *prev_cmd, bool *need_more) } else if (strcmp(prev_cmd, "regions") == 0) { if (strcmp(cmd, "list") == 0) return OPT_REGION_LIST; + } else if (strcmp(prev_cmd, "region-map") == 0 || + strcmp(prev_cmd, "regionmap") == 0) { + if (strcmp(cmd, "show") == 0) + return OPT_REGIONMAP_SHOW; + if (strcmp(cmd, "set") == 0) + return OPT_REGIONMAP_SET; } else if (strcmp(prev_cmd, "zone") == 0) { if (strcmp(cmd, "info") == 0) return OPT_ZONE_INFO; @@ -878,6 +890,7 @@ int main(int argc, char **argv) bool raw_storage_op = (opt_cmd == OPT_REGION_INFO || opt_cmd == OPT_REGION_LIST || opt_cmd == OPT_REGION_SET || opt_cmd == OPT_REGION_DEFAULT || + opt_cmd == OPT_REGIONMAP_SHOW || opt_cmd == OPT_REGIONMAP_SET || opt_cmd == OPT_ZONE_INFO || opt_cmd == OPT_ZONE_SET || opt_cmd == OPT_ZONE_LIST); @@ -974,6 +987,34 @@ int main(int argc, char **argv) } } + if (opt_cmd == OPT_REGIONMAP_SHOW) { + RGWRegionMap regionmap; + int ret = regionmap.read(g_ceph_context, store); + if (ret < 0) { + cerr << "failed to read region map: " << cpp_strerror(-ret) << std::endl; + return -ret; + } + encode_json("region-map", regionmap, formatter); + formatter->flush(cout); + } + + if (opt_cmd == OPT_REGIONMAP_SET) { + RGWRegionMap regionmap; + int ret = read_decode_json(infile, regionmap); + if (ret < 0) { + return 1; + } + + ret = regionmap.store(g_ceph_context, store); + if (ret < 0) { + cerr << "ERROR: couldn't store region map info: " << cpp_strerror(-ret) << std::endl; + return 1; + } + + encode_json("region-map", regionmap, formatter); + formatter->flush(cout); + } + if (opt_cmd == OPT_ZONE_INFO) { RGWRegion region; int ret = region.init(g_ceph_context, store); diff --git a/src/rgw/rgw_rados.cc b/src/rgw/rgw_rados.cc index e3b156d9fa8..e4ab58879ad 100644 --- a/src/rgw/rgw_rados.cc +++ b/src/rgw/rgw_rados.cc @@ -51,6 +51,7 @@ static string zone_info_oid_prefix = "zone_info."; static string region_info_oid_prefix = "region_info."; static string default_region_info_oid = "default.region"; +static string region_map_oid = "region_map"; static RGWObjCategory shadow_category = RGW_OBJ_CATEGORY_SHADOW; @@ -304,6 +305,54 @@ int RGWZoneParams::store_info(CephContext *cct, RGWRados *store, RGWRegion& regi return ret; } +void RGWRegionMap::get_params(CephContext *cct, string& pool_name, string& oid) +{ + pool_name = cct->_conf->rgw_zone_root_pool; + if (pool_name.empty()) { + pool_name = RGW_DEFAULT_ZONE_ROOT_POOL; + } + oid = region_map_oid; +} + +int RGWRegionMap::read(CephContext *cct, RGWRados *store) +{ + string pool_name, oid; + + get_params(cct, pool_name, oid); + + rgw_bucket pool(pool_name.c_str()); + + bufferlist bl; + int ret = rgw_get_obj(store, NULL, pool, oid, bl); + if (ret < 0) + return ret; + + try { + bufferlist::iterator iter = bl.begin(); + ::decode(*this, iter); + } catch (buffer::error& err) { + ldout(cct, 0) << "ERROR: failed to decode region map info from " << pool << ":" << oid << dendl; + return -EIO; + } + + return 0; +} + +int RGWRegionMap::store(CephContext *cct, RGWRados *store) +{ + string pool_name, oid; + + get_params(cct, pool_name, oid); + + rgw_bucket pool(pool_name.c_str()); + + bufferlist bl; + ::encode(*this, bl); + int ret = rgw_put_system_obj(store, pool, oid, bl.c_str(), bl.length(), false, NULL); + + return ret; +} + void RGWObjManifest::append(RGWObjManifest& m) { map<uint64_t, RGWObjManifestPart>::iterator iter; diff --git a/src/rgw/rgw_rados.h b/src/rgw/rgw_rados.h index e36907c2145..5076089db07 100644 --- a/src/rgw/rgw_rados.h +++ b/src/rgw/rgw_rados.h @@ -395,6 +395,10 @@ struct RGWRegionMap { DECODE_FINISH(bl); } + void get_params(CephContext *cct, string& pool_name, string& oid); + int read(CephContext *cct, RGWRados *store); + int store(CephContext *cct, RGWRados *store); + void dump(Formatter *f) const; void decode_json(JSONObj *obj); }; |