drbd(三):drbd的状态说明

时间:2023-02-21 15:53:25

1.几种获取状态信息的方法

drbd有很多获取信息的方式。在drbd84和之前的版本,大多都使用cat /proc/drbd来获取信息,多数情况下,这个文件展示的信息对于管理和维护drbd来说已经足够。

例如以下是drbd84上两个volume的节点状态信息:

[root@drbd1 ~]# cat /proc/drbd
version: 8.4.10-1 (api:1/proto:86-101)
GIT-hash: a4d5de01fffd7e4cde48a080e2c686f9e8cebf4c build by mockbuild@, 2017-09-15 14:23:22
0: cs:Connected ro:Primary/Secondary ds:UpToDate/UpToDate C r-----
ns:76408 nr:0 dw:76408 dr:3441 al:22 bm:0 lo:0 pe:0 ua:0 ap:0 ep:1 wo:f oos:0
1: cs:Connected ro:Primary/Secondary ds:UpToDate/UpToDate C r-----
ns:4957732 nr:0 dw:76324 dr:4883249 al:29 bm:0 lo:0 pe:0 ua:0 ap:0 ep:1 wo:f oos:0

但从drbd9开始,/proc/drbd文件已经废弃了(其实从drbd84就已经废弃了,只不过仍然能获取信息),因为drbd9中添加了几个新状态信息,也修改了一些信息的显示名称,而这个文件并没有"跟上脚步"。以下是drbd9中该文件展示的信息。

[root@drbd91 ~]# cat /proc/drbd
version: 9.0.9-1 (api:2/proto:86-112)
GIT-hash: f7b979e7af01813e031aac579140237640c94569 build by mockbuild@, 2017-09-14 17:45:45
Transports (api:16): tcp (9.0.9-1)

在drbd9中,更多的是使用drbdadmdrbdsetup来获取节点的状态信息。当然,在drbd84中也可以使用它们来获取详细的信息,只不过使用/proc/drbd既方便,又简洁,多数人都直接更愿意使用/proc/drbd。

例如,使用drbdadm获取节点的基本信息。

######### drbdadm status [--verbose] RESOURCE

[root@drbd90 ~]# drbdadm status rs0
rs0 role:Primary
volume:0 disk:UpToDate
volume:1 disk:UpToDate
drbd91.longshuai.com role:Secondary
volume:0 replication:SyncSource peer-disk:Inconsistent done:0.43
volume:1 replication:SyncSource peer-disk:Inconsistent done:23.72 [root@drbd90 ~]# drbdadm status rs0 --verbose
drbdsetup status rs0
rs0 role:Primary
volume:0 disk:UpToDate
volume:1 disk:UpToDate
drbd91.longshuai.com role:Secondary
volume:0 replication:SyncSource peer-disk:Inconsistent done:7.04
volume:1 replication:SyncSource peer-disk:Inconsistent done:48.44

使用drbdsetup获取更详细的信息:

######### drbdsetup status [--verbose] [--statistics] RESOURCE`

[root@drbd90 ~]# drbdsetup status rs0 --verbose --statistics
rs0 node-id:0 role:Primary suspended:no
write-ordering:flush
volume:0 minor:0 disk:UpToDate
size:4882432 read:537552 written:0 al-writes:0 bm-writes:0 upper-pending:0 lower-pending:0 al-suspended:no blocked:no
volume:1 minor:1 disk:UpToDate
size:4882432 read:2811712 written:0 al-writes:0 bm-writes:0 upper-pending:0 lower-pending:0 al-suspended:no blocked:no
drbd91.longshuai.com node-id:1 connection:Connected role:Secondary congested:no
volume:0 replication:SyncSource peer-disk:Inconsistent done:11.00 resync-suspended:no
received:0 sent:537096 out-of-sync:4345336 pending:0 unacked:0
volume:1 replication:SyncSource peer-disk:Inconsistent done:57.58 resync-suspended:no
received:0 sent:2811256 out-of-sync:2071176 pending:0 unacked:0

除此之外,还可以使用drbd-overview获取一些简单的信息。

[root@drbd91 ~]# drbd-overview
NOTE: drbd-overview will be deprecated soon.
Please consider using drbdtop. 0:rs0/0 Connected(2*) Second/Primar UpToDa/UpToDa
1:rs0/1 Connected(2*) Second/Primar UpToDa/UpToDa

2.状态

/proc/drbd文件中的状态信息如下:

[root@drbd1 ~]# cat /proc/drbd
version: 8.4.10-1 (api:1/proto:86-101)
GIT-hash: a4d5de01fffd7e4cde48a080e2c686f9e8cebf4c build by mockbuild@, 2017-09-15 14:23:22
0: cs:Connected ro:Primary/Secondary ds:UpToDate/UpToDate C r-----
ns:76408 nr:0 dw:76408 dr:3441 al:22 bm:0 lo:0 pe:0 ua:0 ap:0 ep:1 wo:f oos:0

其中第三行中:

  • 0是drbd的次设备号(minor),表示该行是/dev/drbd0资源的信息。
  • cs是connect state,即节点的连接状态。
  • ro是roles,即节点的角色状态。
  • ds是disk state,即磁盘的状态,也即drbd底层设备的状态。
  • C是drbd的复制协议,即A、B、C协议。
  • r-----是IO标记,反应的是该资源的IO状态信息。共有6种IO状态标记符号。

第四行是drbd同步过程中的状态,总体概括为"性能指标"。

以下翻译自官方手册: users-guide-8.4users-guide-9.0 。如果有疑问,可从官方手册自行查找答案。

2.1 连接状态(connect state,cs)和复制状态

节点间通过TCP连接进行通信,在建立连接、断开连接、特殊情况下有很多种连接状态。

建立TCP连接后,还有称为"DRBD"的连接。DRBD连接建立完成,表示元数据区、数据区等一切都已准备好,可以进行任何数据同步的操作。

节点间的连接状态既可以从/proc/drbd文件中获取,也可以使用下面的命令来获取。

[root@drbd91 ~]# drbdadm cstate rs0
Connected

drbd84中,将连接状态和复制状态全部都归类为连接状态。但在drbd9中,由于可以通过net指令定义多个drbd节点,它更网络对端和volume的概念。因此它将和连接关系不大的状态独立划分为"复制状态(replication)"中,例如同步、验证相关的状态。本文就懒得去区分它们了,都放在一起解释吧。

有以下几种连接状态,其中最常捕获到的状态已经加粗显示。

  • WFConnection当前节点正在等待对端节点出现。例如对方节点drbdadm down后,本节点将处于本状态。
  • StandAlone无连接。出现这种状态可能是因为:未连接过、使用drbdadm disconnect断开连接、节点由于身份验证的原因未成功加入drbd集群使得连接被删除、脑裂后断开连接。
  • Disconnecting:断开连接的一个临时过渡状态。它很快就会切入下一状态就是StandAlone。
  • Unconnected:尝试再次发起TCP连接时的一个临时连接状态(是连接超时后再次发送连接请求产生的状态),它的下一个状态可能是WFConnection,也可能是WFReportParams。
  • Timeout:和对端通信超时时的临时状态。下一个状态就是Unconnection。
  • BrokenPipe:和对端连接丢失时的临时状态。下一个状态是Unconnection。
  • NetworkFailure:和对端连接丢失时的临时状态。下一个状态是Unconnection。(没错,和上面的一样)
  • ProtocolError:和对端连接丢失时的临时状态。下一个状态是Unconnection。(没错,还是和上面的一样)
  • TearDown:对端关闭TCP连接时的临时状态。下一个状态是Unconnection。
  • ConnectedDRBD连接已经建立完成,数据镜像已经激活成功。这个状态是drbd正常运行时的状态。
  • WFReportParams:TCP连接已经建立完成,该节点正在等待对端的第一个数据包。
  • StartingSyncS:全盘数据同步中。只有在初始化时才应该全盘同步。下一个状态是:SyncSource或PauseSyncS。
  • StartingSyncT:全盘数据同步中。只有在初始化时才应该全盘同步。下一个状态是:WFSyncUUID。
  • WFBitMapS:部分数据正在同步。下一个状态是:SyncSource或PauseSyncS。
  • WFBitMapT:部分数据正在同步。下一个状态是:WFSyncUUID。
  • WFSyncUUID:同步马上就要开始了。下一个状态:SyncTarget或PauseSyncT。
  • SyncSource正在同步,且本节点是数据同步的源端。
  • SyncTartget正在同步,且本节点是数据同步的目标端。
  • PauseSyncS:本节点是同步的源端节点,但同步过程当前被暂停。出现这种状态的原因可能是当前同步进程依赖于另一个同步进程完成,或者使用drbdadm pause-sync手动中断了同步操作。
  • PauseSyncT:本节点是同步的目标端,但同步过程当前被暂停。出现这种状态的原因可能是当前同步进程依赖于另一个同步进程完成,或者使用drbdadm pause-sync手动中断了同步操作。
  • VerifyS:正在进行在线设备验证,且本节点将成为验证的源端。
  • VerifyT:正在进行在线设备验证,且本节点将成为验证的目标端。

在drbd9中,WFConnection状态改为connecting状态。删除了WFReportParams状态。添加了以下几个同步相关的状态:

  • Off:该卷组还未同步,因为连接未建立。
  • Established所有对该卷组的写操作已经在线完成同步。这是drbd正常运行时的状态。
  • Ahead:数据同步操作被挂起,因为网络套接字中达到了一定的堵塞程度,无法应付更多的负载。该状态需要配置"on-congestion"选项来启用。
  • Behind:对端将数据同步操作挂起,因为网络套接字中达到了一定的堵塞程度,无法应付更多的负载。该状态需要在对端节点上配置"on-congestion"选项来启用。

2.2 角色状态(roles,ro)

资源的角色状态既可以从/proc/drbd文件中获取,也可以使用下面的命令来获取。

[root@drbd1 ~]# drbdadm role data1
Primary/Unknown
Primary/Unknown

在角色状态信息中,本地节点总是标记在第一位,远程节点标记在结尾。

可能的节点角色状态有:

  • Primary:资源的primary角色,该角色状态下的drbd设备可以进行挂载、读、写等。在没有启用多主复制模型(dual-primary mode),只能有一个primary节点。
  • Secondary:资源的secondary角色。该角色状态下的drbd设备会接收来自primary端的数据更新(除非和对端不是primary)。且该角色的drbd设备不可挂载、不可读、不可写。
  • Unknown:资源的角色未知。本地节点的角色状态绝对不可能会是这种状态。只有对端节点断开连接时对端节点才处于Unknown状态。

2.3 磁盘状态(disk state,ds)

磁盘的状态既可以从/proc/drbd文件中获取,也可以使用下面的命令来获取。

# drbdadm dstate <resource>
UpToDate/UpToDate

在磁盘状态信息中,本地节点的磁盘状态总是标记在第一位,远程节点标记在结尾。这两端节点的状态信息都可能为以下值:

  • Diskless:没有为DRBD驱动分配底层块设备。这意味着资源可能从没有和它的底层块设备进行关联绑定(attach),也可能是手动detach解除了关联,还可能是出现了底层IO错误时自动detach。
  • Attaching:读取元数据时的一个短暂的状态。
  • Failed:本地块设备故障时的一个短暂的状态,下一个状态是:Diskless。
  • Negotiating:在已连接的DRBD设备上还要进行Attach时的一个短暂的状态。
  • Inconsistent:数据不一致。在双方节点(还未进行全盘同步之前)刚创建新的资源时会立即进入此状态。在某一端(目标段)正接收同步数据时,也会进入不一致状态。
  • Outdated:资源的数据是一致的,但是数据过期了。(例如,已经同步后secondary下线了,之后又上线了,在还没开始重新同步的时候就是Outdated状态)
  • DUnknown:用于标识对端节点没有连接时的磁盘状态。
  • Consistent:连接断开时的数据处于一致性状态,当连接建立后,将决定数据是UpToDate还是Outdated状态。
  • UpToDate:资源的数据是一致的,且数据是最新的。这是drbd数据正常时的状态。

2.4 IO状态标记

IO状态标记表示的是当前资源的IO操作状态。共有6种状态:

  • IO挂起:r或s都可能表示IO挂起,一般是r。r=running,s=suspended。
  • 串行重新同步:资源正在等待进行重新同步,但被resync-after选项延迟了同步进度。该状态标记为"a",通常该状态栏应该处于"-"。
  • 对端初始化同步挂起:资源正在等待进行重新同步,但对端节点因为某些原因而IO挂起。该状态标记为"p",通常该状态栏应该处于"-"。
  • 本地初始化同步挂起:资源正在等待进行重新同步,但本节点因为某些原因而IO挂起。该状态标记为"u",通常该状态栏应该处于"-"。
  • 本地IO阻塞:通常该状态栏应该处于"-"。可能有以下几种标记:
    • d:因为DRBD内部原因导致的IO阻塞。
    • b:后端设备正处于IO阻塞。
    • n:网络套接字阻塞。
    • a:网络套接字和后端块设备同时处于阻塞状态。
  • Activity Log更新挂起:当al更新被挂起时,处于该状态,标记为"s",通常该状态栏应该处于"-"。(如果不知道什么是Active Log,请无视本标记)

2.5 性能指标

主要是一些计数器和计量器的值。

请结合drbd原理图进行理解:

drbd(三):drbd的状态说明

drbd84中使用缩写符号来标记性能指标,而drbd9中使用全称来表示。例如drbd84中的ns和drbd9中的send是同一个意思。

  • ns/send (network send):通过网络连接发送给对端的数据量,单位为Kb。
  • nr/receive (network receive):通过网络连接接收到对端发送来的数据量,单位为Kb。
  • dw/written (disk write):该卷(volume)写入本地磁盘的数据量,单位为Kb。
  • dr/read (disk read):该卷(volume)从本地磁盘读取的数据量,单位为Kb。
  • al/al-writes (activity log):元数据区中al更新的次数。
  • bm/bm-writes (bit map):元数据区中bitmap更新的次数。
  • lo/lower-pending (local count):DRBD发起的打开本地IO子系统的请求次数。
  • pe/pending (pending):本地发送给对端但却没有回复的次数。
  • ua/unacked (unacknowledged):接收到对端发送的请求但却没有给予回复的请求数量。
  • ap/upper-pending (application pending):转发给DRBD的IO块的请求,但DRBD还没给予回复的请求数量。
  • ep (epochs):epoch对象的数量。通常为1。drbd9中没有该指标。
  • wo/write-ordering (write order):当前正在使用的write order方法:b(barrier), f(flush), d(drain)或n(none)。
  • oos/out-of-sync (out of sync):当前不同步的数据量,单位为Kb。

上面所有"未给予回复"的指标数量都表示动作还未完成,需要回复后才表示操作完成。这些未回复数值不能太大。

此外,drbd9中添加了以下几个指标:

  • resync-suspended:重新同步操作当前是否被挂起。可能的值为no/user/peer/dependency。
  • blocked:本地IO的拥挤情况。
    • no:本地IO不拥挤。
    • upper:DRBD层之上的IO被阻塞。例如到文件系统上的IO阻塞。可能有以下几种原因:
      • 管理员使用drbdadm suspend-io命令挂起了IO操作。
      • 短暂的IO阻塞,例如attach/detach导致的。
      • 删除了缓冲区。
      • bitmap的IO等待。
    • lower:底层设备处于拥挤状态。

drbd(三):drbd的状态说明的更多相关文章

  1. &lbrack;转&rsqb;session缓存机制和三种对象状态

    摘自 http://blog.csdn.net/csh624366188/article/details/7612142 Hibernate 的Session就是其中的一个,它提供了基本的增,删,改, ...

  2. Hibernate中的三种数据状态

    Hibernate中的三种数据状态(临时.持久.游离) 1.临时态(瞬时态) 不存在于session中,也不存在于数据库中的数据,被称为临时态. 比如:刚刚使用new关键字创建出的对象. 2.持久态 ...

  3. 浅谈Hibernate中的三种数据状态

    Hibernate中的三种数据状态:临时.持久.游离 1.临时态(瞬时态) 不存在于session中,也不存在于数据库中的数据,被称为临时态. 数据库中没有数据与之对应,超过作用域会被JVM垃圾回收器 ...

  4. 命令stat anaconda-ks&period;cfg会显示出文件的三种时间状态(已加粗):Access、Modify、Change。这三种时间的区别将在下面的touch命令中详细详解:

    7.stat命令 stat命令用于查看文件的具体存储信息和时间等信息,格式为"stat 文件名称". stat命令可以用于查看文件的存储信息和时间等信息,命令stat anacon ...

  5. 实现CheckBox的三种选中状态(全选、半选、不选)在GridView中模拟树形的功能

    度娘了很多帖子,只说三种状态要用图片替换来做,但没找到有用的例子,被逼自己写了一个 三方控件肯定是很多的,如jstree,可以直接用 由于公司的UDS限制,不能上传图片,只能文字说明了. 就是要在gr ...

  6. 【Hibernate框架】对象的三种持久化状态

    一.综述 hibernate中的对象有三种状态,分别是TransientObjects(瞬时对象).PersistentObjects(持久化对象)和DetachedObjects(托管对象也叫做离线 ...

  7. 【HTTP】三、HTTP状态保持机制(Cookie和Session)

      前面我们提到HTTP协议的特点:无连接.无状态.无连接带来的时间开销随着HTTP/1.1引入了持久连接的机制得到了解决.现在来关注其"无状态"的特点.   所谓的无状态,就是指 ...

  8. EasyUI tree的三种选中状态

    EasyUI中tree有三种选中状态,分别是checked(选中).unchecked(未选中).indeterminate(部分选中). 其中indeterminate状态比较特殊,主要表示只有部分 ...

  9. 三 Hibernate持久化状态&amp&semi;主键生成策略

    持久化类 持久化:将内存中的一个对象持久化到数据库中的过程 持久化类:Java类+映射文件.Java中一个类与数据库的表建立了映射关系,那么这个类称为持久化类. 持久化类的编写规则: 对持久化类提供一 ...

随机推荐

  1. Search Insert Position

    int searchInsert(int* nums, int numsSize, int target) { ; ); ; int mid; while(low<=high){ mid=(lo ...

  2. HDU 3461 Code Lock(并查集)

    很好的一个题,思想特别6 题意:给你小写字母个数n,每个字母可以向上翻动,例如:d->c,a->z.然后给你m对数(L,R)(L<=R),表示[L,R]之间可以同时向上翻动,且翻动后 ...

  3. SQL遍历字符串的方法

    字符串穿越: 1.创建一个只存递增序列(1…n)的表——Temp,并将它与目标字符串所在的表Src进行笛卡尔运算.(Temp表的记录数要不小于遍历的目标字符串的长度) 2.过滤掉序列值大于串长的行. ...

  4. Java新手问题集锦

    Java是目前最流行的编程语言之一——它可以用来编写Windows程序或者是Web应用,移动应用,网络程序,消费电子产品,机顶盒设备,它无处不在. 有超过30亿的设备是运行在Java之上的.根据Ora ...

  5. 【转】JSON&period;parse&lpar;&rpar; Unexpected token i in JSON at position 2 报错问题

    JSON.parse(): Unexpected token i in JSON at position 2 报错问题 错误代码: var res = "[{id:1,name:'limin ...

  6. windows安装composer

    Composer 是 PHP 的一个依赖管理工具(不是一个包管理器).它允许你申明项目所依赖的代码库,它会在你的项目中为你安装他们. 在windows下安装的方法 方法一:使用安装程序 这是将 Com ...

  7. B站弹幕姬&lpar;&&num;128020&semi;&rpar;分析与开发(下篇)

    接上篇 下面开始分析弹幕信息: 当我们在完成和服务器的握手之后,b站的弹幕服务器就会开始不停的开始给我们推送相关房间的弹幕消息了.老规矩前面16个字节是这个包的相关信息,我们先来看下这条消息的前面16 ...

  8. Wood Chipping Text Animation

    Blender Tutorial: Wood Chipping Text Animationhttps://www.youtube.com/watch?v=YFmN7eTNfNw 文字建模 木板建模, ...

  9. python-面向对象-11-异常

    异常 目标 异常的概念 捕获异常 异常的传递 抛出异常 01. 异常的概念 程序在运行时,如果 Python 解释器 遇到 到一个错误,会停止程序的执行,并且提示一些错误信息,这就是 异常 程序停止执 ...

  10. &lbrack;不屈的复习&rsqb; - http&colon;&sol;&sol;how2j&period;cn&sol;

    http://how2j.cn/ 该教程网站分得比较规整!