【RHEL 7】iSCSI ターゲットおよびイニシエーターの設定手順

インフラサーバ

はじめに

  • iSCSI ターゲットとは
    • iSCSI におけるストレージ
  • iSCSI イニシエーターとは
    • iSCSI ターゲットを使用するホスト

Linux マシンを iSCSI ターゲット、または iSCSI イニシエーターとして使用できるように設定することができます。

ここでは Red Hat Enterprise Linux 7.3 マシンを使用して、 iSCSI ターゲットと設定する手順、および iSCSI イニシエーターと設定する手順について記載します。

パッケージのインストールとサービス起動

iSCSI ターゲット側

パッケージのインストール

iSCSI ターゲット用のパッケージは targetcli です。

yum install -y targetcli

サービスの起動と有効化

systemctl start target
systemctl enable target

iSCSI イニシエーター側

パッケージのインストール

iSCSI イニシエーター用のパッケージは iscsi-initiator-utils です。

yum install -y iscsi-initiator-utils

サービスの起動と有効化

iscsidiscsi の 2 つのサービスがあります。

systemctl start iscsid
systemctl enable iscsid

systemctl start iscsi
systemctl enable iscsi

IQN 確認

iSCSI ターゲットで、接続を許可する iSCSI イニシエーターを設定します(ACL 設定)が、その設定の際に iSCSI イニシエーターの IQN (iSCSI Qualified Name、iSCSI における識別名) を使用します。そのため iSCSI イニシエーターの IQN を確認しておきます。

iSCSI イニシエーターの IQN は /etc/iscsi/initiatorname.iscsi に記載されています。

# cat /etc/iscsi/initiatorname.iscsi
InitiatorName=iqn.1994-05.com.redhat:a8801395d31a

iSCSI ターゲットの設定

設定は targetcli コマンドで行います。主な設定項目は以下の通りです。

  • ブロックデバイス(公開するディスク)
  • IQN
  • ブロックデバイスと IQN の対応付け
  • ACL(接続を許可するクライントの指定)

targetcli ls コマンドで設定状況を確認できます。

# targetcli ls
Warning: Could not load preferences file /root/.targetcli/prefs.bin.
o- / .......................................................................................................... [...]
  o- backstores ............................................................................................... [...]
  | o- block ................................................................................... [Storage Objects: 0]
  | o- fileio .................................................................................. [Storage Objects: 0]
  | o- pscsi ................................................................................... [Storage Objects: 0]
  | o- ramdisk ................................................................................. [Storage Objects: 0]
  o- iscsi ............................................................................................. [Targets: 0]
  o- loopback .......................................................................................... [Targets: 0]

ブロックデバイスの設定

設定コマンドのフォーマットは以下の通りです。

  • targetcli /backstores/block create name=デバイス名 dev=論理ボリューム名
# targetcli /backstores/block create name=lun0 dev=/dev/VolGroup01/LogVol00
Created block storage object lun0 using /dev/VolGroup01/LogVol00.

IQN の設定

設定コマンドのフォーマットは以下の通りです。

  • targetcli /iscsi create IQN
    • IQN のフォーマットは iqn.yyyy-mm.naming-authority:unique-name
      • iqn 部分はそのまま iqn
      • yyyy-mm はドメイン取得年月
      • naming-authority はドメイン名を逆順にした形式
      • unique-name はドメイン内で一意な名前
# targetcli /iscsi create iqn.2020-08.com.nwengblog:matsuda01
Created target iqn.2020-08.com.nwengblog:matsuda01.
Created TPG 1.
Global pref auto_add_default_portal=true
Created default portal listening on all IPs (0.0.0.0), port 3260.

ブロックデバイスと IQN の対応付け

設定コマンドのフォーマットは以下の通りです。

  • targetcli /iscsi/IQN/tpg1/luns create /backstores/block/デバイス名
# targetcli /iscsi/iqn.2020-08.com.nwengblog:matsuda01/tpg1/luns create /backstores/block/lun0
Created LUN 0.

ACL の設定

設定コマンドのフォーマットは以下の通りです。

  • targetcli /iscsi/ターゲットのIQN/tpg1/acls create イニシエータのIQN
# targetcli /iscsi/iqn.2020-08.com.nwengblog:matsuda01/tpg1/acls create iqn.1994-05.com.redhat:a8801395d31a
Created Node ACL for iqn.1994-05.com.redhat:a8801395d31a
Created mapped LUN 0.

複数のイニシエータを設定する場合は、上のコマンドをイニシエータの数だけ実行します。

この時点で設定状況を確認してみます。

# targetcli ls
o- / .......................................................................................................... [...]
  o- backstores ............................................................................................... [...]
  | o- block ................................................................................... [Storage Objects: 1]
  | | o- lun0 ............................................. [/dev/VolGroup01/LogVol00 (30.0GiB) write-thru activated]
  | |   o- alua .................................................................................... [ALUA Groups: 1]
  | |     o- default_tg_pt_gp ........................................................ [ALUA state: Active/optimized]
  | o- fileio .................................................................................. [Storage Objects: 0]
  | o- pscsi ................................................................................... [Storage Objects: 0]
  | o- ramdisk ................................................................................. [Storage Objects: 0]
  o- iscsi ............................................................................................. [Targets: 1]
  | o- iqn.2020-08.com.nwengblog:matsuda01 ................................................................ [TPGs: 1]
  |   o- tpg1 ................................................................................ [no-gen-acls, no-auth]
  |     o- acls ........................................................................................... [ACLs: 1]
  |     | o- iqn.1994-05.com.redhat:a8801395d31a ................................................... [Mapped LUNs: 1]
  |     |   o- mapped_lun0 ................................................................... [lun0 block/lun0 (rw)]
  |     o- luns ........................................................................................... [LUNs: 1]
  |     | o- lun0 ........................................ [block/lun0 (/dev/VolGroup01/LogVol00) (default_tg_pt_gp)]
  |     o- portals ..................................................................................... [Portals: 1]
  |       o- 0.0.0.0:3260 ...................................................................................... [OK]
  o- loopback .......................................................................................... [Targets: 0]

設定の保存

  • targetcli saveconfig
# targetcli saveconfig
Configuration saved to /etc/target/saveconfig.json

設定の初期化

設定を初期化したい場合は以下コマンドを実行します。

  • targetcli clearconfig confirm=True

iSCSI イニシエーターの設定

設定は iscsiadm コマンドで行います。主な設定項目は以下の通りです。

  • iSCSI ターゲットの検索
  • iSCSIターゲットへのログイン
  • ブロックデバイスの確認

iSCSI ターゲットの検索

iSCSI ターゲットへの疎通性の確認と IQN の確認を行います。コマンドのフォーマットは以下の通りです。

  • iscsiadm -m discovery -t st -p iSCSIターゲットのIP:3260
# iscsiadm -m discovery -t st -p 192.168.139.144:3260
192.168.139.144:3260,1 iqn.2020-08.com.nwengblog:matsuda01

iSCSI ターゲットに接続できない場合は、iSCSI ターゲットの firewalld によって接続が拒否されている可能性があります。

iSCSI ターゲットへのログイン

iSCSI ターゲットへの疎通性の確認と IQN の確認を行います。コマンドのフォーマットは以下の通りです。

  • iscsiadm -m node -T iSCSIターゲットのIQN -p iSCSIターゲットのIP:3260 -l
# iscsiadm -m node -T iqn.2020-08.com.nwengblog:matsuda01 -p 192.168.139.144:3260 -l
Logging in to [iface: default, target: iqn.2020-08.com.nwengblog:matsuda01, portal: 192.168.139.144,3260] (multiple)
Login to [iface: default, target: iqn.2020-08.com.nwengblog:matsuda01, portal: 192.168.139.144,3260] successful.

ブロックデバイスの確認

  • lsblk -S
# lsblk -S
NAME HCTL       TYPE VENDOR   MODEL             REV TRAN
sda  2:0:0:0    disk VMware,  VMware Virtual S 1.0  spi
sdb  33:0:0:0   disk LIO-ORG  lun0             4.0  iscsi
sr0  4:0:0:0    rom  NECVMWar VMware SATA CD01 1.00 sata
  • fdisk -l /dev/NAME
# fdisk -l /dev/sdb

Disk /dev/sdb: 32.2 GB, 32208060416 bytes, 62906368 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O サイズ (最小 / 推奨): 512 バイト / 4194304 バイト

ファイルシステムの作成とマウント

この後は、iSCSI デバイス(上の例では /dev/sdb)に対してファイルシステムを作成し、それをマウントします。(または必要に応じて iSCSI デバイス上にパーティション作成、物理ボリューム作成、ボリュームグループ作成、論理ボリューム作成を実施した上で、ファイルシステムを作成します。)

まず mkfs.ext4 コマンドでファイルシステムを作成します。

# mkfs.ext4 /dev/sdb
mke2fs 1.42.9 (28-Dec-2013)
/dev/sdb is entire device, not just one partition!
Proceed anyway? (y,n) y
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
Stride=0 blocks, Stripe width=1024 blocks
1966080 inodes, 7863296 blocks
393164 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=2155872256
240 block groups
32768 blocks per group, 32768 fragments per group
8192 inodes per group
Superblock backups stored on blocks:
        32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208,
        4096000

Allocating group tables: done
Writing inode tables: done
Creating journal (32768 blocks): done
Writing superblocks and filesystem accounting information: done

次に、マウントポイントとなるディレクトリを作成してマウントします。

# mkdir /iscsi
# mount /dev/sdb /iscsi

さらに、システム起動時に自動で iSCSI デバイスをマウントするように設定します。

/etc/fstab に以下内容を追記します。

/dev/sdb /iscsi ext4 _netdev 0 0

その他の iscsiadm コマンド

iSCSI セッションの表示

  • iscsiadm -m session -o show
# iscsiadm -m session -o show
tcp: [1] 192.168.139.144:3260,1 iqn.2020-08.com.nwengblog:matsuda01 (non-flash)

iSCSI ターゲットからのログアウト

  • iscsiadm -m node -T iSCSIターゲットのIQN -u
# iscsiadm -m node -T iqn.2020-08.com.nwengblog:matsuda01 -u
Logging out of session [sid: 1, target: iqn.2020-08.com.nwengblog:matsuda01, portal: 192.168.139.144,3260]
Logout of [sid: 1, target: iqn.2020-08.com.nwengblog:matsuda01, portal: 192.168.139.144,3260] successful.
#
# iscsiadm -m session -o show
iscsiadm: No active sessions.

※対象の iSCSI デバイスをアンマウントしておく必要があります

ターゲット登録を削除

  • iscsiadm -m node -o delete -p iSCSIターゲットのIP:3260 -T iSCSIターゲットのIQN
# iscsiadm -m node -o delete -p 192.168.139.144:3260 -T iqn.2020-08.com.nwengblog:matsuda01
#

※先に対象の iSCSI ターゲットからログアウトしておく必要があります

【参考】論理ボリュームの作成

iSCSI ターゲット側で行う作業として、ブロックデバイスとする論理ボリュームを作成する手順を記載します。

ここではデバイス /dev/sdb を使用します。

まず fdisk でパーティションを作成します。

# fdisk /dev/sdb
Welcome to fdisk (util-linux 2.23.2).

Changes will remain in memory only, until you decide to write them.
Be careful before using the write command.

Device does not contain a recognized partition table
Building a new DOS disklabel with disk identifier 0xbfda4ca3.

Command (m for help): m
Command action
   a   toggle a bootable flag
   b   edit bsd disklabel
   c   toggle the dos compatibility flag
   d   delete a partition
   g   create a new empty GPT partition table
   G   create an IRIX (SGI) partition table
   l   list known partition types
   m   print this menu
   n   add a new partition
   o   create a new empty DOS partition table
   p   print the partition table
   q   quit without saving changes
   s   create a new empty Sun disklabel
   t   change a partition's system id
   u   change display/entry units
   v   verify the partition table
   w   write table to disk and exit
   x   extra functionality (experts only)
Command (m for help): n
Partition type:
   p   primary (0 primary, 0 extended, 4 free)
   e   extended
Select (default p): p
Partition number (1-4, default 1): 1
First sector (2048-62914559, default 2048):
Using default value 2048
Last sector, +sectors or +size{K,M,G} (2048-62914559, default 62914559):
Using default value 62914559
Partition 1 of type Linux and of size 30 GiB is set

Command (m for help): t
Selected partition 1
Hex code (type L to list all codes): L

 0  Empty           24  NEC DOS         81  Minix / old Lin bf  Solaris
 1  FAT12           27  Hidden NTFS Win 82  Linux swap / So c1  DRDOS/sec (FAT-
 2  XENIX root      39  Plan 9          83  Linux           c4  DRDOS/sec (FAT-
 3  XENIX usr       3c  PartitionMagic  84  OS/2 hidden C:  c6  DRDOS/sec (FAT-
 4  FAT16 <32M      40  Venix 80286     85  Linux extended  c7  Syrinx
 5  Extended        41  PPC PReP Boot   86  NTFS volume set da  Non-FS data
 6  FAT16           42  SFS             87  NTFS volume set db  CP/M / CTOS / .
 7  HPFS/NTFS/exFAT 4d  QNX4.x          88  Linux plaintext de  Dell Utility
 8  AIX             4e  QNX4.x 2nd part 8e  Linux LVM       df  BootIt
 9  AIX bootable    4f  QNX4.x 3rd part 93  Amoeba          e1  DOS access
 a  OS/2 Boot Manag 50  OnTrack DM      94  Amoeba BBT      e3  DOS R/O
 b  W95 FAT32       51  OnTrack DM6 Aux 9f  BSD/OS          e4  SpeedStor
 c  W95 FAT32 (LBA) 52  CP/M            a0  IBM Thinkpad hi eb  BeOS fs
 e  W95 FAT16 (LBA) 53  OnTrack DM6 Aux a5  FreeBSD         ee  GPT
 f  W95 Ext'd (LBA) 54  OnTrackDM6      a6  OpenBSD         ef  EFI (FAT-12/16/
10  OPUS            55  EZ-Drive        a7  NeXTSTEP        f0  Linux/PA-RISC b
11  Hidden FAT12    56  Golden Bow      a8  Darwin UFS      f1  SpeedStor
12  Compaq diagnost 5c  Priam Edisk     a9  NetBSD          f4  SpeedStor
14  Hidden FAT16 <3 61  SpeedStor       ab  Darwin boot     f2  DOS secondary
16  Hidden FAT16    63  GNU HURD or Sys af  HFS / HFS+      fb  VMware VMFS
17  Hidden HPFS/NTF 64  Novell Netware  b7  BSDI fs         fc  VMware VMKCORE
18  AST SmartSleep  65  Novell Netware  b8  BSDI swap       fd  Linux raid auto
1b  Hidden W95 FAT3 70  DiskSecure Mult bb  Boot Wizard hid fe  LANstep
1c  Hidden W95 FAT3 75  PC/IX           be  Solaris boot    ff  BBT
1e  Hidden W95 FAT1 80  Old Minix
Hex code (type L to list all codes): 8e
Changed type of partition 'Linux' to 'Linux LVM'

Command (m for help): p

Disk /dev/sdb: 32.2 GB, 32212254720 bytes, 62914560 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk label type: dos
Disk identifier: 0xbfda4ca3

   Device Boot      Start         End      Blocks   Id  System
/dev/sdb1            2048    62914559    31456256   8e  Linux LVM

Command (m for help): w
The partition table has been altered!

Calling ioctl() to re-read partition table.
Syncing disks.
#

次に pvcreate/dev/sdb1 上に物理ボリュームを作成します。

# pvcreate /dev/sdb1
  Physical volume "/dev/sdb1" successfully created.
#
# pvdisplay /dev/sdb1
  "/dev/sdb1" is a new physical volume of "<30.00 GiB"
  --- NEW Physical volume ---
  PV Name               /dev/sdb1
  VG Name
  PV Size               <30.00 GiB
  Allocatable           NO
  PE Size               0
  Total PE              0
  Free PE               0
  Allocated PE          0
  PV UUID               cu4Ai5-F4Gs-WiYN-moLK-j1nq-kQEg-QFqcAT

次に vgcreate コマンドを使用してボリュームグループ VolGroup01 を作成します。

# vgcreate VolGroup01 /dev/sdb1
  Volume group "VolGroup01" successfully created
#
# vgdisplay VolGroup01
  --- Volume group ---
  VG Name               VolGroup01
  System ID
  Format                lvm2
  Metadata Areas        1
  Metadata Sequence No  1
  VG Access             read/write
  VG Status             resizable
  MAX LV                0
  Cur LV                0
  Open LV               0
  Max PV                0
  Cur PV                1
  Act PV                1
  VG Size               <30.00 GiB
  PE Size               4.00 MiB
  Total PE              7679
  Alloc PE / Size       0 / 0
  Free  PE / Size       7679 / <30.00 GiB
  VG UUID               OTJSJn-bIt2-j4uZ-HtVF-15PJ-anLL-ZC5Mif

最後にlvcreate コマンドを使用して論理ボリュームLogVol00 を作成します。

# lvcreate -l 100%FREE -n LogVol00 VolGroup01
  Logical volume "LogVol00" created.
#
# lvdisplay
  --- Logical volume ---
(略)

  --- Logical volume ---
  LV Path                /dev/VolGroup01/LogVol00
  LV Name                LogVol00
  VG Name                VolGroup01
  LV UUID                qrFGPV-7goB-xhbx-Ei4g-1EU9-oSi2-PuV1m8
  LV Write Access        read/write
  LV Creation host, time RHEL-DB02, 2020-08-12 03:55:34 -0400
  LV Status              available
  # open                 0
  LV Size                <30.00 GiB
  Current LE             7679
  Segments               1
  Allocation             inherit
  Read ahead sectors     auto
  - currently set to     8192
  Block device           253:3

以上です。

参考資料

第25章 オンラインストレージ管理 Red Hat Enterprise Linux 7 | Red Hat Customer Portal
The Red Hat Customer Portal delivers the knowledge, expertise, and guidance available through your Red Hat subscription.
CentOS 7.3でiSCSIターゲットを構成 | setup | OSS Fan
OSSを利用してサーバを構築するための情報を公開しています。
CentOS 7.3でiSCSIイニシエータを構成 | setup | OSS Fan
OSSを利用してサーバを構築するための情報を公開しています。
LVMで 論理ボリュームの作成、拡張、縮小、複製 - Qiita
前の記事 LVM 概要 構成概要 複数の物理ボリュームがあり、その上に複数のボリュームグループを作成することができ、その上に複数の論理ボリュームを作成することができます。 複数の物理ボリュームを使用する場合、その上に作...

―――――――――――――

タイトルとURLをコピーしました