DRBD常用管理篇

2021-09-19 20:13:35 字數 4946 閱讀 4510

在drbd進入使用階段之後,要經常檢視它的工作狀態,通過這些狀態來判斷drbd運**況。

1) 使用drbd-overview命令觀察狀態

最為簡便的方式就是執行drbd-overview命令

#drbd-overview

0:r0  connected primary/secondary uptodate/uptodate c r—– /nfs ext4 20g 45m 19g 1%

2) 通過偽檔案系統/proc/drbd 檔案來執行狀態

#cat /proc/drbd

version: 8.3.16 (api:88/proto:86-97)

git-hash: a798fa7e274428a357657fb52f0ecf40192c1985 build by phil@build64r6, 2014-11-24 14:51:37

0: cs:connected ro:primary/secondary ds:uptodate/uptodate c r—–

ns:0 nr:0 dw:664 dr:2017 al:1 bm:0 lo:0 pe:0 ua:0 ap:0 ep:1 wo:f oos:0

狀態指示

第一行:  軟體的版本號

第二行:

有關構建drbd的特定資訊

第三行: drbd的主要資訊

cs(connect state):表示網路連線的狀態

ro(role):表示執行節點的角色,

primary/secondary 表示本機為主

ds(disk state):表示當前的硬碟狀態

replication protocol:表示當前複製所使用的協議,可以是abc

i/o flags:6個i/o輸入輸出標誌,從各個方面反映了本地資源的狀態

performance indicators:效能指標,這是一組統計資料和計數器,反映出資源的利用情況和效能

3) 連線狀態

連線狀態可以通過監控/proc/drbd檔案得到具體資訊,也可以使用drbdadm cstate命令來獲取。

#drbdadm cstate r0

connected

連線的狀態也有可能是以下其中的一種:

standalone:沒有可用的網路配置,資源沒有被連線,或者執行過 drbdadm disconnect resource 命令,例子如下:

#drbdadm disconnect all

#drbdadm cstate r0

standalone

4) 資源角色

資源連線狀態可以通過/proc/drbd或者使用drbdadm role resource來獲取。

#drbdadm role all

primary/secondary

可能的角色為:

primary:當前的資源是primary角色,可以進行讀取和定稿的操作。該角色在兩個節點中僅能出現在乙個節點[雙節點模式除外]

secondary:表示該角色為從節點,這種角色下既不能讀取也不寫入。這種角色可能會發生在乙個或者兩個節點上。

第一行:

unknown:這種角色表示當前資源的角色不。本地資源不會有這種狀態,它僅出現在用來表示對點的資源角色,而且僅在無法連線模式下。如下:

#drbdadm disconnect all

#cat /proc/drbd

version: 8.3.16 (api:88/proto:86-97)

git-hash: a798fa7e274428a357657fb52f0ecf40192c1985 build by phil@build64r6, 2014-11-24 14:51:37

0: cs:standalone ro:secondary/unknown ds:uptodate/dunknown   r—–

ns:660 nr:4 dw:664 dr:1029 al:5 bm:0 lo:0 pe:0 ua:0 ap:0 ep:1 wo:f oos:0

5) 磁碟狀態

磁碟狀態可以通過/proc/drbd或者使用drbdadm dstate resource來獲取。

# drbdadm dstate r0

uptodate/uptodate

首先輸入的是本地硬碟狀態,後面的是遠端硬碟狀態。以下為硬碟的狀態:

diskless:無盤狀態,當前沒有與drbd驅動相關塊裝置。這種狀態通常代表著資源沒有被附加上後台裝置。可能是通過使用 rbdadm detach命令手工分離了後台裝置。或者由於底層i/o的錯誤而自動分離。
attaching:附加狀態,這種狀態是在讀取元資料時出現的一種瞬間狀態。
negotiating:協商狀態,在已經連線的drbd裝置上進行「attach」讀取元資料的乙個瞬間狀態。
inconsistent:資料不一致狀態這種狀態出現兩個drbd節點上的資源在建立了新的資源後立即建立連線時(就是完全初始化同步之前),這種情況下兩個資源節點都會出現,另一種可能就是在同步過程中乙個節點出現這種狀態,而且是出現在同步的目標上。
outdated:資料過期狀態,資源資料一致,但是已經過期,這種情況需要進行進一步處理。
dunknown:硬碟不明確狀態,如果網路連線無效,那麼這種狀態將會被用於表示對點磁碟的狀態。
consisten:資料一致狀態,在沒有連線時資料一致的狀態,當連線完成後將會決定資料的狀態是uptodate狀態還是outdated狀態。
uptodate:資料一致狀態,而且是最新的資料一致狀態。這也是正常狀態模式。

6) i/o狀態標誌

在/proc/drbd檔案中提供了有關i/o操作資訊,這種標誌資訊一共有6個,可能的值如下:

d:內部原因導致i/o阻塞,例如,瞬間狀態出現時。
b:後台裝置i/o出現阻塞。
n:網路字出現阻塞。
a:同時出現裝置i/o阻塞和網路阻塞。

7) 效能指標

在預覽/proc/drbd時,每個資源的第二行都包含了計數器和度量值。

# cat /proc/drbd 

version: 8.3.16 (api:88/proto:86-97)

git-hash: a798fa7e274428a357657fb52f0ecf40192c1985 build by phil@build64r6, 2014-11-24 14:51:37

0: cs:connected ro:primary/secondary ds:uptodate/uptodate c r—–

ns:524420 nr:0 dw:525084 dr:2041 al:132 bm:0 lo:0 pe:0 ua:0 ap:0 ep:1 wo:f oos:0

ns(network send):通過網路連線傳送到對端的資料量,單位kb.

nr(network receive):通過網路連線從對點接收的資料量,單位kb.

dw(disk write):向本地硬碟寫入網路資料,單位kb.

dr(disk read):網路從本地硬碟讀取的資料量,單位kb.

al(activity log):元資料活動日誌的更新次數。

bm(bit map):元資料區域更新的資源。

lo(local count):由drbd產生的本地i/o請求資料。

pe(pending):就是等待響應,已經傳送到聖戰,但是還沒有得到對端回應的數量。

ep(epochs):epoch物件的數,通常為1。當使用barrier或者none寫順序方法時,可能會增加底層i/o負荷。

wo(write order):當前使用的寫順序的方法:b(barrier)/f(flush)/d(drain)/n(none)。

oos(out of sync):當前沒有同步的資料總數量,單位為kb.

8) 啟用/禁用資源

//啟用資源r0

# drbdadm up r0

//禁用資源r0

# drbdadm down r0

9) 重新配置資源

drbd在執行時,允許使用者重新配置資源,為了實現這個目的,需要進行以下操作:

1、在drbd的配置檔案/etc/drbd.conf(包括所有資源)中進行有必要的改變

2、在兩個節點之間同步

drbd的配置檔案

3、在兩個節點上執行drbdadm adjust 命令 (在執行此命令時,建議新增-d引數)

10) 匯出當前

資源配置資訊

# drbdadm dump all

# /etc/drbd.conf

common

# resource r0 on node2.dd.com: not ignored, not stacked

resource r0

on node2.dd.com

syncer

}

DRBD常用管理篇

在drbd進入使用階段之後,要經常檢視它的工作狀態,通過這些狀態來判斷drbd運 況。1 使用drbd overview命令觀察狀態 最為簡便的方式就是執行drbd overview命令 drbd overview 0 r0 connected primary secondary uptodate ...

DRBD管理與維護

drbd管理與維護 drbd admcreate md web 建立供drbd記錄資訊資料塊 mkdir p usr local drbd var run drbd 建立資源目錄 service drbd start 啟動drbd drbdadm overwrite data of peer pri...

Linux常用指令(使用者管理篇)

halt reboot sync 一般使用普通使用者登入,可再用 su 使用者名稱 命令來切換成系統管理員身份。使用者家目錄 home 當使用者登入時,會自動進入自己的家目錄。例 home cent01 home cent02 linux的使用者需要至少屬於乙個組。新增使用者 useradd 選項 ...