はじめに
- 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
サービスの起動と有効化
iscsid
と iscsi
の 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 ターゲットへの疎通性の確認と 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
以上です。
参考資料


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