|
|
1、配置文件介绍
, E( r+ w7 ?/ _" M9 s4 C; o. D" u4 h3 T% H; _: B7 `( f% f
drbd的主配置文件为/etc/drbd.conf;为了管理的便捷性,目前通常会将些配置文件分成多个部分,且都保存至/etc/drbd.d目录中,主配置文件中仅使用"include"指令将这些配置文件片断整合起来。通常,/etc/drbd.d目录中的配置文件为global_common.conf和所有以.res结尾的文件。其中global_common.conf中主要定义global段和common段,而每一个.res的文件用于定义一个资源。
M4 n2 Y+ F+ V P) K% z5 Z& {2 ~0 o' e3 F$ d- a* ?! O7 e6 o( A
在配置文件中,global段仅能出现一次,且如果所有的配置信息都保存至同一个配置文件中而不分开为多个文件的话,global段必须位于配置文件的最开始处。目前global段中可以定义的参数仅有minor-count, dialog-refresh, disable-ip-verification和usage-count。
! o' f$ b9 g* Z1 `$ N# B7 A( o0 Z5 x& }! T8 W" G/ A4 L
common段则用于定义被每一个资源默认继承的参数,可以在资源定义中使用的参数都可以在common段中定义。实际应用中,common段并非必须,但建议将多个资源共享的参数定义为common段中的参数以降低配置文件的复杂度。& E1 B6 \# h% y, j- H7 d/ p
e/ I `# g+ r
resource段则用于定义drbd资源,每个资源通常定义在一个单独的位于/etc/drbd.d目录中的以.res结尾的文件中。资源在定义时必须为其命名,名字可以由非空白的ASCII字符组成。每一个资源段的定义中至少要包含两个host子段,以定义此资源关联至的节点,其它参数均可以从common段或drbd的默认中进行继承而无须定义。0 o% r/ D. V/ P$ K
; E9 `9 ~. o, ?5 r3 j; ^以下是我的配置事例:, H8 _6 n7 l; s$ z' p. C6 u+ }
5 d9 O. ?; p, b' W+ k8 p
#cat /etc/drbd.d/global-common.conf
, h. }( f- |- h
& A) F6 f2 |$ w" n/ o
& \$ L1 u7 |0 I+ J; f+ H4 Z0 Q5 J' S$ U; ?& Y4 y' H3 S
1 n+ m. x7 _2 v& b- fglobal {9 o& \; r( S; P* B" c0 r
usage-count no;( M: V& p- V/ k2 T9 C
# minor-count dialog-refresh disable-ip-verification' A4 G/ g* h2 G/ v
}
3 O8 k: e ^+ K: {( vcommon {
+ z9 a% A2 U( R+ _$ x protocol C;: e9 ?, L9 L2 W: z( D5 S4 e9 n
handlers {" d& n! n, ^" o
pri-on-incon-degr "/usr/lib/drbd/notify-pri-on-incon-degr.sh; /usr/lib/drbd/notify-emergency-reboot.sh; echo b > /proc/sysrq-trigger ; reboot -f";* l1 Q! |% b/ H: D/ {9 w% f
pri-lost-after-sb "/usr/lib/drbd/notify-pri-lost-after-sb.sh; /usr/lib/drbd/notify-emergency-reboot.sh; echo b > /proc/sysrq-trigger ; reboot -f";7 R; u4 o& j) ^1 \
local-io-error "/usr/lib/drbd/notify-io-error.sh; /usr/lib/drbd/notify-emergency-shutdown.sh; echo o > /proc/sysrq-trigger ; halt -f";( e$ ~- S% M t' u( x0 q& c
# fence-peer "/usr/lib/drbd/crm-fence-peer.sh";
- h* C \7 U: a' I3 K # split-brain "/usr/lib/drbd/notify-split-brain.sh root";
) t$ P& Q; s9 X! v # out-of-sync "/usr/lib/drbd/notify-out-of-sync.sh root";
4 K( T, w, w1 l1 ^* M- X( I: s # before-resync-target "/usr/lib/drbd/snapshot-resync-target-lvm.sh -p 15 -- -c 16k";" L1 I9 m) o) q& e
# after-resync-target /usr/lib/drbd/unsnapshot-resync-target-lvm.sh;) a5 Y6 Y9 A/ W/ _2 n. b+ B
}
: _$ o8 N: ~/ t" z: Q8 C% n startup {
" k) J' E6 S9 K* p# W5 D% _ #wfc-timeout 120;, j) h6 h. p1 S" y; d# Z7 N0 V+ m
#degr-wfc-timeout 120;
% \, S+ Y" Z; A/ Z) H }
; g6 o" E1 ^' N. p disk {
2 e- l8 m5 q$ z) h! I on-io-error detach;$ x- ~7 r0 v2 G% S3 L& f# x
#fencing resource-only;
( W: C5 }: B- k* e3 u# y" o }
4 m2 l4 e Q- z net { L3 `% f! R# u8 D. Z1 a8 c; I
cram-hmac-alg "sha1";7 j$ [$ N! h" f* U3 N: f
shared-secret "mydrbd";
& `; T6 o2 y: \: `0 ~ }
# a; W& p0 b4 t1 W6 Q* c5 v2 a syncer {
& Q1 C$ O8 U& Q% X9 W rate 1000M;2 u8 z6 ^; h- [
}- v4 ~6 G0 n$ I0 i/ w* A) I" `
}
7 Z' m1 L' y, k6 |, x2、定义一个资源/etc/drbd.d/web.res,内容如下:
/ Z; Q4 V. D( e3 Y7 b5 g8 M; f
2 @# M$ V6 Z3 W q' S5 A* L; l! D% k/ g- x& r, W M q8 W
( f! Q6 ^; G3 [% }: O+ mresource web {7 @; Z7 a" O' F0 C& e5 t0 X
on node1.wzlinux.com {
: F& S( F2 k* {9 X- d device /dev/drbd0;9 c" ~' a2 X' u/ e; E$ E" d) M. [
disk /dev/sdb;
' V0 }" {! U& |# J" Z ? _$ K0 \ address 192.168.0.10:7789;& l6 W6 e! a) N l; z) ~
meta-disk internal;; c; L7 e# m$ R) h
}' f0 a g7 M9 A. c9 c5 L$ l
on node2.wzlinux.com {* h1 B0 x' @* r
device /dev/drbd0;
/ b4 r9 R2 x$ F6 h disk /dev/sdb;7 _6 P" D; D( y
address 192.168.0.11:7789;* M# y! ?$ [# P1 I
meta-disk internal;
& i& v8 R: [- s }
2 T8 S+ D: h+ l3 _6 ?' N}" v5 }* b; p; G
注:以上配置在两个节点上必须相同
3 f( l- H; c3 J2 v( e( j0 [+ v) u0 G2 P8 B v5 c
" ~" y' q0 Y" D
6 j/ m# T; \, y U+ O Q四、drbd启动和查看
9 C. _! |8 U8 Z: c4 m. f4 R
& c% D4 P1 i. C1、初始化资源4 e. o& s; G3 { @
1 w, A. \ b* D1 E
在Node1和Node2上分别执行:7 S# @- i2 g' O+ }* W1 b
4 @. ^. q' o5 {3 R w8 i# drbdadm create-md web
0 x2 H' U8 L# b( R& [0 j; m, \6 Y# x+ G$ C8 r1 F( w
wKiom1Zuaaezfc2oAABvnsE2UA0970.jpg# m: l9 G- t5 N, c4 F2 L
" Q J- n0 O. I% p- T8 O$ h2、启动服务8 j7 ?# ~3 c: j1 d: W. o- R4 A
* E6 P# z, l V* d
在Node1和Node2上分别执行:3 P0 V: o1 S& ]: F I9 C
# _7 n# q' d) {# service drbd start, t& R- r# R/ u4 u% x+ Z
& k% u4 E' R. X8 p; D
wKiom1Zuad-yY6IVAAA5oMSEnj0629.jpg; t/ C1 I0 C; d7 ]: I# W
6 m' R2 A' Q; d5 z. {. C. @
3、查看启动状态
2 F/ @8 W9 e3 d* T4 d
6 D' W- V5 ]) l4 ]* f( U! r. F& `
q2 n. V+ K5 J1 u+ {
6 f1 m" l! o T8 wcat /proc/drbd #或者直接使用命令drbd-overview6 q# L W: j1 w$ S
wKiom1ZubITTPfQFAABtRuKmbw0960.jpg- r% M, C$ u8 @4 o( A2 B
+ v) s+ E4 N5 W& g 从上面的信息中可以看出此时两个节点均处于Secondary状态。于是,我们接下来需要将其中一个节点设置为Primary。在要设置为Primary的节点上执行如下命令:
3 O+ T6 R D& t9 g2 A* p5 {. L+ |% k; V
$ M& j$ e% F" d6 F4 u+ ^3 m* V2 o
9 G- t! u9 [# g1 r
- l9 F) K: b m6 t }drbdadm primary --force web1 U4 p0 [" z+ t% Q$ g7 Q0 H
然后我们再去查看状态,可以看到数据在同步中。
- u+ o& ?" r3 r7 j
) X' q) v- `1 |5 f. c/ EwKiom1Zub52A0x25AACE9DA7R5s955.jpg
8 B7 ^- M+ o" I2 s, d7 r) O
4 N! h$ _# I8 v& M5 g$ u4 U注: 也可以在要设置为Primary的节点上使用如下命令来设置主节点:
+ u7 R; y# c: d- @
7 J$ q2 `% e! \/ R$ t$ U # drbdadm -- --overwrite-data-of-peer primary web
% I. j1 ^) V7 S- c! `) B& }/ ?% g6 U+ r0 H1 o+ I! K$ j1 D& U
等数据同步完成以后再次查看状态,可以发现节点已经牌实时状态,且节点已经有了主次:3 O+ T* [. I/ x# h+ v4 r4 F
/ M$ x8 ]% s/ T1 R; S3 awKioL1ZucCri9IWoAABunqEsX6c581.jpg2 i& S5 w! k$ v% D5 @3 A
# F0 g: o; V% z
4、创建文件系统( y/ B" Q8 z% Q; H8 [/ o
1 R8 @6 O E# X! d$ Y% z) Y5 d
文件系统的挂载只能在Primary节点进行,因此,也只有在设置了主节点后才能对drbd设备进行格式化:
& V( Y% E6 r8 |6 l3 _0 W; U' U( z# r# @: y" v2 ]7 k
( T" n X; S' J& o
9 v% i2 Q9 m, [: B4 k% ~
, M+ l, K- b8 |5 `5 imkfs.ext4 /dev/drbd0) ?" r ]7 ^/ ?9 u2 E2 D* x
mount /dev/drbd0 /var/www/html# H0 g B3 O7 H. m1 n
wKioL1ZucXTzM6dgAABh9dm3wdc516.jpg
" k" e* O: G7 ^8 p5 J0 W/ s$ Q ~1 ]- k& r
5、切换Primary和Secondary节点* R8 l+ ~% e; x6 l" _
( m a2 m: w- y9 B
对主Primary/Secondary模型的drbd服务来讲,在某个时刻只能有一个节点为Primary,因此,要切换两个节点的角色,只能在先将原有的Primary节点设置为Secondary后,才能原来的Secondary节点设置为Primary:, q8 S) X. r8 j) k+ X; X8 p% i
7 p0 N' {& o) D" U; h" { J5 a" E
Node1:. Q, M- Q9 e# Z
1 @2 o2 K! X2 g6 r8 {4 ~* U& y* E0 ~! e' Y2 n% H2 b2 U
* f6 F; I) q" V t
& t) _# s% g: L) x2 b; W) q6 Zcp /etc/fstab /var/www/html/ #复制一个测试文件
2 E) ]8 |# I/ ]) h) u" f- e! y$ J6 B( iumount /var/www/html7 v0 p2 G1 L- p1 q5 _ q
drbdadm secondary web #设定为备节点
# T, P; a1 N. I. h查看状态:
, ?1 \( w: {% `& O2 l6 c5 Q& f* L: S6 |. u" ]. P1 {
/ F0 ]2 I! Q* ?* p9 T0 Q1 Z* G( S3 l, l! d( y
# drbd-overview
6 \, ^1 s8 r/ M9 t) ]5 ^2 k/ i, @, z 0:web Connected Secondary/Secondary UpToDate/UpToDate C r----
* V% F) j: Y! k! x0 T2 B+ yNode2:1 V% ~$ z& X( G E, c6 W3 H$ H
; U9 x5 ]5 t9 K/ I/ `$ D! T
4 D3 E& f+ N2 R' H' `
; G7 ~9 l, Y/ O7 ^2 T# }! Mdrbdadm primary web #提升为主节点4 X4 O6 x1 N& o; q0 x
drbd-overview #查看状态是否提升成功
' c: ?( i. O! D9 ?mount /dev/drbd0 /var/www/html #挂载文件3 E# p( |* h9 ~& f
使用下面的命令查看在此前在主节点上复制至此设备的文件是否存在:0 E4 k; M7 ^3 F9 b
2 K |3 u* m& Y: F/ f: D5 q M1 L' C4 d- H
1, ^2 f% ]+ V6 [9 \
$ n& j& L5 x+ j4 T* x6 s: ~
ll /var/www/html/
( m/ G ?/ y% |- U9 v9 H# k8 gwKiom1Zuc0Cgl5JqAAAw2zqGE2k492.jpg
' g* H7 e9 ]% U
9 u& `3 j$ w7 @; p' B/ |2 s( d 到目前为止WEB服务的数据可以实现实时同步,只要把WEB服务搭建起来就可以直接使用了,非常方便。 |
|