您的位置:首页 > 其它

在RHEL5系统中搭建iSCSI存储服务器

2011-08-04 22:14 525 查看
在RHEL5系统中搭建iSCSI存储服务器

2010.09.18 TsengYia#126.com http://selinux.cublog.cn
###################################################################

系统环境:RHEL5.5 [2.6.18-194.el5]

软件环境(使用RHEL5.5光盘自带的RPM包):

服务器:

ClusterStorage/scsi-target-utils-0.0.6.20091205snap.el5_.1.i386.rpm

ClusterStorage/perl-Config-General-2.40-1.el5.noarch.rpm

Server/libibverbs-1.1.3-2.el5.i386.rpm

Server/openib-1.4.1-5.el5.noarch.rpm

Server/librdmacm-1.0.10-1.el5.i386.rpm

Server/libcxgb3-1.2.5-2.el5.i386.rpm

客户端:

Server/iscsi-initiator-utils-6.2.0.871-0.16.el5.i386.rpm

—— 需要注意:

1. scsi-target-utils包文件在RHEL5.0光盘中没有,好像从RHEL5.1开始才有。如果要下载源码包,可以从http://iscsitarget.sourceforge.net获得。

2. libibverbs包的安装依赖于libibverbs-driver,可以通过安装libcxgb3包(或者libmthca、libmlx4、libnes,其中任何一个都可以)获得,否则可能出现报错:

error: Failed dependencies:

libibverbs-driver is needed by libibverbs-1.1.3-2.el5.i386

###################################################################

一、配置存储服务器端 (iSCSI Target)

主机名:host1

IP地址:192.168.4.77

1. 安装scsi-target-utils相关软件包

[root@host1 ~]# mount /dev/cdrom /media/cdrom

[root@host1 ~]# cd /media/cdrom

[root@host1 cdrom]# rpm -ivh ClusterStorage/perl-Config-General-2.40-1.el5.noarch.rpm \

> ClusterStorage/scsi-target-utils-0.0.6.20091205snap.el5_.1.i386.rpm \

> Server/libibverbs-1.1.3-2.el5.i386.rpm \

> Server/openib-1.4.1-5.el5.noarch.rpm \

> Server/librdmacm-1.0.10-1.el5.i386.rpm \

> Server/libcxgb3-1.2.5-2.el5.i386.rpm
—— 服务器端配置过程可参考 /usr/share/doc/scsi-target-utils-0.0/README.iscsi 文件,命令行主要管理工具为tgtadm,系统服务为tgtd。

2. 创建要输出的存储Target

1) 启动tgtd服务 (Target Daemon)

[root@host1 ~]# service tgtd start

Starting SCSI target daemon: Starting target framework daemon

[root@host1 ~]# chkconfig --level 35 tgtd on

2) 定义两个target (给不同的客户机使用)

[root@host1 ~]# tgtadm --lld iscsi --op new --mode target --tid 1 --targetname iqn.2010-
09.cn.cnblog.selinux:target1.raid10.host1

[root@host1 ~]# tgtadm --lld iscsi --op new --mode target --tid 2 --targetname iqn.2010-
09.cn.cnblog.selinux:target2.disk6.host1
—— 其中“iqn.2010-09......”用于指定符合iSCSi规范的target名称,格式为“iqn.YYYY-mm.反向域名:识别标记”

3) 确认新定义的target信息,默认每个target中自动创建lun 0 (不可移除)

[root@host1 ~]# tgtadm --lld iscsi --op show --mode target

Target 1: iqn.2010-09.cn.cnblog.selinux:target1.raid10.host1

System information:

Driver: iscsi

State: ready

I_T nexus information:

LUN information:

LUN: 0

Type: controller

SCSI ID: IET 00010000

SCSI SN: beaf10

Size: 0MB

Online: Yes

Removable media: No

Backing store type: rdwr

Backing store path: None

Account information:

ACL information:

Target 2: iqn.2010-09.cn.cnblog.selinux:target2.disk6.host1

System information:

Driver: iscsi

……

3. 划分lun (Logical Unit)

在同一个Target中,可以划分多个lun,每个lun可以使用服务器端的RAID阵列、单个磁盘、分区、LVM或文件来充当。如果使用独立的整个
磁盘作为lun分配给客户机,则映射到客户端后仍然是整个磁盘,客户端可以直接使用原有磁盘中的文件系统。反之,如果使用一个磁盘阵列、
分区或文件作为lun分配给客户机,则映射到客户端后需要重新分区、格式化方可使用,原有数据无法保留。

下面的操作把一个RAID10阵列划分给Target1中的lun 1,把一块单独的SCSI磁盘划分给Target2中的lun 1,分别给不同的客户机使用。

1) 创建RAID10磁盘阵列 (软RAID,使用四块SCSI磁盘)

[root@host1 ~]# mdadm --create --verbose /dev/md0 --auto yes --raid-devices=4 --level=10 /dev/sd[b-e]

mdadm: layout defaults to n1

mdadm: chunk size defaults to 64K

mdadm: size set to 8388544K

mdadm: array /dev/md0 started

[root@host1 ~]# ls -l /dev/md0 #//确认新建的阵列设备文件

brw-r----- 1 root disk 9, 0 09-18 08:43 /dev/md0

[root@host1 ~]# mdadm --detail --scan --verbose #//确认阵列信息

ARRAY /dev/md0 level=raid10 num-devices=4 metadata=0.90

UUID=90e8eb47:420a08e7:e9b43c55:2600513

devices=/dev/sdb,/dev/sdc,/dev/sdd,/dev/sde

[root@host1 ~]# cat /proc/mdstat #//查看阵列状态

Personalities : [raid10]

md0 : active raid10 sde[3] sdd[2] sdc[1] sdb[0]

16777088 blocks 64K chunks 2 near-copies [4/4] [UUUU]

unused devices: <none>

2) 将/dev/md0划分给Target1中的lun 1,指定客户机192.168.4.99可以使用

[root@host1 ~]# tgtadm --lld iscsi --op new --mode logicalunit --tid 1 --lun 1 --backing-store /dev/md0

[root@host1 ~]# tgtadm --lld iscsi --op bind --mode target --tid 1 --initiator-address 192.168.4.99

3) 将/dev/sdf划分给Target2中的lun 1,指定客户机192.168.4.88可以使用

[root@host1 ~]# tgtadm --lld iscsi --op new --mode logicalunit --tid 2 --lun 1 --backing-store /dev/sdf

[root@host1 ~]# tgtadm --lld iscsi --op bind --mode target --tid 2 --initiator-address 192.168.4.88

4) 再次查看target信息,确认分配的lun信息

[root@host1 ~]# tgtadm --lld iscsi --op show --mode target

Target 1: iqn.2010-09.cn.cnblog.selinux:target1.raid10.host1

……

LUN: 1 #//Target1中的lun 1信息

Type: disk

SCSI ID: IET 00010001

SCSI SN: beaf11

Size: 17180MB

Online: Yes

Removable media: No

Backing store type: rdwr

Backing store path: /dev/md0

Account information:

ACL information:

192.168.4.99

Target 2: iqn.2010-09.cn.cnblog.selinux:target2.disk6.host1

……

LUN: 1 #//Target2中的lun 1信息

Type: disk

SCSI ID: IET 00020001

SCSI SN: beaf21

Size: 17180MB

Online: Yes

Removable media: No

Backing store type: rdwr

Backing store path: /dev/sdf

Account information:

ACL information:

192.168.4.88

4. 修改配置文件,保存上述关键配置
[root@host1 ~]# vi /etc/tgt/targets.conf

default-driver iscsi

<target iqn.2010-09.cn.cnblog.selinux:target1.raid10.host1>

backing-store /dev/md0

initiator-address 192.168.4.99

</target>

<target iqn.2010-09.cn.cnblog.selinux:target2.disk6.host1>

backing-store /dev/sdf

initiator-address 192.168.4.88

</target>

二、配置存储客户端 (iSCSI Initiator)

主机名:host2

IP地址:192.168.4.99

主机名:host3

IP地址:192.168.4.88

—— 存储客户端的配置使用基本类似,以下仅以host2为例。

1. 安装iscsi-intiator-utils软件包
[root@host2 ~]# mount /dev/cdrom /media/cdrom

[root@host2 ~]# cd /media/cdrom/Server

[root@host2 Server]# rpm -ivh iscsi-initiator-utils-6.2.0.871-0.16.el5.i386.rpm

—— 客户端配置过程可参考 /usr/share/doc/iscsi-initiator-utils-6.2.0-871/README 文件,命令行主要管理工具为iscsiadm,系统服务为iscsi。

2. 查找iSCSI服务器端提供的Target信息
[root@host2 ~]# chkconfig --level 35 iscsi on

[root@host2 ~]# service iscsi start

[root@host2 ~]# iscsiadm --mode discovery --type sendtargets --portal 192.168.4.77

192.168.4.77:3260,1 iqn.2010-09.cn.cnblog.selinux:target1.raid10.host1

3. 登陆到iSCSI服务器端提供的Target
[root@host2 ~]# iscsiadm --mode node --portal 192.168.4.77 --targetname iqn.2010-09.cn.cnblog.selinux:target1.raid10.host1 -
-login

Logging in to [iface:default, target:iqn.2010-09.cn.cnblog.selinux:target1.raid10.host1, portal:192.168.4.77,3260]

Login to [iface:default, target:iqn.2010-09.cn.cnblog.selinux:target1.raid10.host1, portal:192.168.4.77,3260]: successful
[root@host2 ~]# lsscsi #//确认已连接(新增)的iSCSI磁盘设备(原来已有一块SCSI磁盘,因此这里新增的为/dev/sdb)

……

[1:0:0:0] storage IET Controller 0001 -

[1:0:0:1] disk IET VIRUAL-DISK 0001 /dev/sdb
[root@host2 ~]# sfdisk -s

……

/dev/sdb: 16777088

total: 33554304 blocks

4. 分区、格式化iSCSI磁盘设备,并挂载使用

若Target端分配的lun是独立的磁盘,且已包含有分区和文件系统则在initiator端无需再次分区、格式化。
[root@host2 ~]# fdisk /dev/sdb #//划分一个sdb1分区,过程略

[root@host2 ~]# partprobe /dev/sdb

[root@host2 ~]# mkfs -t ext3 /dev/sdb1

[root@host2 ~]# mkdir /media/iscsi

[root@host2 ~]# vi /etc/fstab

……

/dev/sdb1 /media/iscsi ext3 _netdev 0 0

[root@host2 ~]# mount /media/iscsi

[root@host2 ~]# mount | grep iscsi #//查看挂载情况

/dev/sdb1 on /media/iscsi type ext3 (rw,_netdev)

5. 确认生成的配置文件
[root@host2 ~]# cd /var/lib/iscsi/nodes/

[root@host2 ~]# cat iqn.2010-09.cn.cnblog.selinux\:target1.raid10.host1/192.169.4.77\,3260\,1/default

# BEGIN RECORD 2.0-871

node.name = iqn.2010-09.cn.cnblog.selinux:target1.raid10.host1

node.tpgt = 1

node.startup = automatic

iface.iscsi_ifacename = default

iface.transport_name = tcp

node.discovery_address= 192.168.4.77

node.discovery_port = 3260

node.discovery_type = send_targets

……

三、iSCSI存储服务器的用户验证 (可选)
1. 服务器端(Target)设置,以Target1为例

1) 方法一:

[root@host1 ~]# tgtadm --lld iscsi --op new --mode account --user tsengyia --password
pwd@123

[root@host1 ~]# tgtadm --lld iscsi --op bind --mode account --tid 1 --user tsengyia

[root@host1 ~]# tgtadm --lld iscsi --op show --mode target

Target 1: iqn.2010-09.cn.cnblog.selinux:target1.raid10.host1 #//确认Target1的认证用户信息

……

Account information:

tsengyia

ACL information:

192.168.4.99

2) 方法二:

[root@host1 ~]# vi /etc/tgt/targets.conf

default-driver iscsi

<target iqn.2010-09.cn.cnblog.selinux:target1.raid10.host1>

backing-store /dev/md0

incominguser tsengyia pwd@123

initiator-address 192.168.4.99

</target>

……

[root@host1 ~]# service tgtd restart #//注意先将所有Initiator端断开连接

2. 客户端(Intiator)设置,以Host2中为例
[root@host2 ~]# cd /var/lib/iscsi/nodes/

[root@host2 ~]# vi iqn.2010-09.cn.cnblog.selinux\:target1.raid10.host1/192.169.4.77\,3260\,1/default

# BEGIN RECORD 2.0-871

node.name = iqn.2010-09.cn.cnblog.selinux:target1.raid10.host1

node.tpgt = 1

node.startup = automatic

iface.iscsi_ifacename = default

iface.transport_name = tcp

node.discovery_address= 192.168.4.77

node.discovery_port = 3260

node.discovery_type = send_targets

……

node.session.auth.authmethod = CHAP #//默认为None,不使用认证

node.session.auth.username = tsengyia

node.session.auth.password = pwd@123

……

[root@host2 ~]# service iscsi restart
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: