本篇文章给大家分享的是有关如何进行ceph object map的实现,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
object map 里引入了ceph::BitVector<2> m_object_map;
是一个位图实现,根据object_no 来记录每个object的存在状态。 m_object_map[object_no] != new_state)
每个image对应有一个object_map:
namespace librbd {
class AsyncOperation;
class AsyncRequest;
class AsyncResizeRequest;
class CopyupRequest;
class ImageWatcher;
struct ImageCtx {
CephContext *cct;
...
ObjectMap object_map; // ===== > 最原始的pull 是: ceph::BitVector<2> object_map;
这儿检查object是不是存在:
if (!m_ictx->object_map.object_may_exist(m_object_no))
做copy_up的时候,会将相应的object置上OBJECT_EXISTS:
bool sent = m_ictx->object_map.aio_update(m_object_no, OBJECT_EXISTS,
boost::optional<uint8_t>(),
ctx);
---------------------
创建一个支持object map的镜像:
./rbd create --image-feature exclusive-lock --image-feature object-map --image-feature layering -p rbd user1_image_om --size 1024 --image-format 2
有一个专门的object 来存object map :
rbd_object_map.4a3ec5a23fb32
rbd_header.4a3ec5a23fb32
rbd_id.user1_image_om
/* New-style rbd image 'foo' consists of objects
* rbd_id.foo - id of image
* rbd_header.<id> - image metadata
* rbd_object_map.<id> - optional image object map
* rbd_data.<id>.00000000
* rbd_data.<id>.00000001
* ... - data
*/
#define RBD_HEADER_PREFIX "rbd_header."
#define RBD_OBJECT_MAP_PREFIX "rbd_object_map."
#define RBD_DATA_PREFIX "rbd_data."
#define RBD_ID_PREFIX "rbd_id."
hammer上创建支持object map的正确姿势:
[guzhongyan@ceph32 ~]$ rbd create --size 50000 --image-format 2 --image-features +12 test_image_om
[guzhongyan@ceph32 ~]$ rbd info test_image_om
rbd image 'test_image_om':
size 50000 MB in 12500 objects
order 22 (4096 kB objects)
block_name_prefix: rbd_data.6ac6606b8b4567
format: 2
features: exclusive, object map
flags:
以上就是如何进行ceph object map的实现,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注天达云行业资讯频道。