设为首页 收藏本站
查看: 789|回复: 0

[经验分享] 共享存储之iscsi网络共享存储应用详解

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-8-23 09:41:42 | 显示全部楼层 |阅读模式
iSCSI概述:
iSCSI技术是一种由IBM公司研究开发的,是一个供硬件设备使用的可以在IP协议的上层运行的SCSI指令集,这种指令集合可以实现在IP网络上运行SCSI协议,使其能够在诸如高速千兆以太网上进行路由选择。iSCSI技术是一种新储存技术,该技术是将现有SCSI接口与以太网络(Ethernet)技术结合,使服务器可与使用IP网络的储存装置互相交换资料。

iSCSI:Internet 小型计算机系统接口 (iSCSI:Internet Small Computer System Interface)。

Internet 小型计算机系统接口(iSCSI)是一种基于 TCP/IP的协议,用来建立和管理 IP 存储设备、主机和客户机等之间的相互连接,并创建存储区域网络(SAN)。SAN 使得 SCSI 协议应用于高速数据传输网络成为可能,这种传输以数据块级别(block-level)在多个数据存储网络间进行。


SCSI 结构基于客户/服务器模式,其通常应用环境是:设备互相靠近,并且这些设备由 SCSI 总线连接。iSCSI 的主要功能是在 TCP/IP 网络上的主机系统(启动器 initiator)和存储设备(目标器 target)之间进行大量数据的封装和可靠传输过程。此外,iSCSI 提供了在 IP 网络封装 SCSI 命令,且运行在 TCP 上。
完整的iSCSI系统的拓扑结构如下:
041650196377839.jpg
iSCSI配置实现过程如下:

实验系统环境如下:
操作系统: CentOS release 6.5 (Final)
director(iSCSI Target): 172.16.100.3/16 scsi-target-utils-1.0.24-10.el6.x86_64
node1(iSCSI Initiator) : 172.16.100.6/16  iscsi-initiator-utils.x86_64 0:6.2.0.873-10.el6
关闭防火墙:
iptables: Firewall is not running.
关闭SELINUX:
setenforce: SELinux is disabled

准备工作:
iSCSI可分享的设备类型有很多,包括镜像文件(*.img)、分区(partition)、物理硬盘、raid设备、逻辑卷等,下面我们测试常用的几种设备类型:
(1)准备共享的设备分区类型
1
2
3
4
5
6
7
8
# fdisk -l /dev/sdb

Disk /dev/sdb: 128.8 GB, 128849018880 bytes
255 heads, 63 sectors/track, 15665 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x00000000



建立所需要的新分区大小为20G:
1
2
3
4
5
6
7
8
9
10
# fdisk -l /dev/sdb
Command (m for help): n  
Command action
   e   extended
   p   primary partition (1-4)
p
Partition number (1-4): 1
First cylinder (1-15665, default 1):
Using default value 1
Last cylinder, +cylinders or +size{K,M,G} (1-15665, default 15665): +20G



重新读取分区表:
1
2
3
4
5
6
7
8
9
# partx -a /dev/sdb
# fdisk -l /dev/sdb1

Disk /dev/sdb1: 21.5 GB, 21484399104 bytes
255 heads, 63 sectors/track, 2611 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x00000000



(2)准备要共享的镜像文件
在director的/srv目录下创建一个1G大小的镜像文件
1
2
3
4
5
6
7
# mkdir /srv/iscsi
# dd if=/dev/zero of=/srv/iscsi/disk1.img bs=1M count=1024
1024+0 records in
1024+0 records out
1073741824 bytes (1.1 GB) copied, 36.8793 s, 29.1 MB/s
[iyunv@director ~]# ll -lh /srv/iscsi/disk1.img
-rw-r--r-- 1 root root 1.0G Aug 20 14:40 /srv/iscsi/disk1.img



wKiom1e3-_bhzLUQAAAmkFC66lQ010.jpg
(3)创建逻辑卷
创建一个大小为10G的LV
1
2
3
4
5
6
# pvcreate /dev/sdc
  Physical volume "/dev/sdc" successfully created
# vgcreate vg1 /dev/sdc
  Volume group "vg1" successfully created
# lvcreate -L 20G -n iscsi vg1
  Logical volume "iscsi" created



wKiom1e3_y6B85MbAAA2B1zV-M4750.jpg


(4)准备共享的设备物理硬盘
添加一个大小为120G的硬盘


配置director(iSCSI Target)
(1)安装scsi-target-utils管理工具
CentOS自带scsi-target-utils软件包,使用该工具进行target配置:
1
2
3
4
5
6
# yum -y install scsi-target-utils
# chkconfig tgtd on
# service tgtd start
# ss -tunlp | grep tgt
tcp    LISTEN     0      128                   :::3260                 :::*      users:(("tgtd",1259,5),("tgtd",1262,5))
tcp    LISTEN     0      128                    *:3260                  *:*      users:(("tgtd",1259,4),("tgtd",1262,4))



(2)配置target有以下两种方式:
第一种方式:使用tgtadm全命令工具创建;此命令工具配置的iscsi target系统重启之后会丢失。
第二种方式:编辑/etc/tgt/targets.conf,编辑配置文件生成的iscsi target系统重启之后不会丢失。

第一种使用target命令工具配置如下:
(1)创建一个target:
1
# tgtadm -L iscsi -o new -m target -t 1 -T iqn.2016.08.com.samlee:iscsi.disk



(2)查询创建的target所有信息:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# tgtadm -L iscsi -m target -o show
或:
# tgt-admin -show
Target 1: iqn.2016.08.com.samlee:iscsi.disk    ##target名称,以及标识号
    System information: ##系统信息及状态
        Driver: iscsi
        State: ready
    I_T nexus information:
    LUN information:
        LUN: 0        ##逻辑单元号;默认从0开始
            Type: controller
            SCSI ID: IET     00010000
            SCSI SN: beaf10
            Size: 0 MB, Block size: 1
            Online: Yes
            Removable media: No    ##移除
            Prevent removal: No    ##阻止
            Readonly: No            
            Backing store type: null    ##块设备类型
            Backing store path: None    ##提供块设备的位置
            Backing store flags:         ##块设备标记
    Account information:                ##授权用户访问
    ACL information:                    ##授权ip地址段访问



(3)在target中添加分区设备
1
# tgtadm -L iscsi -m logicalunit -o new -t 1 -l 1 -b /dev/sdb1



(4)在target中添加镜像文件
1
# tgtadm -L iscsi -m logicalunit -o new -t 1 -l 2 -b /srv/iscsi/disk1.img



(5)在target中添加lv逻辑卷
1
# tgtadm -L iscsi -m logicalunit -o new -t 1 -l 3 -b /dev/vg1/iscsi



(6)在target中添加硬盘设备
1
# tgtadm -L iscsi -m logicalunit -o new -t 1 -l 4 -b /dev/sdd



(7)给target授权允许172.16.0.0/16网络访问及iscsiuser用户访问,默认是不允许任何用户访问
1
2
3
# tgtadm -L iscsi -m account -o new --user iscsiuser --password iscsiuser
# tgtadm -L iscsi -m account -o bind --tid 1 --user iscsiuser
# tgtadm -L iscsi -m target -o bind -t 1 -I 172.16.0.0/16




第二种方式:编辑/etc/tgt/targets.conf
target主配置文件为/etc/tgt/targets.conf,下面我们来设置改文件。
在该文件最后追加以下设置:

1
2
3
4
5
6
7
8
<target iqn.2016.08.com.samlee:iscsi.disk>
        backing-store /srv/iscsi/disk1.img
        backing-store /dev/sdb1
        backing-store /dev/vg1/iscsi
        backing-store /dev/sdd
        incominguser iscsiuser iscsiuser
        initiator-address 172.16.0.0/16
</target>




说明:


1
2
3
4
5
6
7
8
9
说明:
(1)iqn = iSCSI Qualified Name

(2)iSCSI target的名称规则如下:
iqn.2016.08.com.samlee:iscsi.disk
iqn.年份-月份.域名反写.设备识别

(2)每个在同一个target上的backing-store 称为逻辑单元号(Logical Unit Number,LUN),
这个实验中有4个LUN。





配置iSCSI Initiator
(1)安装iSCSI客户端工具
1
# yum -y install iscsi-initiator-utils



(2)设置开机自启动
1
2
# chkconfig iscsi on
# chkconfig iscsid on



(3)配置initiator文件
initiator的配置文件位于/etc/iscsi/,该目录下有两个文件,initiatorname.iscsi 和iscsid.conf,其中iscsid.conf 是其配置文件,initiatorname.iscsi 是标记了initiator的名称,我们做如下配置:
1
2
# echo "InitiatorName=`iscsi-iname -p iqn.2016.08.com.samlee:iscsi.disk`" > /etc/iscsi/initiatorname.iscsi
# echo "InitiatorAlias=node1.samlee.com" >> /etc/iscsi/initiatorname.iscsi



配置iscsid.conf文件开启用户认证:
1
2
3
4
5
# vim /etc/iscsi/iscsid.conf
启用一下选项:
node.session.auth.authmethod = CHAP
node.session.auth.username = iscsiuser
node.session.auth.password = iscsiuser



启动iscsi客户端服务
1
2
# service iscsi start
# service iscsid start




(4)侦测target
如果我们事先不知道目标主机的target名称,我们就需要进行侦测:
1
2
3
# iscsiadm -m discovery -t st -p 172.16.100.3
Starting iscsid:                                           [  OK  ]
172.16.100.3:3260,1 iqn.2016.08.com.samlee:iscsi.disk



参数选项说明:

1
2
3
-m discovery  //侦测target
-t sendtargets  //通过iscsi协议
-p IP:port  //指定target的IP和port,不写port的话,默认为3260



(5)查看nodes
iscsiadm 侦测到的结果会写入/var/lib/iscsi/nodes/ 中,因此只需启动/etc/init.d/iscsi 就能够在下次开机时,自动连接到正确的target了
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
# ls /var/lib/iscsi/
ifaces  isns  nodes  send_targets  slp  static
# ls /var/lib/iscsi/send_targets/
172.16.100.3,3260
# ls -lR /var/lib/iscsi/nodes/
/var/lib/iscsi/nodes/:
total 4
drw------- 3 root root 4096 Aug 20 16:42 iqn.2016.08.com.samlee:iscsi.disk

/var/lib/iscsi/nodes/iqn.2016.08.com.samlee:iscsi.disk:
total 4
drw------- 2 root root 4096 Aug 20 16:42 172.16.100.3,3260,1

/var/lib/iscsi/nodes/iqn.2016.08.com.samlee:iscsi.disk/172.16.100.3,3260,1:
total 4
-rw------- 1 root root 1818 Aug 20 16:42 default



侦测信息都写入了/var/lib/iscsi/nodes/iqn.2016.08.com.samlee:iscsi.disk/172.16.100.3,3260,1/default文件中。
(6)连接target
查看目前系统上面所有的target
1
2
# iscsiadm -m node
172.16.100.3:3260,1 iqn.2016.08.com.samlee:iscsi.disk



登陆target
1
2
3
# iscsiadm -m node -T iqn.2016.08.com.samlee:iscsi.disk -P 172.16.100.3 -l
Logging in to [iface: default, target: iqn.2016.08.com.samlee:iscsi.disk, portal: 172.16.100.3,3260] (multiple)
Login to [iface: default, target: iqn.2016.08.com.samlee:iscsi.disk, portal: 172.16.100.3,3260] successful.



(6)查看磁盘状态如下图所示:
wKioL1e4HX_jNtLLAACMZuNH_xk003.jpg
现在可以看到,initiator 上面多了四块硬盘,大小和target上的LUN一致。这时你就可以像使用本地磁盘一样使用这些iSCSI设备。

测试应用如下:
(1)将/dev/sdb 和/dev/sdc 创建成LV挂载使用:
创建LV逻辑卷:
1
2
3
# pvcreate /dev/sdb /dev/sdc
# vgcreate vg_iscsi /dev/sdb /dev/sdc
# lvcreate -L 130G -n lv_iscsi vg_iscsi



wKioL1e6crvTUAQ-AABMW86SNdY055.jpg
格式化创建文件并挂载:
1
2
3
4
5
# mke2fs -t ext4 /dev/vg_iscsi/lv_iscsi
# mkdir /data
# vim /etc/fstab
/dev/vg_iscsi/lv_iscsi  /data                   ext4    defaults,_netdev        0 0
# mount -a



创建测试文件:
1
2
# touch  /data/iscsi{1..100}.txt
# ls /data/



wKiom1e6dWaB-BLdAABKp-KdnK0838.jpg
创建测试文件成功后,重启客户端:
1
2
# df -TH
# ls /data/



wKiom1e6duWxLYTBAABwozVCpVI476.jpg

以上为iSCSI配置实现全过程。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-261755-1-1.html 上篇帖子: 解决linux64位安装jpeg出错 make:./libtool:Command not found 下篇帖子: Linux_CentOS6.4基础网络配置 网络
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表