博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
librbd
阅读量:4215 次
发布时间:2019-05-26

本文共 2114 字,大约阅读时间需要 7 分钟。

librbd是ceph 对外提供的块存储接口,这个接口了c/c++ 两种接口,接口提供的头文件分别在ceph-master\ceph-master\src\include\rbd\librbd.hpp和source\ceph-master\ceph-master\src\include\rbd\librbd.h中这里我们以提供的c++为例,namespace librbd {  using librados::IoCtx;class CEPH_RBD_API RBD{#创建,删除,clone镜像等操作  int create(IoCtx& io_ctx, const char *name, uint64_t size, int *order);  int clone(IoCtx& p_ioctx, const char *p_name, const char *p_snapname,	       IoCtx& c_ioctx, const char *c_name, uint64_t features,	       int *c_order);   // RBD pool mirroring support functions  int mirror_mode_get(IoCtx& io_ctx, rbd_mirror_mode_t *mirror_mode); };class CEPH_RBD_API Image{#主要是镜像的读写操作  int snap_list(std::vector
& snaps); /* DEPRECATED; use snap_exists2 */ bool snap_exists(const char *snapname) __attribute__ ((deprecated)); int snap_exists2(const char *snapname, bool *exists); int snap_create(const char *snapname); int snap_remove(const char *snapname); int snap_remove2(const char *snapname, uint32_t flags, ProgressContext& pctx);}从这里和容易看出librbd对外提供了一个namspace。这样我们使用using librbd就可以使用linrbd提供的函数其次在这个namespace 中使用了librados中的ioctx,从这里可以看出librbd是在librados之上的在libedb中只要提供了两个class,分别是rbd 和 image.这两个类的实现都在ceph-master\ceph-master\src\librbd\librbd.cc 中我们来看看rbd中的open函数 int RBD::open(IoCtx& io_ctx, Image& image, const char *name, const char *snap_name) { #新建一个ImageCtx ImageCtx *ictx = new ImageCtx(name, "", snap_name, io_ctx, false); TracepointProvider::initialize
(get_cct(io_ctx)); tracepoint(librbd, open_image_enter, ictx, ictx->name.c_str(), ictx->id.c_str(), ictx->snap_name.c_str(), ictx->read_only); #如果形参image.ctx不为null,说明上一次可能没有调用close函数,这里首先会调用close函数将其关闭 if (image.ctx != NULL) { reinterpret_cast
(image.ctx)->state->close(); image.ctx = NULL; } #走到这里的话image.ctx 已经为null了,这里通过新建的Imagectx来重新open int r = ictx->state->open(false); if (r < 0) { tracepoint(librbd, open_image_exit, r); return r; } #将新建且已经打开的ictx 赋值给image.ctx image.ctx = (image_ctx_t) ictx; tracepoint(librbd, open_image_exit, 0); return 0; } 从这里可以知道rbd class的open函数主要是给image类的ctx赋值,这个值是一个ImageCtx类型

转载地址:http://fjnmi.baihongyu.com/

你可能感兴趣的文章
java事务大总结(二) 理解JDBC事务的工作机制
查看>>
java事务大总结(三) 理解学习 JTA(Java Transaction API)
查看>>
java事务大总结(四)spring事务相关大总结
查看>>
驴妈妈管理的一点经验总结
查看>>
IOS开发学习的好资料大搜藏
查看>>
SSH的认证终结(无需密码的git操作或者ssh链接无需密码)
查看>>
Jetty 的工作原理以及与 Tomcat 的比较
查看>>
ssh-keygen的使用方法 注意权限问题
查看>>
zookeeper的server的集群配置实例[张振华-Jack]
查看>>
【屌丝程序的口才逆袭演讲稿50篇】第一篇:互联网时代U盘化生存方式 【张振华.Jack】
查看>>
CentOS6.4配置Hadoop-2.6.0集群配置安装指南(经过实战演练)【张振华.Jack】
查看>>
【屌丝程序的口才逆袭演讲稿50篇】第二篇:专注的力量 [张振华.Jack]
查看>>
【屌丝程序的口才逆袭演讲稿50篇】第三篇:我的舍与得的2014[张振华.Jack]
查看>>
【屌丝程序的口才逆袭演讲稿50篇】第五篇:不要给自己找任何借口【张振华.Jack】
查看>>
【屌丝程序的口才逆袭演讲稿50篇】第七篇:请留意我们身边的风景 【张振华.Jack】
查看>>
【屌丝程序的口才逆袭演讲稿50篇】第八篇:坚持的力量 【张振华.Jack】
查看>>
【屌丝程序的口才逆袭演讲稿50篇】第九篇:春节那些事-过年回家不需要理由【张振华.Jack】
查看>>
【屌丝程序的口才逆袭演讲稿50篇】第十篇:程序员们请看看外面的世界吧【张振华.Jack】
查看>>
【屌丝程序的口才逆袭演讲稿50篇】第十一篇:马云乌镇40分钟演讲实录【张振华.Jack】
查看>>
Java并发编程从入门到精通 张振华.Jack --我的书
查看>>