rbd镜像的锁

https://docs.ceph.com/en/reef/rbd/rbd-exclusive-locks/

官网的

exclusive-lock 的线性化只保证 RBD 内部结构(object-map/journal 等)不被并发修改,并不等于能让两台机器同时挂载 ext4/xfs 并安全读写。文档也强调它是为了避免"非协调写入"


我们两个客户端都执行了

复制代码
rbd map rbdpool/disk1

后可以通过

复制代码
rbd info rbdpool/disk1 # 查看属性
rbd status rbdpool/disk1 # 查看状态

rbd lock list rbdpool/disk1 # 查看锁的归属,同一个时候只有一个客户端获得锁

一开始是node2获得锁,然后在node3上执行

复制代码
dd if=/dev/zero of=/dev/rbd0 bs=4M count=1 oflag=direct

然后锁就到了node3

如果想要设置为独占锁的话怎么办

复制代码
rbd map rbdpool/disk1 --exclusive

然后在另外一台客户端映射就会失败

复制代码
root@node3:/# rbd map rbdpool/disk1
rbd: sysfs write failed
In some cases useful info is found in syslog - try "dmesg | tail".
rbd: map failed: (30) Read-only file system

但是可以以可读的方式挂载

复制代码
root@node3:/# rbd map rbdpool/disk1 --read-only
/dev/rbd0

但是通过可读方式映射的通过status查看看不到

bug

复制代码
root@node3:/# rbd map rbdpool/disk1
modinfo: ERROR: Module alias rbd not found.
modprobe: FATAL: Module rbd not found in directory /lib/modules/5.15.0-139-generic
rbd: failed to load rbd kernel module (1)
rbd: sysfs write failed
In some cases useful info is found in syslog - try "dmesg | tail".
rbd: map failed: (2) No such file or directory

在宿主机中执行

复制代码
# 加载 rbd 内核模块
modprobe rbd

# 验证模块是否加载成功(有输出即成功)
lsmod | grep rbd

盘如何分区

复制代码
cat > /tmp/osd_node3_only.yml <<'YAML'
service_type: osd
service_id: node3_dedicated_osd
placement:
  hosts:
    - node3
data_devices:
  paths:
    - /dev/sdb
db_devices:
  paths:
    - /dev/sdc

# 固定大小(单位后缀可用)
block_db_size: '5G'
block_wal_size: '5G'
YAML

ceph orch apply -i /tmp/osd_node3_only.yml --dry-run # 模拟运行

ceph orch apply -i /tmp/osd_spec.yml # 部署
相关推荐
一个行走的民1 天前
BlueStore 核心原理与关键机制
ceph
奋斗的小青年I3 天前
Proxmox VE Ceph 超融合集群落地实战
windows·ceph·vmware·pve·超融合·proxmox
一个行走的民3 天前
深度剖析 Ceph PG 分裂机制:原理、底层、实操、影响、线上避坑(最全完整版)
ceph·算法
一个行走的民4 天前
Ceph 核心概念精讲:彻底搞懂 PG、PGP、pg_num、pgp_num
ceph
Mr.王83516 天前
Kubernetes宿主机本地盘池化管理
ceph·云原生·容器·kubernetes
一个行走的民20 天前
CEPH OSD心跳机制
ceph
一个行走的民20 天前
Ceph PG 状态详解与线上故障处理
网络·ceph
一个行走的民20 天前
Ceph MDS 状态机与 Monitor 中的状态流转分析
ceph
Virtual_human080625 天前
在VMware workstation上,部署3节点ceph测试,及加入openstack
ceph·云计算·openstack·osd·ceph集群
Brandon汐1 个月前
从0开始搭建一主两节点k8s集群对接Ceph集群
ceph·容器·kubernetes