当前位置: 首页 > news >正文

保姆级教程:在CentOS 7上用targetcli配置iSCSI Target,并让另一台Linux客户端成功挂载

从零构建企业级iSCSI存储网络:CentOS 7实战指南

在虚拟化与云计算环境中,存储网络的灵活配置能力直接决定了基础设施的扩展性和可靠性。iSCSI作为IP SAN的核心技术方案,以其硬件兼容性强、部署成本低的优势,成为中小企业构建共享存储的首选方案。本文将手把手带您完成从服务端配置到客户端挂载的全流程操作,特别针对CentOS 7环境中的常见坑点提供解决方案。

1. 环境准备与基础概念

在开始配置前,我们需要明确实验环境的硬件拓扑。假设您已准备两台CentOS 7虚拟机,分别承担以下角色:

  • 存储服务器(192.168.100.20):配备额外磁盘(如/dev/sdb)作为共享存储源
  • 客户端(192.168.100.19):通过以太网访问远程存储

iSCSI协议的核心组件包括:

  • Target:存储资源的提供方(服务端)
  • Initiator:存储资源的使用方(客户端)
  • IQN(iSCSI Qualified Name):全球唯一标识符,格式为iqn.yyyy-mm.<reversed-domain>:identifier

生产环境中建议使用独立的物理网卡或VLAN隔离iSCSI流量,避免与其他网络服务产生带宽竞争

2. 服务端深度配置

2.1 软件安装与磁盘准备

首先在存储服务器执行基础软件安装:

# 安装iSCSI服务端组件 yum install -y targetcli targetd

创建物理磁盘的存储对象时,需特别注意磁盘选择:

targetcli /backstores/block create disk1 /dev/sdb

disk1为自定义存储对象名称,对应物理磁盘/dev/sdb。通过ls命令可验证创建结果:

o- block .................................................... [Storage Objects: 1] | o- disk1 ........................... [/dev/sdb (40.0GiB) write-thru activated]

2.2 创建iSCSI目标与访问控制

建立iSCSI目标时需要遵循IQN命名规范:

/iscsi/ create iqn.2023-07.example.com:storage.target

关键安全配置步骤:

  1. 创建LUN映射:
    cd /iscsi/iqn.2023-07.example.com:storage.target/tpg1/luns create /backstores/block/disk1
  2. 设置CHAP认证(强制建议生产环境启用):
    cd /iscsi/iqn.2023-07.example.com:storage.target/tpg1/acls create iqn.2023-07.example.com:client.initiator set auth userid=storage_user set auth password=Complex@Pass123

2.3 服务优化与防火墙

调整内核参数提升iSCSI性能:

echo "net.ipv4.tcp_timestamps = 1" >> /etc/sysctl.conf echo "net.ipv4.tcp_sack = 1" >> /etc/sysctl.conf sysctl -p

防火墙规则配置示例:

firewall-cmd --permanent --add-port=3260/tcp firewall-cmd --reload

3. 客户端连接实战

3.1 初始化连接配置

客户端需安装必要软件包:

yum install -y iscsi-initiator-utils

修改配置文件建立认证关联:

vim /etc/iscsi/initiatorname.iscsi InitiatorName=iqn.2023-07.example.com:client.initiator vim /etc/iscsi/iscsid.conf node.session.auth.authmethod = CHAP node.session.auth.username = storage_user node.session.auth.password = Complex@Pass123

3.2 发现与挂载操作

执行存储发现时会显示可用目标:

iscsiadm -m discovery -t sendtargets -p 192.168.100.20

典型输出:

192.168.100.20:3260 via sendtargets iqn.2023-07.example.com:storage.target

建立会话连接:

iscsiadm -m node -T iqn.2023-07.example.com:storage.target -p 192.168.100.20 -l

验证磁盘识别情况:

lsblk | grep -i "sd[b-z]"

4. 高级配置与排错指南

4.1 多路径IO配置(可选)

对于高可用环境,建议配置多路径:

yum install -y device-mapper-multipath mpathconf --enable --with_multipathd y

配置文件示例(/etc/multipath.conf):

devices { device { vendor "LIO-ORG" product "*" path_grouping_policy failover path_checker tur } }

4.2 常见故障排查

连接失败检查清单

  1. 网络连通性测试:ping 192.168.100.20
  2. 端口可用性验证:telnet 192.168.100.20 3260
  3. 服务状态确认:systemctl status targetd
  4. 认证日志分析:journalctl -u iscsid -f

会话管理命令参考

  • 查看活动会话:iscsiadm -m session
  • 临时断开连接:iscsiadm -m node -U all
  • 永久删除节点:iscsiadm -m node -o delete

5. 生产环境最佳实践

5.1 性能调优参数

在/etc/iscsi/iscsid.conf中添加:

node.conn[0].timeo.noop_out_interval = 15 node.conn[0].timeo.noop_out_timeout = 15 node.session.initial_login_retry_max = 12

5.2 自动化挂载方案

正确的fstab配置示例:

/dev/disk/by-path/ip-192.168.100.20:3260-iscsi-iqn.2023-07.example.com:storage.target-lun-0 /mnt/iscsi xfs _netdev,rw,noatime 0 0

关键注意事项:

  • 必须使用_netdev挂载选项
  • 建议通过磁盘路径标识而非设备名(如/dev/sdb)
  • 可添加nofail选项避免启动阻塞

对于需要更高可靠性的场景,可以考虑使用udev规则自动挂载:

vim /etc/udev/rules.d/99-iscsi.rules ACTION=="add", SUBSYSTEM=="block", ENV{DEVTYPE}=="disk", ENV{ID_SERIAL}=="36001405bcd1a892b4a1e8a4a2e1e8f8a", RUN+="/bin/mount /mnt/iscsi"
http://www.zskr.cn/news/1432897.html

相关文章:

  • 用小学生都能懂的几何图解,5分钟搞懂Jain‘s Fairness Index(附Python验证代码)
  • 人才测评公司有哪些?资质认证、常模样本量、行业案例与数据合规性四维筛选法(附避坑清单) - 品牌排行榜
  • 从‘神奇数字’到趣味数学:带孩子用Scratch或Python探索水仙花数(亲子编程指南)
  • deepseek数学公式如何正确粘贴?别扯了,这破问题正在吃掉AI替你省下的时间!“AI导出鸭”实测,这才是打工人的救命稻草 - AI导出鸭
  • AI训练数据抓取:公开社交数据的合规边界与技术实现
  • 2026年收藏|AIGC率59%降至6%?5款实测降AI工具+6大去AI痕迹纯手改指南 - 降AI实验室
  • GMT6.4绘图进阶:给你的地形剖面图加上高程填充与海平面标识
  • 别再死记硬背了!用这个电容压差“突变”的数学例子,彻底搞懂EG2104自举原理
  • VASP计算完别急着关!手把手教你从OUTCAR、DOSCAR里“挖”出有用数据
  • 如何快速掌握DownKyi:5步实现B站视频下载终极技巧
  • 2026年生产报工软件怎么选?黑湖小工单对比其他MES有什么优势? - 黑湖科技老黑
  • AI文本检测与反检测:PassMe.ai原理、应用与人类化写作策略
  • Flutter视频播放避坑指南:除了降低RTSP延迟,VLC插件这些高级选项你配置对了吗?
  • NAS外接存储避坑指南:USB硬盘盒、阵列盒、网络挂载,哪种方案最适合你的DS920+/TS-453D?
  • 低代码≠零运维:Lovable平台上线后崩溃的7个凌晨,我们用这4个监控埋点挽回SLA(生产环境血泪复盘)
  • DownKyi哔哩下载姬:解锁B站视频离线观看的全能解决方案
  • 天津双赢再生资源回收:天津工厂机械设备回收公司 - LYL仔仔
  • 移民美国项目怎么选 多维度解析助决策 - 品牌排行榜
  • 可解释AI实战指南:从SHAP、LIME原理到企业级落地
  • 手把手教你用Proteus 8.9搭建8086仿真环境(附MASM32配置与常见报错修复)
  • 读工业软件简史06工业软件强国(上)
  • 告别传统PDE求解器:用PyTorch实现傅立叶神经算子(FNO),速度提升1000倍
  • 关于综述文章如何进行调研总结规律的skill,直接生成思维导图与excel图表,并总结趋势
  • 2026年牵手红娘服务权威推荐深度盘点:线下婚恋场景见面率低与匹配效率瓶颈 - 品牌推荐
  • 临沂精工漏电漏水检测维修消防管查漏|工程消防维保|厂房防水/管道电缆故障一站式维修 - 资讯热点
  • Unity Timeline实战:用自定义轨道和Signal打造可交互的剧情对话系统(含完整项目代码)
  • 可解释AI实践指南:从模型可信度到业务落地的技术解析
  • Fundrise首席执行官本米勒:VCX、Roaring Kitty
  • 终极游戏本地化方案:XUnity.AutoTranslator如何打破语言壁垒
  • 实战指南:用LIME和SHAP给你的黑盒模型(比如XGBoost)做个‘X光检查’