分类: LINUX
2008-05-04 22:31:27
NBD(Network Block Device)让你可以将一个远程主机的磁盘空间,当作一个块设备来使用.就像一块硬盘一样.
使用它,你可以很方便的将另一台服务器的硬盘空间,增加到本地服务器上.
NBD与NFS有所不同.NFS只是提供一个挂载点供客户端使用,客户端无法改变这个挂载点的分区格式.
而NBD提供的是一个块设备,客户端可以把这个块设备格式化成各种类型的分区.更便于用户的使用.
NBD是一个内核模块,大部分Linux发行版都已包含它.
在Turbolinux的10以上的版本中,NBD已被编译成模块.保存在
/lib/modules/$version/kernel/driver/block/下.
你还需要在服务器端和客户端上安装nbd-server和nbd-client工具.
你可以从官方网站上下载源码包,并分别在服务器端和客户端服务器上进行安装:
我们这里下载nbd-2.8.8.tar.bz2
下载后,执行下列步骤进行安装:
# tar jxf nbd-2.8.8.tar.bz2 # cd nbd-2.8.8 # ./configure # make # make install
你需要先建立一个磁盘映像文件,作为提供给客户端使用的块设备.我们制作一个300MB的文件当做块设备. # cd /var/tmp # dd if=/dev/zero of=nbd-disk0 bs=104857600 count=3 启动nbd-server,监听1234端口,使用nbd-disk0映像文件. # nbd-server 1234 /var/tmp/nbd-disk0 查看nbd进程. # ps -ef | grep nbd root 11292 1 0 15:02 ? 00:00:00 nbd-server 1234 /var/tmp/nbd-disk0 nbd-server用法: nbd-server port file [size][kKmM] [-l authorize_file] [-r] [-m] [-c] [-a timeout_sec] port nbd-server监听端口. file 绑定的映像文件. size 在客户端所见的块设备大小(单位可以是: k,K,m,M). -r|--read-only 只读模式,客户端无法在块设备上进行写操作. -m|--multi-file 多个文件,可以将多个映像文件作为一个块设备提供给客户端. -c|--copy-on-write 所有客户端的写操作被会另存为一个文件,连接断开后,这个文件会被删除. 可以保证映像文件内容不会被修改. -l|--authorize-file file 一个允许访问此nbd的主机列表文件. -a|--idle-time 服务器断开与客户端连接前的最大空闲时间.
加载nbd模块. # modprobe nbd # lsmod | grep nbd nbd 26400 0 查看nbd设备是否建立. # ls /dev/nbd* -hl brw-r----- 1 root disk 43, 0 Jul 27 06:40 /dev/nbd0 brw-r----- 1 root disk 43, 1 Jul 27 06:40 /dev/nbd1 brw-r----- 1 root disk 43, 2 Jul 27 06:40 /dev/nbd2 brw-r----- 1 root disk 43, 3 Jul 27 06:40 /dev/nbd3 brw-r----- 1 root disk 43, 4 Jul 27 06:40 /dev/nbd4 brw-r----- 1 root disk 43, 5 Jul 27 06:40 /dev/nbd5 brw-r----- 1 root disk 43, 6 Jul 27 06:40 /dev/nbd6 brw-r----- 1 root disk 43, 7 Jul 27 06:40 /dev/nbd7 brw-r----- 1 root disk 43, 8 Jul 27 06:40 /dev/nbd8 brw-r----- 1 root disk 43, 9 Jul 27 06:40 /dev/nbd9 将/dev/nbd0设备与主机连接. # nbd-client 192.168.1.1 1234 /dev/nbd0 Negotiation: ..size = 307200KB bs=1024, sz=307200 nbd-client用法: nbd-client [bs=blocksize] host port nbd_device [-swap] bs 用于设置块大小,默认是1024,可以是512,1024.2048,4096 host 服务器的主机名或IP port 服务器的监听端口 nbd_device 映射到本地的哪个nbd设备(如: /dev/nbd0) -swap 指定nbd设备将用做swap空间 nbd-client -d nbd_device 用于断开连接 连接成功后,可以查看到nbd-client进程. # ps -ef | grep nbd root 3156 1 0 06:44 pts/0 00:00:00 nbd-client 192.168.1.1 1234 /dev/nbd0 使用前,需要格式化这个块设备. # mkfs.ext3 /dev/nbd0 mke2fs 1.39 (29-May-2006) Filesystem label= OS type: Linux Block size=1024 (log=0) Fragment size=1024 (log=0) 76912 inodes, 307200 blocks 15360 blocks (5.00%) reserved for the super user First data block=1 Maximum filesystem blocks=67633152 38 block groups 8192 blocks per group, 8192 fragments per group 2024 inodes per group Superblock backups stored on blocks: 8193, 24577, 40961, 57345, 73729, 204801, 221185 Writing inode tables: done Creating journal (8192 blocks): done Writing superblocks and filesystem accounting information: done This filesystem will be automatically checked every 39 mounts or 180 days, whichever comes first. Use tune2fs -c or -i to override. 挂载这个块设备. # mkdir /mnt/nbd0 # mount /dev/nbd0 /mnt/nbd0 # cd /mnt/nbd0 # ls lost+found 复制/root目录到这个目录中. # cp /root . -rf # ls lost+found root 断开这个块设备. # umount /mnt/nbd0/ # nbd-client -d /dev/nbd0 Disconnecting: que, disconnect, sock, done Kernel call returned: Broken pipeClosing: que, sock, done
# cd /var/tmp # dd if=/dev/zero of=nbd-disk1 bs=104857600 count=3 记录了 3+0 的读入 记录了 3+0 的写出 314572800 字节 (315 MB) 已复制,0.584027 秒,539 MB/秒 # dd if=/dev/zero of=nbd-disk2 bs=104857600 count=3 记录了 3+0 的读入 记录了 3+0 的写出 314572800 字节 (315 MB) 已复制,1.5128 秒,208 MB/秒 # nbd-server 1234 /var/tmp/nbd-disk1 # nbd-server 1235 /var/tmp/nbd-disk1 # nbd-server 1236 /var/tmp/nbd-disk2 # ps -ef | grep nbd root 11292 1 0 15:02 ? 00:00:00 nbd-server 1234 /var/tmp/nbd-disk0 root 11599 1 0 15:14 ? 00:00:00 nbd-server 1235 /var/tmp/nbd-disk1 root 11606 1 0 15:14 ? 00:00:00 nbd-server 1236 /var/tmp/nbd-disk2
# lsmod | grep nbd nbd 24736 0 # ls /dev/nbd* /dev/nbd0 /dev/nbd11 /dev/nbd14 /dev/nbd3 /dev/nbd6 /dev/nbd9 /dev/nbd1 /dev/nbd12 /dev/nbd15 /dev/nbd4 /dev/nbd7 /dev/nbd10 /dev/nbd13 /dev/nbd2 /dev/nbd5 /dev/nbd8 # nbd-client 192.168.1.1 1234 /dev/nbd0 Negotiation: ..size = 307200KB bs=1024, sz=307200 # nbd-client 192.168.1.1 1235 /dev/nbd1 Negotiation: ..size = 307200KB bs=1024, sz=307200 # nbd-client 192.168.1.1 1236 /dev/nbd2 Negotiation: ..size = 307200KB bs=1024, sz=307200 将nbd1格式化为vfat格式. # mkfs.vfat /dev/nbd1 mkfs.vfat 2.11 (12 Mar 2005) unable to get drive geometry, using default 255/63 将nbd2格式化为ext2格式. # mkfs.ext2 /dev/nbd2 mke2fs 1.39 (29-May-2006) Filesystem label= OS type: Linux Block size=1024 (log=0) Fragment size=1024 (log=0) 76912 inodes, 307200 blocks 15360 blocks (5.00%) reserved for the super user First data block=1 Maximum filesystem blocks=67633152 38 block groups 8192 blocks per group, 8192 fragments per group 2024 inodes per group Superblock backups stored on blocks: 8193, 24577, 40961, 57345, 73729, 204801, 221185 Writing inode tables: done Writing superblocks and filesystem accounting information: done This filesystem will be automatically checked every 21 mounts or 180 days, whichever comes first. Use tune2fs -c or -i to override. 挂载这3个块设备 # cd /mnt # mkdir nbd1 nbd2 # mount /dev/nbd0 nbd0 # mount /dev/nbd1 nbd1 # mount /dev/nbd2 nbd2 # df -h Filesystem Size Used Avail Use% Mounted on /dev/nbd0 291M 11M 265M 4% /mnt/nbd0 /dev/nbd1 300M 0 300M 0% /mnt/nbd1 /dev/nbd2 291M 2.1M 274M 1% /mnt/nbd2 # mount /dev/nbd0 on /mnt/nbd0 type ext3 (rw) /dev/nbd1 on /mnt/nbd1 type vfat (rw) /dev/nbd2 on /mnt/nbd2 type ext2 (rw)