哇~真的是你呀!今天是LINUX中的ISCSI服务

简介: iSCSI(Internet Small Computer System Interface)是一种用于将存储设备(如硬盘驱动器)通过网络连接到计算机系统的存储协议。它允许计算机通过IP网络访问远程存储设备,就像访问本地存储设备一样。

前言

iSCSI(Internet Small Computer System Interface)是一种用于将存储设备(如硬盘驱动器)通过网络连接到计算机系统的存储协议。它允许计算机通过IP网络访问远程存储设备,就像访问本地存储设备一样。


在Linux中,iSCSI是通过iSCSI Initiator实现的。iSCSI Initiator是Linux系统中的软件组件,用于建立与远程iSCSI Target(存储设备)之间的通信链接。它将远程iSCSI Target逻辑单元(LUN)映射到本地计算机上,使得计算机可以通过网络访问这些逻辑单元。


使用Linux中的iSCSI,您可以将远程存储设备连接到计算机,并将其作为本地存储设备使用。这对于实现存储共享、数据备份和集中化存储管理等场景非常有用。您可以通过简单的命令行工具(如`iscsiadm`)配置iSCSI Initiator,建立与远程iSCSI Target的连接,然后将它们挂载到Linux文件系统中。


总结起来,Linux中的iSCSI是一种用于通过网络连接远程存储设备的协议,通过iSCSI Initiator可以将远程存储设备映射为本地存储设备,以便Linux系统可以方便地访问和使用这些存储资源。


一、概述


(1)全称:Internet Small Computer System Interface——互联网小型计算机接口


(2)通过网络获取磁盘设备在本地进行存储使用。


(3)iscsi

  1) 基于IP协议进行scsi数据的传输

   2)IP/SAN网络: 基于双绞线为传输介质的存储网络

   3)光纤存储网络:基于光纤传输的存储网络,造价极高

   4)实现方式:软件形式;硬件形式

   5)默认端口号:3260


(4)相关名词

  1) iscsi initiator:iscsi客户端

   2)iscsi target:iscsi服务端

   3)lun:一个块设备存储

   4)iqn:iscsi名称;iqn.时间.域名反写:定义标识


(5)使用targetcli工具进入到iscsi服务器端管理界面

   targetcli

       进入到服务器端的iscsi命令配置信息

   o- / .................... [...]

       顶级目录

     o- backstores ............... [...]

       后备存储,主备存储空间,要共享的设备或分区得先加入到这里

      | o- block .............. [Storage Objects: 0]

       块存储,o- backstores子目录

      | o- fileio ............. [Storage Objects: 0]

       文件存储,o- backstores子目录

      | o- pscsi ................. [Storage Objects: 0]

       真实物理scsi设备,o- backstores子目录

      | o- ramdisk ................ [Storage Objects: 0]

       闪存,o- backstores子目录

     o- iscsi ................ [Targets: 0]

       以ISCSI的方式共享存储设备的目录

     o- loopback ................. [Targets: 0]


二、构建iscsi服务


一、服务器端设置

(1)服务器端

  1) 进入到/backstores/block目录中添加设备到块设备列表

   

create disk0 /dev/sdb1

   2)进入到iscsi目录中生成iqn标签

       create

   3)进入到/iscsi/iqn.20...909/tpg1/luns>目录下创建逻辑单元

   

create /backstores/block/disk0

   4)进入到/iscsi/iqn.20...909/tpg1/acls>目录中创建访问控制规则

 

create iqn.20......

   5)进入到/iscsi/iqn.20.../tpg1/portals>目录中创建端口

 

create 192.168.1.1 3260

           注意:因为原本存在一个端口0.0.0.0:3260,所以需要将原来的端口删除掉再进行创建

   exit退出,否则设置不会被保存

  6) 在认证文件中成iqn编号

     

vim  /etc/iscsi/initiatorname.iscsi

       将原来的认证编号改为新生成的编号

   7)启动服务

systemctl start iscsi
        systemctl start iscsid


二、客户端

(1)客户端

   1)安装软件

 

yum -y install iscsi-initator-utils

  2) 在认证文件中生成iqn编号

 

vim  /etc/iscsi/initatorname.iscsi

       将原来的认证编号改为新生成的编号

   3)开启客户端服务

 

systemctl start iscsi
        systemctl start iscsid

  4) 查找可用的iscsi资源列表

 

iscsiadm -m discovery -t st -p 192.168.1.1:3260

       -m    指定模式

       -t    指定动作类型,st,sendtargets

       -p    指定服务器和端口

  5) 访问服务器的共享资源

 

iscsiadm -m node -T iqn.2003-01.org.linux-iscsi.localhost.x8664:sn.3f2f0c3bd909 -l

       -T    targetnameiqn

       -l    login


三、注意事项



   1、自动挂载时必须使用UUID,否则会出问题,同时在参数中添加_netdev,如UUID=33899a29-9f9e-476f-b8e9-cc9ad0986dac /mnt xfs defaults,_netdev

       blkid查看UUID

   2、开机启动关闭防火墙,因为当计算机开机首先是bios自检查找硬盘中的操作系统引导启动,但是当系统没有完全启动时计算机就没有通过网络通讯,而iscsi是基于网络的共享存储,所以开机重启需要告诉内核这条开机挂载是基于网络的存储


四、实验


现有两台主机一台服务器,一台客户机


要求:1、在服务器上构建iscsi服务


           2、客户端实现自动挂载


1)在两台主机上配置基础环境:关闭防火墙、SELINUX、配置yum源、设置IP测试通联行


2)在服务器上添加硬盘,通过热扫描进行识别,进行磁盘分区,格式化

热扫描for i in `ls /sys/class/scsi_host`;do echo "- - -">$i/scan;done

分区fdisk /dev/sdb

格式化分区mkfs -t xfs /dev/sdb1

3)在服务器上安装targercli,使用targetcli工具进入到iscsi服务器端管理界面

安装yum -y install targetcli

使用targetcli命令进入到服务器端的iscsi命令配置信息

进入到/backstores/block目录中添加设备到块设备列表

   create disk0 /dev/sdb1

进入到iscsi目录中生成iqn标签

   create

进入到/iscsi/iqn.20...909/tpg1/luns>目录下创建逻辑单元

   create /backstores/block/disk0

进入到/iscsi/iqn.20...909/tpg1/acls>目录中创建访问控制规则

   create iqn.20......

进入到/iscsi/iqn.20.../tpg1/portals>目录中创建端口

   create 192.168.1.1 3260

       注意:因为原本存在一个端口0.0.0.0:3260,所以需要将原来的端口删除掉再进行创建

退出,否则设置不会被保存


4)在认证文件中成iqn编号

 

vim  /etc/iscsi/initiatorname.iscsi

   将原来的认证编号改为新生成的编号

启动服务

   systemctl start iscsi

   systemctl start iscsid

5)在客户端配置

安装软件

 

yum -y install iscsi-initator-utils

在认证文件中生成iqn编号

 

vim  /etc/iscsi/initatorname.iscsi

   将原来的认证编号改为新生成的编号

开启客户端服务

 

systemctl start iscsi
    systemctl start iscsid

查找可用的iscsi资源列表

iscsiadm -m discovery -t st -p 192.168.1.1:3260

   -m    指定模式

   -t    指定动作类型,st,sendtargets

   -p    指定服务器和端口

访问服务器的共享资源

 

iscsiadm -m node -T iqn.2003-01.org.linux-iscsi.localhost.x8664:sn.3f2f0c3bd909 -l

   -T    targetnameiqn

   -l    login

6)在客户端进行自动挂载

在客户端创建文目录/test

在服务端中查看共享磁盘的UUID

回到客户端进行自动挂载vim /etc/fstab,并mount  -a 检查挂载情况

重启验证

如果要取消连接的话:1在客户端卸载sdb1,2关闭服务

目录
相关文章
|
2天前
|
Unix Linux iOS开发
操作系统透视:从历史沿革到现代应用,剖析Linux与网站服务架构
操作系统透视:从历史沿革到现代应用,剖析Linux与网站服务架构
37 0
|
5天前
|
缓存 Linux 网络安全
百度搜索:蓝易云【Linux系统服务器启动SSH服务时出现“error while loading shared libraries”错误该如何解决】
以上步骤应该能够解决“error while loading shared libraries”错误,使SSH服务能够正常启动并运行。
21 3
|
5天前
|
监控 安全 Linux
Linux日志管理服务 rsyslogd
Linux日志管理服务 rsyslogd
17 2
Linux日志管理服务 rsyslogd
|
14天前
|
NoSQL 关系型数据库 Linux
阿里云RDS购买Linux——安装redis服务
阿里云RDS购买Linux——安装redis服务
28 0
|
14天前
|
缓存 监控 Linux
如何实现 Linux 服务 Crash 后自动重启?
如何实现 Linux 服务 Crash 后自动重启?
|
15天前
|
存储 监控 Ubuntu
揭秘 systemd:释放 Linux 服务管理的力量【systemd 一】
揭秘 systemd:释放 Linux 服务管理的力量【systemd 一】
24 0
|
21天前
|
存储 网络协议 Ubuntu
【SVN内网穿透】远程访问Linux SVN服务(二)
由于文档资料越来越多,将所有资料都存放在自己的电脑上容易混淆,并且也不利于分享。这种情况下,考虑将资料上传SVN统一管理,这样一来其他人也能很方便的查略各种资料。 当SVN安装在局域网内的话,想要远程访问资料库或者代码将会受到限制,为了能从公共网络访问内网SVN资料库,cpolar能很好的解决这一需求,cpolar是一个能把内网服务暴露至公网进行访问的工具。 SVN分为服务端和客户端,服务端主要是做数据资料存储,客户端主要是图形化工具连接服务端获取服务端数据资料,下面介绍在ubuntu系统安装服务端,在通过客户端远程访问。
|
21天前
|
存储 Ubuntu 网络协议
【SVN内网穿透】远程访问Linux SVN服务(一)
由于文档资料越来越多,将所有资料都存放在自己的电脑上容易混淆,并且也不利于分享。这种情况下,考虑将资料上传SVN统一管理,这样一来其他人也能很方便的查略各种资料。 当SVN安装在局域网内的话,想要远程访问资料库或者代码将会受到限制,为了能从公共网络访问内网SVN资料库,cpolar能很好的解决这一需求,cpolar是一个能把内网服务暴露至公网进行访问的工具。 SVN分为服务端和客户端,服务端主要是做数据资料存储,客户端主要是图形化工具连接服务端获取服务端数据资料,下面介绍在ubuntu系统安装服务端,在通过客户端远程访问。
|
21天前
|
存储 网络协议 Ubuntu
如何通过内网穿透实现远程访问Linux SVN服务
如何通过内网穿透实现远程访问Linux SVN服务
25 0
|
22天前
|
网络协议 Linux 网络安全
Linux服务器配置指南:网络、用户管理、共享服务及DNS配置详解
Linux服务器配置指南:网络、用户管理、共享服务及DNS配置详解
100 0