首页 > 其他分享 >Ceph块存储系统RDB接口

Ceph块存储系统RDB接口

时间:2024-07-10 21:31:20浏览次数:37  
标签:快照 img 存储系统 Ceph demo1 xy101 RDB 镜像 rbd

目录

1.创建 Ceph 块存储系统 RBD 接口

1.1 创建一个名为 rbd-xy101 的专门用于 RBD 的存储池

1.2 创建镜像

1.3 查看镜像

1.4 修改镜像大小

1.5 删除镜像

1.6 临时删除镜像

2.Linux客户端使用

2.1 在管理节点创建并授权一个用户可访问指定的 RBD 存储池

2.2 修改RBD镜像特性

2.3 将用户的keyring文件和ceph.conf文件发送到客户端的/etc/ceph目录下

客户端操作

2.4 安装 ceph-common 软件包

2.5 执行客户端映射

2.6 查看映射状态

2.7 格式化并挂载

2.8 在线扩容

3.快照管理

4.快照分层

5.快照展平

6.镜像导入导出


将上一篇博客client节点挂载内容解挂

1.创建 Ceph 块存储系统 RBD 接口

服务端 

1.1 创建一个名为 rbd-xy101 的专门用于 RBD 的存储池

ceph osd pool create rbd-xy101 64

ceph osd pool application enable rbd-xy101 rbd     #将poll转化为rbd模式
rbd pool init -p rbd-xy101     #rbd初始化

1.2 创建镜像

rbd create -p rbd-xy101 --image rbd-demo1.img --size 10G    #创建镜像

1.3 查看镜像

rbd ls -l -p rbd-xy101   #查看pool中镜像列表
rbd info -p rbd-xy101 --image rbd-demo1.img  #查看镜像详细信息

1.4 修改镜像大小

rbd resize -p rbd-xy101 --image rbd-demo1.img --size 20G  #扩大镜像大小

#使用 resize 调整镜像大小,一般建议只增不减,如果是减少的话需要加选项 --allow-shrink
rbd resize -p rbd-xy101 --image rbd-demo1.img --size 5G --allow-shrink

1.5 删除镜像

#删除镜像
rbd rm|remove -p rbd-xy101 --image rbd-demo1.img
或
rbd rm rbd-xy101/rbd-demo1.img

1.6 临时删除镜像

rbd trash move -p rbd-xy101 --image rbd-demo1.img   #删除放在回收站,可恢复
等于 rbd trash move rbd-xy101/rbd-demo1.img

rbd trash list -p rbd-xy101              #查看被临时删除的镜像列表和镜像恢复id

rbd trash restore rbd-xy101/              #恢复被临时删除的镜像

2.Linux客户端使用

客户端使用 RBD 有两种方式:
●通过内核模块KRBD将镜像映射为系统本地块设备,通常设置文件一般为:/dev/rbd*
●另一种是通过librbd接口,通常KVM虚拟机使用这种接口。

本例主要是使用Linux客户端挂载RBD镜像为本地磁盘使用。开始之前需要在所需要客户端节点上面安装ceph-common软件包,因为客户端需要调用rbd命令将RBD镜像映射到本地当作一块普通硬盘使用。并还需要把ceph.conf配置文件和授权keyring文件复制到对应的节点。

2.1 在管理节点创建并授权一个用户可访问指定的 RBD 存储池

ceph auth get-or-create client.<用户名> osd "allow * pool=<存储池名>" mon "allow r" > /etc/ceph/<用户名>.keyring

ceph auth get-or-create client.osd-mount osd "allow * pool=rbd-xy101" mon "allow r" > ceph.client.osd-mount.keyring

2.2 修改RBD镜像特性

CentOS7默认情况下只支持layering和striping特性,需要将其它的特性关闭

rbd feature disable rbd-xy101/rbd-demo1.img object-map, fast-diff, deep-flatten

2.3 将用户的keyring文件和ceph.conf文件发送到客户端的/etc/ceph目录下

scp ceph.client.osd-mount.keyring ceph.conf client:/etc/ceph/

客户端操作

2.4 安装 ceph-common 软件包

//linux客户端操作
#安装 ceph-common 软件包
yum install -y ceph-common

2.5 执行客户端映射

语法格式
rbd map <存储池名>/<镜像名称> --keyring /etc/ceph/<用户名>.keyring --user <用户名>
rbd map rbd-xy101/rbd-demo1.img --keyring ceph.client.osd-mount.keyring --user osd-mount

2.6 查看映射状态

rbd showmapped
rbd device list

2.7 格式化并挂载

语法格式:
mkfs -t xfs /dev/rbd0  ##针对xfs文件系统
mkdir /opt/rbd/
mount /dev/rbd0 /opt/rbd/

umount /opt/rbd     #解挂
rbd unmap rbd-xy101/rbd-demo1.img   #取消映射


2.8 在线扩容

在管理节点调整镜像的大小
rbd resize <存储池名>/<镜像名称> --size 20G
 
在客户端刷新设备文件(扩容镜像后在线刷新)
xfs_growfs /dev/rbd0		#刷新xfs文件系统容量
resize2fs /dev/rbd0			#刷新ext4类型文件系统容量

xfs_growfs /dev/rbd0
df -hT



3.快照管理

对 rbd 镜像进行快照,可以保留镜像的状态历史,另外还可以利用快照的分层技术,通过将快照克隆为新的镜像使用。

在管理节点对镜像创建快照
rbd snap create -p rbd-xy101 --image rbd-demo1.img --snap rbd-demo1.snap1
 
可简写为:
rbd snap create rbd-xy101/rbd-demo1.img@rbd-demo1.snap1


列出指定镜像所有快照
rbd snap list -p rbd-xy101 --image rbd-demo1.img

 
#用json格式输出:
rbd snap list rbd-demo/rbd-demo1.img --format json --pretty-format

回滚镜像到指定
在回滚快照之前,需要将镜像取消镜像的映射,然后再回滚。
 
 
#在客户端操作 取消映射
rm -rf /opt/rbd/*
umount /opt/rbd
rbd unmap rbd-xy101/rbd-demo1.img

#在管理节点操作
rbd snap rollback rbd-xy101/rbd-demo1.img@rbd-demo1.snap1
rbd snap rollback <存储池名>/<镜像名称>@<快照名称>
 
#在客户端重新映射并挂载
rbd map rbd-xy101/rbd-demo1.img --keyring ceph.client.osd-mount.keyring --user osd-mount
mount /dev/rbd0 /opt/rbd/
ls /opt/rbd        #发现数据还原回来了



限制镜像可创建快照数
rbd snap limit set rbd-xy101/rbd-demo1.img --limit 3
 
解除限制
rbd snap limit clear rbd-xy101/rbd-demo1.img

删除快照
#删除指定快照:
rbd snap rm rbd-xy101/rbd-demo1.img@demo1_snap1
 
#删除所有快照:
rbd snap purge rbd-xy101/rbd-demo1.img


4.快照分层

快照分层支持用快照的克隆生成新镜像,这种镜像与直接创建的镜像几乎完全一样,支持镜像的所有操作。唯一不同的是克隆镜像引用了一个只读的上游快照,而且此快照必须要设置保护模式。

快照克隆
1)将上游快照设置为保护模式:

 rbd snap protect rbd-xy101/rbd-demo1.img@rbd-demo1.snap666
2)克隆快照为新的镜像

 rbd clone rbd-xy101/rbd-demo1.img@rbd-demo1.snap666 --dest rbd-xy101/rbd-demo666.img
rbd ls -l -p rbd-xy101  #查看
 
3)命令查看克隆完成后快照的子镜像
rbd children myrbd/demon1.img@666.snap1


5.快照展平

通常情况下通过快照克隆而得到的镜像会保留对父快照的引用,这时候不可以删除该父快照,否则会有影响。

rbd snap rm rbd-xy101/rbd-demo1.img@rbd-demo1.snap666
#报错 snapshot '666.snap1' is protected from removal.
 
如果要删除快照但想保留其子镜像,必须先展平其子镜像,展平的时间取决于镜像的大小
1) 展平子镜像

rbd flatten rbd-xy101/rbd-demo666.img
2)取消快照保护
rbd snap unprotect rbd-xy101/rbd-demo1.img@rbd-demo1.snap666
3)删除快照
rbd snap rm rbd-xy101/rbd-demo1.img@rbd-demo1.snap666
 
 
rbd ls -l -p rbd-demo            #在删除掉快照后,查看子镜像依然存在


6.镜像导入导出

导出镜像

rbd export rbd-xy101/rbd-demo666.img /opt/rbd-demo666.img

导入镜像

client节点
#取消挂载、映射
umount /opt/rbd
rbd unmap rbd-xy101/rbd-demo1.img

admin节点
#清除镜像下的所有快照,并删除镜像
rbd snap rm rbd-xy101/rbd-demo1.img --snap rbd-demo1.snap1    #删除快照
rbd rm rbd-xy101/rbd-demo1.img
rbd rm rbd-xy101/rbd-demo666.img  #删除镜像

#导入镜像
rbd import /opt/rbd-demo666.img rbd-xy101/rbd-demo666.img

rbd ls -l -p rbd-xy101



admin节点
CentOS7默认情况下只支持layering和striping特性,需要将其它的特性关闭
bd feature disable rbd-xy101/rbd-demo666.img object-map, fast-diff, deep-flatten

rbd info rbd-xy101/rbd-demo666.img   #查看镜像详细情况

client节点重新做映射、挂载
rbd map rbd-xy101/rbd-demo666.img --keyring ceph.client.osd-mount.keyring --user osd-mount
rbd showmapped  #查看
mount /dev/rbd0 /opt/rbd/
ls /opt/rbd


标签:快照,img,存储系统,Ceph,demo1,xy101,RDB,镜像,rbd
From: https://blog.csdn.net/2402_83805984/article/details/140321797

相关文章