1.安装所需软件:
yum –y install scsi-target-utils iscsi-initiator-utils
功能说明:scsi-target-utils:用来将 Linux 系统仿真成为 iSCSI target 的功能;
iscsi-initiator-utils:挂载来自 target 的磁盘到 Linux 本机上。
2.target的设定:
----target相关文件说明:
----以下几种设备都可作为target分享出去:使用 dd 指令所建立的大型档案可供仿真为磁盘 (无须预先格式化);
使用单一分割槽 (partition) 分享为磁盘;
使用单一完整的磁盘 (无须预先分割);
使用磁盘阵列分享 (其实与单一磁盘相同方式);
使用软件磁盘阵列 (software raid) 分享成单一磁盘;
使用 LVM 的 LV 装置分享为磁盘。
----建立一个名为 /tmp/iscsi.img 的 300MB 档案:
----iSCSI Qualified Name (iSCSI 合格名称):iqn.yyyy-mm.:identifier
iqn.年年-月.单位网域名的反转写法 :这个分享的target名称依据此名称设定我们的设备名称为:iqn.2013-06.com.example:luyx30----设定ISCSI的配置文件/etc/tgt/targets.conf相关说明:(引自鸟哥的linux私房菜)backing-store (虚拟的装置), direct-store (实际的装置): 设定装置时,如果你的整颗磁盘是全部被拿来当 iSCSI 分享之用,那么才能够使用 direct-store 。不过,根据网络上的其他文件, 似乎说明这个设定值有点危险的样子。所以,基本上还是建议单纯使用模拟的 backing-store 较佳。例如鸟哥的简单案例中,就通通使用 backing-store 而已。
initiator-address (用户端地址): 如果你想要限制能够使用这个 target 的客户端来源,才需要填写这个设定值。基本上,不用设定它 (代表所有人都能使用的意思), 因为我们后来会使用 iptables 来规范可以联机的客户端嘛!
incominguser (用户账号密码设定): 如果除了来源 IP 的限制之外,你还想要让使用者输入账密才能使用你的 iSCSI target 的话,那么就加用这个设定项目。 此设定后面接两个参数,分别是账号与密码啰。
write-cache [off|on] (是否使用快取): 在预设的情况下,tgtd 会使用快取来增快速度。不过,这样可能会有遗失数据的风险。所以,如果你的数据比较重要的话, 或许不要使用快取,直接存取装置会比较妥当一些。
----启动iscsi:
注意:若有开启防火墙功能,需要将端口3260开放.
3.initiator的设定:
----initiator相关文件说明:
/etc/iscsi/iscsid.conf:主要的配置文件,用来连结到 iSCSI target 的设定;
/sbin/iscsid:启动 iSCSI initiator 的主要服务程序;
/sbin/iscsiadm:用来管理 iSCSI initiator 的主要设定程序;
/etc/init.d/iscsid:让本机模拟成为 iSCSI initiater 的主要服务;
/etc/init.d/iscsi:在本机成为 iSCSI initiator 之后,启动此脚本,让我们可以登入 iSCSI target。所以 iscsid 先启动后,才能启动这个服务。为了防呆,所以 /etc/init.d/iscsi 已经写了一个启动指令, 启动 iscsi 前尚未启动 iscsid ,则会先呼叫 iscsid 才继续处理 iscsi .
----修改initiator的配置文件/etc/iscsi/iscsid.conf,新增以下部分:
----使用iscsiadm来发现target端的设备(记得服务器端防火墙要开放3260端口或关闭防火墙):
可侦测到相应的设备,若信息有修订过的话,那你可以到这个档案内修改,也可以透过 iscsiadm 的 update 功能处理相关参数的。
----连接到iscsi target:
----查看当前的磁盘文件,可发现target:
----iscsiadm的相关说明:
移除某个不要的target:
iscsiadm –m node –T targetname –logout
iscsiadm –m node –o [delete|new|update] –T targetname
4.到此,ISCSI的target和initiator的配置就完成了.在initiator可以向正常使用磁盘一样使用target.