分布式复制块设备之DRBD

DRBD:(Distributed Replicated Block Device)  分布式复制块设备

        是一个用软件实现的、无共享的、服务器之间镜像块设备内容的存储复制解决方案。 

主要特点:

        1.Distributed Replicated Block Device

        2.A software based, shared nothing, replicated storage solution mirroring the content of block devices (hard disks, partitions, logical volumes etc.) between servers.
        3.DRBD's core functionality is implemented by way of a Linux kernel module
        4.DRBD mirrors data

               (1)In real time
               (2)Transparently
               (3)Synchronously or asynchronously

如下图为DRBD的工作模式:

         

如图所示:DRBD有主从之分

        primary:(可执行读、写操作)        secondary:(文件系统不能挂载)

        DRBD它能够将位于两个主机的硬盘或分区做成镜像设备,客户端应用程序像我们主服务器发起写请求,经过DRBD模块的时候,DRBD模块会将请求一分为二,将请求发往本地硬盘一份,然后通过TCP/IP协议将数据通过网卡传递给secondary一份。

        如果我们先读写数据,首先发起系统调用(File System),文件系统在实现文件读写的时候,为了加快读取速度,内核会在内存空间中划分出一段空间,用于Buffer和Cache,Buffer和Cache主要用来缓存源数据和数据等;所以在读写数据时,实在Buffer和Cache中完成的,而且在Buffer和Cache中完成读写之后不会立即同步到磁盘上,而由Buffer和Cache往硬盘中写数据时,DRBD会把数据分流成两份,一份写到本地硬盘中,一份会经TCP/IP协议经过网卡传送到另一个节点上。

        另外primary在与secondary传送数据时有三种协议:

                1、A模型(异步模型):刚刚交由TCP/IP协议站,刚刚往外发送时,就通告主机结束。

                2、B模型(半同步模型):数据报文发送到对方节点的TCP/IP协议站,就通告系统已经完成。

                3、C模型(同步模型):数据报文发到对方主机并且存储完成以后,才返回主节点同步完成。

DRBD Resources

        Include:

                Resource name(资源名称)

                        可以是除了空白字符外的任意ACSII码字符;

                DRBD device(资源设备)

                        双方节点上,此DRBD设备的设备文件,一般为/dev/drbdN,其主设备号IANA(147);

                Disk configuration(磁盘设备)

                        在双方节点上,各自提供的存储设备;

                Network configuration(网络配置)

                        双方数据同步时所使用的网络属性;

DRBD    administration tools(管理工具):

            drbdadm
                 The high level administration tool of the DRBD program suite                                                                          It obtains all DRBD configuration parameters from the configuration file /etc/drbd.conf                                 (/etc/drbd.d/)
            drbdsetup
                The program that allows users to configure the DRBD module that has been loaded into the run            ning kernel It is the low-level tool within the DRBD program suite 
                drbdmeta
                The program which allows users to create, dump, restore, and modify DRBD's meta data 

            structures

繁杂的概念我不知道我有木有解释清楚,接下来就跟我一起走进DRBD的配置吧!!!

       

DRBD配置:

         DRBD在Linux 2.6.33之前,需要对内核打补丁才能使用。而Red hat 5.8 kernel是2.6.18,所以首先需要给内核打补丁。

        节点之间同步时间:

                date [ntp server]

        配置主机名称,主机名称之间需要使用域名解析

                hostname node1.heartbeat.com

        使主机名开机以后不会失效:

                 echo "node1.heartbeat.com" > /etc/sysconfig/network

 

        配置第二个节点主机名称,主机名称之间需要使用域名解析 

                hostname node2.heartbeat.com

        使主机名开机以后不会失效:

                 echo "node2.heartbeat.com" > /etc/sysconfig/network

                

使用hosts文件解析对方节点:

            172.16.39.5     node1.heartbeat.com

            172.16.39.6     node2.heartbeat.com 

            在第二个节点做相同的配置

        使两个节点互信通信:

            ssh-keygen -f ~/.ssh/id_rsa -t rsa -P ' ' 
            ssh-copy-id -i .ssh/id_rsa.pub node2.heartbeat.com

            在第二个节点做相同的配置    

            ssh-keygen -f ~/.ssh/id_rsa -t rsa -P ' ' 
            ssh-copy-id -i .ssh/id_rsa.pub node1.heartbeat.com

  

安装补丁包:

        两个节点各自安装补丁包:     

                rpm -ivh drbd83-8.3.15-2.el5.centos.i386.rpm     kmod-drbd83-8.3.15-3.el5.centos.i686.rpm

        在两个节点分别划出两个分区:(做DRDB)

        DRBD的配置文件:

              /etc/drbd.conf

              /etc/drbd.d/global.common.conf

              /etc/drbd.d/resource.d/*  任何一个文件都是一个资源

        copy模板文件至主配置文件下:

             cp /usr/share/doc/drbd-8.3.15/drbd.conf  /etc/drbd.conf

配置global_common.conf

global {
        usage-count no;
        # minor-count dialog-refresh disable-ip-verification
}

common {
        protocol C;

        handlers {
                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";
                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";
                local-io-error "/usr/lib/drbd/notify-io-error.sh; /usr/lib/drbd/notify-emergency-shutdown.sh; echo o > /proc/sysrq-trigger ; halt -f";
                # fence-peer "/usr/lib/drbd/crm-fence-peer.sh";
                # split-brain "/usr/lib/drbd/notify-split-brain.sh root";
                # out-of-sync "/usr/lib/drbd/notify-out-of-sync.sh root";
                # before-resync-target "/usr/lib/drbd/snapshot-resync-target-lvm.sh -p 15 -- -c 16k";
                # after-resync-target /usr/lib/drbd/unsnapshot-resync-target-lvm.sh;
        }

        startup {
                #wfc-timeout 120;
                #degr-wfc-timeout 120;
        }

        disk {
                on-io-error detach;
                                #fencing resource-only;
        }

        net {
                                cram-hmac-alg "sha1";
                                shared-secret "mydrbdlab";
        }

        syncer {
                rate 1000M;
        }
}

        

定义一个资源/etc/drbd.d/web.res
resource web {
  on node1.heartbeat.com {
    device    /dev/drbd0;
    disk      /dev/sda5;
    address   172.16.100.11:7789;
    meta-disk internal;
  }
  on node2.heartbeat.com {
    device    /dev/drbd0;
    disk      /dev/sda5;
    address   172.16.100.12:7789;
    meta-disk internal;
  }
}

 

以上文件在两个节点上必须相同,因此,可以基于ssh将刚才配置的文件全部同步至另外一个节点。
# scp  /etc/drbd.*  node2:/etc

初始化资源,在Node1和Node2上分别执行:
# drbdadm create-md web

启动服务,在Node1和Node2上分别执行:
/etc/init.d/drbd start

 

查看启动状态:

 tail  -f /proc/drbd

而后再次查看状态,可以发现数据同步过程已经开始:
# drbd-overview 
  0:web  SyncSource Primary/Secondary UpToDate/Inconsistent C r---- 
    [============>.......] sync'ed: 66.2% (172140/505964)K delay_probe: 35

等数据同步完成以后再次查看状态,可以发现节点已经牌实时状态,且节点已经有了主次:
 drbd-overview 
  0:web  Connected Primary/Secondary UpToDate/UpToDate C r---- 

创建文件系统

文件系统的挂载只能在Primary节点进行,因此,也只有在设置了主节点后才能对drbd设备进行格式化:
 mke2fs -j -L DRBD /dev/drbd0
 mkdir /mnt/drbd 
mount /dev/drbd0 /mnt/drbd

切换Primary和Secondary节点

对主Primary/Secondary模型的drbd服务来讲,在某个时刻只能有一个节点为Primary,因此,要切换两个节点的角色,只能在先将原有的Primary节点设置为Secondary后,才能原来的Secondary节点设置为Primary:

Node1:
 cp -r /etc/drbd.* /mnt/drbd  
umount /mnt/drbd
drbdadm secondary web

查看状态:
 drbd-overview 
  0:web  Connected Secondary/Secondary UpToDate/UpToDate C r---- 

Node2:
 drbdadm primary web
 drbd-overview 
  0:web  Connected Primary/Secondary UpToDate/UpToDate C r---- 
 mkdir /mnt/drbd
mount /dev/drbd0 /mnt/drbd

使用下面的命令查看在此前在主节点上复制至此设备的文件是否存在:
 ls /mnt/drbd

 

 

 

                                                                                   时间原因:到此为止,有错误的地方请大家帮我改正...

                                                                                                                                                                        谢谢

 

 

 

 

 

 

 

本文出自 “小勇” 博客,谢绝转载!

你可能感兴趣的:(分布式存储,drbd)