开始阅读之前,请先注意示例中使用的 DRBD 版本
drbdadm -V |
注意:安装的 kernel-devel 的内核源码(内核源码路径/usr/src/kernel/)和当前系统的 kernel 版本(uname -r)不一致的话需要把当前内核更新一下。
在2.6.33
及以上版本的内核默认中有DRBD
,之前在用的DRBD
主要8.0
、8.2
、8.3
三个版本,对应的rpm
包是drbd
,drbd82
和drbd83
,因此需要安装对应的内核模块,对应的名字为kmod-drbd
,kmod-drbd82
,kmod-drbd83
。
由于drbd
是作为内核模块进行工作的,故建议使用与内核对应的版本,对应关系如下表。
Linux releases | DRBD releases |
---|---|
2.6.33 | 8.3.7 |
2.6.34 | 8.3.7 |
2.6.35 | 8.3.8 |
2.6.36 | 8.3.8.1 |
2.6.37 | 8.3.9 |
2.6.38 | 8.3.9 |
2.6.39 | 8.3.10 |
3.0 - 3.4 | 8.3.11 |
3.5 - 3.7 | 8.3.13 |
注意:目前官网上面 8.0 – 8.3.x 已标注为Deprecated
即不建议使用状态。
drbd 状态记录
清除单个 DRBD
资源配置:(以 drbd10 为例)
drbd-overview # drbd概览 |
重启 DRBD
服务
service drbd stop |
DRBD
扩容
当遇到我们的drbd resource
设备容量不够的时候,而且我们的底层设备支持在线增大容量的时候(比如 lvm),我们可以先增大底层设备的大小,然后再通过drbdadm resize resource_name
来实现对resource
的扩容。
这里有需要注意的是:
只有在单主模式下可以这样做,而且需要先在两节点上都增大底层设备的容量,然后仅在主节点上执行resize
命令。
在执行了resize
命令后,将自动触发一次当前主节点到其他所有从节点的 re-synchronization;
如果我们在drbd
非工作状态下对底层设备进行了扩容,然后再启动drbd
,将不需要执行resize
命令(当然前提是在配置文件中没有对 disk 参数项指定大小),drbd
自己会知道已经增大了容量;
在进行底层设备的增容操作的时候千万不要修改到原设备上面的数据,尤其是drbd
的meta
信息,否则有可能毁掉所有数据。
流程简单示例
先在两端扩展Lun(需要相同大小) |
global_common.conf 配置(示例)
global { |
数据同步协议
DRBD
有三种数据同步模式:同步,异步,半同步
- 异步:指的是当数据写到磁盘上,并且复制的数据已经被放到我们的
tcp
缓冲区并等待发送以后,就认为写入完成; - 半同步:指的是数据已经写到磁盘上,并且这些数据已经发送到对方内存缓冲区,对方的
tcp
已经收到数据,并宣布写入; - 同步:指的是主节点已写入,从节点磁盘也写入;
DRBD
的复制模型是靠protocol
关键字来定义的:protocol A
表示异步;protocol B
表示半同步;protocol C
表示同步,默认为protocol C
。
在同步模式下只有主、从节点上两块磁盘同时损害才会导致数据丢失。在半同步模式下只有主节点宕机,同时从节点异常停电才会导致数据丢失。
注意:
- 主从所在的磁盘分区最好大小相等,
DRBD
磁盘镜像相当于网络RAID1
;(本人使用时强制相等,但网上没有关于分区大小是否一定要相同的确切说法) - 网络同步时需要一定的时间,在同步完成之前最好不要重启,否则会重新同步;
DRBD
的主节点不会监控从节点的状态,所以有可能会造成数据重传;- 格式化只需要在
primary
节点上进行,且只能在主节点上挂载;若主节点下线,从节点上线,则从节点可以直接挂载,不需要再次格式化。集群中只有 primary 服务器可以挂载设备,secondary 挂载会报错。只有在进行故障迁移升级为主时才需要挂载。 - 如果
DRBD
状态下关机双控恢复不过来,尝试删除DRBD
配置信息,然后停掉DRBD
端 ODSP 和mysql
重启之后即可;(此条仅针对公司项目)
单个drbd
配置文件(以 drbd10.res 为例)
项目中的配置方案
resource drbd11 { |
另外一种配置方案
来自这里
resource r0 { # ① |
翻译以看懂为目的:
1.允许某些系统服务项关联的名称,如:nfs, http, mysql_0, postgres_wal 等;
Name that allows some association to the service that needs them. For example, nfs, http, mysql_0, postgres_wal, etc.
2.DRBD
设备名称及编号;
The device name for DRBD and its minor number.
在上面的例子中,drbd
的编号是0
。udev 集成脚本提供符号链接/dev/drbd/by-res/nfs/0
。或者,也可以省略配置中的设备节点名称,然后使用下面这种形式代替:drbd0 minor 0
(/dev/可选)或/dev/drbd0
;
In the example above, the minor number 0 is used for DRBD. The udev integration scripts will give you a symbolic link /dev/drbd/by-res/nfs/0. Alternatively, omit the device node name in the configuration and use the following line instead:
drbd0 minor 0 (/dev/ is optional) or /dev/drbd0
3.节点之间进行复制的原始设备。注意:在本例中,两个节点上面的设备是相同的。若使用不同设备,请将磁盘参数移动到状态为on
节点上。(?)
The raw device that is replicated between nodes. Note, in this example the devices are the same on both nodes. If you need different devices, move the disk parameter into the on host.
4.meta-disk
参数通常包含隐式值,但是你也可以指定一个显式设备保存元数据。详情参见:这里>>>
The meta-disk parameter usually contains the value internal, but it is possible to specify an explicit device to hold the meta data. See http://www.drbd.org/users-guide-emb/ch-internals.html#s-metadata for more information.
5.on
节配置指明改配置应用于具体哪个host
。
The on section states which host this configuration statement applies to.
6.各节点的IP
地址和端口号。每个资源需要一个单独的端口,通常以7788
开始。
The IP address and port number of the respective node. Each resource needs an individual port, usually starting with 7788.
7.同步率。将其设置为磁盘读写和网络带宽的三分之一。仅限制重新同步,而不是复制。
The synchronization rate. Set it to one third of the lower of the disk- and network bandwidth. It only limits the resynchronization, not the replication.
主从切换
主备节点切换有两种方式,分别是停止DRBD
服务切换和正常切换。
正常切换
主切换成从,需要先卸载文件系统,再执行降级为从的命令
主端
umount /data/ |
从端
从切换成主,要先执行升主的命令,然后挂载文件系统
drbdadm primary all |
停止 drbd 服务切换
基本思路:关闭主节点服务,此时挂载的DRBD
分区就自动在主节点卸载了,然后在备用节点执行切换命令
[root@drbd2 ~]#drbdadm primary all |
当在备用节点执行切换到主节点命令后,原来的主用节点自动变为备用节点。无需在主用节点再次执行切换到备用节点的命令。
脑裂修复
当DRBD
出现脑裂后,会导致DRBD
两边的磁盘数据不一致,在确定要作为从的节点上切换成secondary
,并放弃该资源的数据:
drbdadm secondary r0 |
然后作为primary
的节点重新连接secondary
(如果这个节点当前的连接状态为WFConnection
的话,可以省略),使用如下命令连接:
drbdadm connect r0 |
其他
双控配置互信(假定在控 1 执行)
echo y|ssh-keygen -t dsa -f ~/.ssh/id_dsa -N "" |