18.3 iSCSI initiator 的设定

谈完了 target 的设定,并且观察到相关 target 的 LUN 数据后,接下来就是要来挂载使用啰。使用的方法很简单, 只不过我们得要安装额外的软件来取得 target 的 LUN 使用权就是了。


18.3.1 所需软件与软件结构

在前一小节就谈过了,要设定 iSCSI initiator 必须要安装 iscsi-initiator-utils 才行。安装的方法请使用 yum 去处理,这里不再多讲话。那么这个软件的结构是如何呢?

  • /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 喔!
    老实说,因为 /etc/init.d/iscsi 脚本已经包含了启动 /etc/init.d/iscsid 的步骤在里面,所以,理论上, 你只要启动 iscsi 就好啦!此外,那个 iscsid.conf 里面大概只要设定好登入 target 时的帐密即可, 其他的 target 搜寻、设定、取得的方法都直接使用 iscsiadm 这个指令来完成。由于 iscsiadm 侦测到的结果会直接写入 /var/lib/iscsi/nodes/ 当中,因此只要启动 /etc/init.d/iscsi 就能够在下次开机时,自动的连结到正确的 target 啰。 那么就让我们来处理处理整个过程吧 (注6)!

18.3.2 initiator 的实际设定

首先,我们得要知道 target 提供了啥咚咚啊,因此,理论上,不论是 target 还是 initiator 都应该是要我们管理的机器才对。 而现在我们知道 target 其实有设定账号与密码的,所以底下我们就得要修改一下 iscsid.conf 的内容才行。

  • 修改 /etc/iscsi/iscsid.conf 内容,并启动 iscsi
    这个档案的修改很简单,因为里面的参数大多已经预设做的不错了,所以只要填写 target 登入时所需要的帐密即可。 修改的地方有两个,一个是侦测时 (discovery) 可能会用到的帐密,一个是联机时 (node) 会用到的帐密:
  1. [root@clientlinux ~]# vim /etc/iscsi/iscsid.conf
  2. node.session.auth.username = vbirduser <==在 target 时设定的
  3. node.session.auth.password = vbirdpasswd <==约在 53, 54
  4. discovery.sendtargets.auth.username = vbirduser <==约在 67, 68
  5. discovery.sendtargets.auth.password = vbirdpasswd
  6. [root@clientlinux ~]# chkconfig iscsid on
  7. [root@clientlinux ~]# chkconfig iscsi on

由于我们尚未与 target 联机,所以 iscsi 并无法让我们顺利启动的!因此上面只要 chkconfig 即可,不需要启动他。 要开始来侦测 target 与写入系统信息啰。全部使用 iscsiadm 这个指令就可以完成所有动作了。

  • 侦测 192.168.100.254 这部 target 的相关数据
    虽然我们已经知道 target 的名字,不过,这里假设还不知道啦!因为有可能哪一天你的公司有钱了, 会去买实体的 iSCSI 数组嘛!所以这里还是讲完整的侦测过程好了!你可以这样使用:
  1. [root@clientlinux ~]# iscsiadm -m discovery -t sendtargets -p IP:port
  2. 选项与参数:
  3. -m discovery :使用侦测的方式进行 iscsiadmin 指令功能;
  4. -t sendtargets :透过 iscsi 的协议,侦测后面的设备所拥有的 target 数据
  5. -p IP:port :就是那部 iscsi 设备的 IP 与埠口,不写埠口预设是 3260 啰!
  6. 范例:侦测 192.168.100.254 这部 iSCSI 设备的相关数据
  7. [root@clientlinux ~]# iscsiadm -m discovery -t sendtargets -p 192.168.100.254
  8. 192.168.100.254:3260,1 iqn.2011-08.vbird.centos:vbirddisk
  9. # 192.168.100.254:3260,1 :在此 IP, 端口上面的 target 号码,本例中为 target1
  10. # iqn.2011-08.vbird.centos:vbirddisk :就是我们的 target 名称啊!
  11. [root@clientlinux ~]# ll -R /var/lib/iscsi/nodes/
  12. /var/lib/iscsi/nodes/iqn.2011-08.vbird.centos:vbirddisk
  13. /var/lib/iscsi/nodes/iqn.2011-08.vbird.centos:vbirddisk/192.168.100.254,3260,1
  14. # 上面的特殊字体部分,就是我们利用 iscsiadm 侦测到的 target 结果!

现在我们知道了 target 的名称,同时将所有侦测到的信息通通写入到上述 /var/lib/iscsi/nodes/iqn.2011-08.vbird.centos:vbirddisk/192.168.100.254,3260,1 目录内的 default 档案中, 若信息有修订过的话,那你可以到这个档案内修改,也可以透过 iscsiadm 的 update 功能处理相关参数的。

  • 开始进行联机 iSCSI target
    因为我们的 initiator 可能会连接多部的 target 设备,因此,我们得先要瞧瞧目前系统上面侦测到的 target 有几部, 然后再找到我们要的那部 target 来进行登入的作业。不过,如果你想要将所有侦测到的 target 全部都登入的话, 那么整个步骤可以再简化:
  1. 范例:根据前一个步骤侦测到的资料,启动全部的 target
  2. [root@clientlinux ~]# /etc/init.d/iscsi restart
  3. 正在停止 iscsi [ 确定 ]
  4. 正在激活 iscsi [ 确定 ]
  5. # 将系统里面全部的 target 通通以 /var/lib/iscs/nodes/ 内的设定登入
  6. # 上面的特殊字体比较需要注意啦!你只要做到这里即可,底下的瞧瞧就好。
  7. 范例:显示出目前系统上面所有的 target 数据:
  8. [root@clientlinux ~]# iscsiadm -m node
  9. 192.168.100.254:3260,1 iqn.2011-08.vbird.centos:vbirddisk
  10. 选项与参数:
  11. -m node:找出目前本机上面所有侦测到的 target 信息,可能并未登入喔
  12. 范例:仅登入某部 target ,不要重新启动 iscsi 服务
  13. [root@clientlinux ~]# iscsiadm -m node -T target名称 --login
  14. 选项与参数:
  15. -T target名称:仅使用后面接的那部 target target 名称可用上个指令查到!
  16. --login :就是登入啊!
  17. [root@clientlinux ~]# iscsiadm -m node -T iqn.2011-08.vbird.centos:vbirddisk \
  18. > --login
  19. # 这次进行会出现错误,是因为我们已经登入了,不可重复登入喔!

接下来呢?呵呵!很棒的是,我们要来开始处理这个 iSCSI 的磁盘了喔!怎么处理?瞧一瞧!

  1. [root@clientlinux ~]# fdisk -l
  2. Disk /dev/sda: 8589 MB, 8589934592 bytes <==这是原有的那颗磁盘,略过不看
  3. ....(中间省略)....
  4. Disk /dev/sdc: 2147 MB, 2147483648 bytes
  5. 67 heads, 62 sectors/track, 1009 cylinders
  6. Units = cylinders of 4154 * 512 = 2126848 bytes
  7. Sector size (logical/physical): 512 bytes / 512 bytes
  8. Disk /dev/sdb: 2154 MB, 2154991104 bytes
  9. 67 heads, 62 sectors/track, 1013 cylinders
  10. Units = cylinders of 4154 * 512 = 2126848 bytes
  11. Sector size (logical/physical): 512 bytes / 512 bytes
  12. Disk /dev/sdd: 524 MB, 524288000 bytes
  13. 17 heads, 59 sectors/track, 1020 cylinders
  14. Units = cylinders of 1003 * 512 = 513536 bytes
  15. Sector size (logical/physical): 512 bytes / 512 bytes

你会发现主机上面多出了三个新的磁盘,容量与刚刚在 192.168.100.254 那部 iSCSI target 上面分享的 LUN 一样大。 那这三颗磁盘可以怎么用?你想怎么用就怎么用啊!只是,唯一要注意的,就是 iSCSI target 每次都要比 iSCSI initiator 这部主机还要早开机,否则我们的 initiator 恐怕就会出问题。

  • 更新/删除/新增 target 数据的方法
    如果你的 iSCSI target 可能因为某些原因被拿走了,或者是已经不存在于你的区网中,或者是要送修了~ 这个时候你的 iSCSI initiator 总是得要关闭吧!但是,又不能全部关掉 (/etc/init.d/iscsi stop), 因为还有其他的 iSCSI target 在使用。这个时候该如何取消不要的 target 呢?很简单!流程如下:
  1. [root@clientlinux ~]# iscsiadm -m node -T targetname --logout
  2. [root@clientlinux ~]# iscsiadm -m node -o [delete|new|update] -T targetname
  3. 选项与参数:
  4. --logout :就是注销 target,但是并没有删除 /var/lib/iscsi/nodes/ 内的数据
  5. -o delete:删除后面接的那部 target 链接信息 (/var/lib/iscsi/nodes/*)
  6. -o update:更新相关的信息
  7. -o new :增加一个新的 target 信息。
  8. 范例:关闭来自鸟哥的 iSCSI target 的数据,并且移除链接
  9. [root@clientlinux ~]# iscsiadm -m node <==还是先秀出相关的 target iqn 名称
  10. 192.168.100.254:3260,1 iqn.2011-08.vbird.centos:vbirddisk
  11. [root@clientlinux ~]# iscsiadm -m node -T <u>iqn.2011-08.vbird.centos:vbirddisk</u> \
  12. > --logout
  13. Logging out of session [sid: 1, target: iqn.2011-08.vbird.centos:vbirddisk,
  14. portal: 192.168.100.254,3260]
  15. Logout of [sid: 1, target: iqn.2011-08.vbird.centos:vbirddisk, portal:
  16. 192.168.100.254,3260] successful.
  17. # 这个时候的 target 连结还是存在的,虽然注销你还是看的到!
  18. [root@clientlinux ~]# iscsiadm -m node -o delete \
  19. > -T iqn.2011-08.vbird.centos:vbirddisk
  20. [root@clientlinux ~]# iscsiadm -m node
  21. iscsiadm: no records found! <==嘿嘿!不存在这个 target 了~
  22. [root@clientlinux ~]# /etc/init.d/iscsi restart
  23. # 你会发现唔!怎么 target 的信息不见了!这样瞭了乎!

如果一切都没有问题,现在,请回到 discovery 的过程,重新再将 iSCSI target 侦测一次,再重新启动 initiator 来取得那三个磁盘吧!我们要来测试与利用该磁盘啰!


18.3.3 一个测试范例

到底 iSCSI 可以怎么用?我们就来玩一玩。假设:

  • 你刚刚如同鸟哥的整个运作流程,已经在 initiator 上面将 target 数据清除了;
  • 现在我们只知道 iSCSI target 的 IP 是 192.168.100.254 ,而需要的帐密是 vbirduser, vbirdpasswd;
  • 帐密信息你已经写入 /etc/iscsi/iscsid.conf 里面了;
  • 假设我们预计要将 target 的磁盘拿来当作 LVM 内的 PV 使用;
  • 并且将所有的磁盘容量都给一个名为 /dev/iscsi/disk 的 LV 使用;
  • 这个 LV 会被格式化为 ext4 ,且挂载在 /data/iscsi 内。
    那么,整体的流程是:
  1. # 1\. 启动 iscsi ,并且开始侦测及登入 192.168.100.254 上面的 target 名称
  2. [root@clientlinux ~]# /etc/init.d/iscsi restart
  3. [root@clientlinux ~]# chkconfig iscsi on
  4. [root@clientlinux ~]# iscsiadm -m discovery -t sendtargets -p 192.168.100.254
  5. [root@clientlinux ~]# /etc/init.d/iscsi restart
  6. [root@clientlinux ~]# iscsiadm -m node
  7. 192.168.100.254:3260,1 iqn.2011-08.vbird.centos:vbirddisk
  8. # 2\. 开始处理 LVM 的流程,由 PV, VG, LV 依序处理喔!
  9. [root@clientlinux ~]# fdisk -l <==出现的资料中你会发现 /dev/sd[b-d]
  10. [root@clientlinux ~]# pvcreate /dev/sd{b,c,d} <==建立 PV 去!
  11. Wiping swap signature on /dev/sdb
  12. Physical volume "/dev/sdb" successfully created
  13. Physical volume "/dev/sdc" successfully created
  14. Physical volume "/dev/sdd" successfully created
  15. [root@clientlinux ~]# vgcreate iscsi /dev/sd{b,c,d} <==建立 VG 去!
  16. Volume group "iscsi" successfully created
  17. [root@clientlinux ~]# vgdisplay <==要找到可用的容量啰!
  18. --- Volume group ---
  19. VG Name iscsi
  20. ....(中间省略)....
  21. Act PV 3
  22. VG Size 4.48 GiB
  23. PE Size 4.00 MiB
  24. Total PE 1148 <==就是这玩意儿!共 1148 个!
  25. Alloc PE / Size 0 / 0
  26. Free PE / Size 1148 / 4.48 GiB
  27. ....(底下省略)....
  28. [root@clientlinux ~]# lvcreate -l 1148 -n disk iscsi
  29. Logical volume "disk" created
  30. [root@clientlinux ~]# lvdisplay
  31. --- Logical volume ---
  32. LV Name /dev/iscsi/disk
  33. VG Name iscsi
  34. LV UUID opR64B-Zeoe-C58n-ipN2-em3O-nUYs-wjEZDP
  35. LV Write Access read/write
  36. LV Status available
  37. # open 0
  38. LV Size 4.48 GiB <==注意一下容量对不对啊!
  39. Current LE 1148
  40. Segments 3
  41. Allocation inherit
  42. Read ahead sectors auto
  43. - currently set to 256
  44. Block device 253:2
  45. # 3\. 开始格式化,并且进行开机自动挂载的动作!
  46. [root@clientlinux ~]# mkfs -t ext4 /dev/iscsi/disk
  47. [root@clientlinux ~]# mkdir -p /data/iscsi
  48. [root@clientlinux ~]# vim /etc/fstab
  49. /dev/iscsi/disk /data/iscsi ext4 defaults,_netdev 1 2
  50. [root@clientlinux ~]# mount -a
  51. [root@clientlinux ~]# df -Th
  52. 文件系统 类型 Size Used Avail Use% 挂载点
  53. /dev/mapper/iscsi-disk
  54. ext4 4.5G 137M 4.1G 4% /data/iscsi

比较特殊的是 /etc/fstab 里面的第四个字段,加上 netdev (最前面是底线) 指的是,因为这个 partition 位于网络上, 所以得要网络开机启动完成后才会挂载的意思。现在,请让你的 iSCSI initiator 重新启动看看, 试看看重新启动系统后,你的 /data/iscsi 是否还存在呢? ^^

然后,让我们切回 iSCSI target 那部主机,研究看看到底谁有使用我们的 target 呢?

  1. [root@www ~]# tgt-admin --show
  2. Target 1: iqn.2011-08.vbird.centos:vbirddisk
  3. System information:
  4. Driver: iscsi
  5. State: ready
  6. I_T nexus information:
  7. I_T nexus: 2
  8. Initiator: iqn.1994-05.com.redhat:71cf137f58f2 <==不是很喜欢的名字!
  9. Connection: 0
  10. IP Address: 192.168.100.10 <==就是这里联机进来啰!
  11. LUN information:
  12. ....(后面省略)....

明明是 initiator 怎么会是那个 redhat 的名字呢?如果你不介意那就算了,如果挺介意的话,那么修改 initiator 那部主机的 /etc/iscsi/initiatorname.iscsi 这个档案的内容,将它变成类似如下的模样即可:

Tips: 不过,这个动作最好在使用 target 的 LUN 之前就进行,否则,当你使用了 LUN 的磁盘后,再修改这个档案后, 你的磁盘文件名可能会改变。例如鸟哥的案例中,改过 initiatorname 之后,原本的磁盘文件名竟变成 /dev/sd[efg] 了!害鸟哥的 LV 就不能再度使用了…

22.3. 18.3 iSCSI initiator 的设定  - 图1

  1. # 1\. 先在 iSCSI initiator 上面进行如下动作:
  2. [root@clientlinux ~]# vim /etc/iscsi/initiatorname.iscsi
  3. InitiatorName=iqn.2011-08.vbird.centos:initiator
  4. [root@clientlinux ~]# /etc/init.d/iscsi restart
  5. # 2\. 在 iSCSI target 上面就可以发现如下的数据修订了:
  6. [root@www ~]# tgt-admin --show
  7. Target 1: iqn.2011-08.vbird.centos:vbirddisk
  8. System information:
  9. Driver: iscsi
  10. State: ready
  11. I_T nexus information:
  12. I_T nexus: 5
  13. Initiator: iqn.2011-08.vbird.centos:initiator
  14. Connection: 0
  15. IP Address: 192.168.100.10
  16. ....(后面省略)....

原文: https://wizardforcel.gitbooks.io/vbird-linux-server-3e/content/133.html