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

Linux下iSCSI服务端配置全攻略:从tgtadm基础到CHAP认证实战

Linux下iSCSI服务端配置全攻略从tgtadm基础到CHAP认证实战在当今企业级存储解决方案中iSCSI凭借其基于IP网络的灵活性和成本效益成为构建存储区域网络(SAN)的热门选择。不同于传统的FC-SAN需要专用硬件iSCSI允许通过标准以太网传输SCSI指令特别适合预算有限但需要共享存储的中小型企业。本文将深入探讨使用Linux平台上的tgtadm工具搭建iSCSI服务端的完整流程涵盖从基础配置到CHAP安全认证的全套实战方案。1. 环境准备与基础概念在开始配置前我们需要明确几个核心概念。iSCSI架构中Target指提供存储资源的服务端而Initiator则是连接并使用这些存储资源的客户端。tgtadm作为Linux平台最常用的iSCSI Target管理工具之一提供了命令行界面来创建和管理存储资源。1.1 系统要求与软件安装推荐使用CentOS/RHEL 7或Ubuntu 18.04作为服务器操作系统。不同发行版的安装命令略有差异# CentOS/RHEL sudo yum install scsi-target-utils sudo systemctl enable tgtd sudo systemctl start tgtd # Ubuntu/Debian sudo apt-get install tgt sudo systemctl enable tgt sudo systemctl start tgt安装完成后可通过以下命令验证服务状态systemctl status tgtd提示如果系统启用了SELinux需要额外配置策略或将其设置为permissive模式以避免访问限制。1.2 存储设备准备在配置iSCSI Target前需要确定用于共享的存储设备。可以是物理磁盘如/dev/sdb磁盘分区如/dev/sdb1逻辑卷如/dev/vg_data/lv_shared文件镜像通过dd创建使用文件作为后端存储的创建方法dd if/dev/zero of/var/lib/tgt/disk1.img bs1M count1024这将创建一个1GB大小的虚拟磁盘文件。2. 基础Target配置实战2.1 创建iSCSI Target使用tgtadm创建Target的基本语法结构为tgtadm --lld iscsi --op new --mode target --tid [TID] -T [IQN]其中--lld iscsi指定使用iSCSI驱动--op new表示新建操作--mode target操作对象为Target--tid指定Target ID数字-T指定IQN名称格式固定实际创建示例tgtadm --lld iscsi --op new --mode target --tid 1 -T iqn.2023-08.com.example:storage.disk1IQN命名规范以iqn.开头年月2023-08反向域名com.example自定义标识storage.disk12.2 添加LUN设备创建Target后需要为其添加逻辑单元(LUN)tgtadm --lld iscsi --op new --mode logicalunit --tid 1 --lun 1 -b /dev/sdb1关键参数说明参数说明--tid目标Target ID--lun逻辑单元号通常从1开始-b后端存储设备路径可同时添加多个LUNtgtadm --lld iscsi --op new --mode logicalunit --tid 1 --lun 1 -b /dev/sdb1 tgtadm --lld iscsi --op new --mode logicalunit --tid 1 --lun 2 -b /dev/sdc12.3 访问控制配置默认情况下新建的Target不允许任何客户端连接。需要设置访问控制规则允许特定IP段访问tgtadm --lld iscsi --op bind --mode target --tid 1 -I 192.168.1.0/24允许所有IP访问不推荐生产环境使用tgtadm --lld iscsi --op bind --mode target --tid 1 -I ALL3. 高级配置与管理3.1 持久化配置通过tgtadm直接创建的配置在服务重启后会丢失。需要将配置保存到文件tgt-admin --dump /etc/tgt/conf.d/targets.conf配置文件示例target iqn.2023-08.com.example:storage.disk1 backing-store /dev/sdb1 backing-store /dev/sdc1 initiator-address 192.168.1.0/24 /target3.2 性能优化参数在配置文件中可以添加性能调优参数target iqn.2023-08.com.example:storage.fast backing-store /dev/nvme0n1p1 write-cache off MaxRecvDataSegmentLength 262144 MaxXmitDataSegmentLength 262144 InitialR2T No ImmediateData Yes /target关键性能参数说明write-cache控制写入缓存off更安全但性能略低Max*DataSegmentLength增大可提升大块数据传输效率InitialR2T和ImmediateData设置为No/Yes可减少延迟3.3 多路径配置为提高可靠性可以配置多路径IO(MPIO)tgtadm --lld iscsi --op new --mode target --tid 2 -T iqn.2023-08.com.example:storage.mpio tgtadm --lld iscsi --op new --mode logicalunit --tid 2 --lun 1 -b /dev/sdd tgtadm --lld iscsi --op bind --mode target --tid 2 -I 192.168.1.100 tgtadm --lld iscsi --op bind --mode target --tid 2 -I 192.168.2.100客户端需要配置多路径软件如multipath-tools来识别和管理多条路径。4. CHAP认证配置4.1 CHAP基础概念CHAP(Challenge-Handshake Authentication Protocol)为iSCSI连接提供认证安全层防止未授权访问。它通过三次握手验证客户端身份且在会话过程中会多次验证比单纯的IP过滤更安全。CHAP分为两种单向CHAP仅验证客户端双向CHAP客户端和服务端相互验证4.2 配置单向CHAP创建CHAP账户tgtadm --lld iscsi --op new --mode account --user alice --password Str0ngPss将账户绑定到Targettgtadm --lld iscsi --op bind --mode account --tid 1 --user alice配置文件中的表示方式target iqn.2023-08.com.example:storage.secure backing-store /dev/sde1 incominguser alice Str0ngPss /target4.3 配置双向CHAP双向CHAP需要额外设置服务端凭证tgtadm --lld iscsi --op new --mode account --user server-auth --password S3rv3rPss tgtadm --lld iscsi --op bind --mode account --tid 1 --user server-auth --outgoing配置文件表示target iqn.2023-08.com.example:storage.mutual backing-store /dev/sdf1 incominguser client-auth Cl13ntPss outgoinguser server-auth S3rv3rPss /target4.4 CHAP最佳实践密码长度至少12字符包含大小写字母、数字和特殊符号定期轮换密码通过脚本自动化为不同客户端分配独立账户避免在命令行直接使用密码推荐通过配置文件设置测试环境可以先使用简单密码生产环境必须使用强密码5. 运维与故障排查5.1 常用监控命令查看所有Target信息tgtadm --lld iscsi --op show --mode target查看具体Target的详细配置tgtadm --lld iscsi --op show --mode target --tid 1查看活动会话tgtadm --lld iscsi --op show --mode conn5.2 常见问题解决问题1客户端无法发现Target检查步骤确认tgtd服务运行状态检查防火墙是否开放3260端口验证网络连通性检查Target的访问控制列表问题2CHAP认证失败排查方法确认用户名和密码完全匹配包括大小写检查账户是否已正确绑定到Target对于双向CHAP确认两端配置一致查看系统日志获取详细错误信息journalctl -u tgtd -f5.3 性能监控与优化使用iSCSI内置统计功能tgtadm --lld iscsi --op show --mode stat关键性能指标监控项指标说明健康值参考rx_data_octets接收数据量根据网络带宽评估tx_data_octets发送数据量根据网络带宽评估cmd_pdus处理命令数持续高值可能需优化digest_err校验错误应为0对于高性能需求场景可以考虑使用专用网卡和网络进行iSCSI传输启用Jumbo FrameMTU 9000使用高性能存储设备如NVMe SSD调整TCP参数如增大窗口大小

相关文章:

Linux下iSCSI服务端配置全攻略:从tgtadm基础到CHAP认证实战

Linux下iSCSI服务端配置全攻略:从tgtadm基础到CHAP认证实战 在当今企业级存储解决方案中,iSCSI凭借其基于IP网络的灵活性和成本效益,成为构建存储区域网络(SAN)的热门选择。不同于传统的FC-SAN需要专用硬件,iSCSI允许通过标准以太…...

智能感知编码:从技术原理到行业落地

1. 智能感知编码的技术背景 视频内容爆炸式增长的时代已经到来。从短视频平台到在线教育,从直播电商到远程医疗,高清视频正成为信息传递的主要载体。但随之而来的带宽成本压力也让从业者头疼不已——数据显示,某头部短视频平台每月带宽成本高…...

RS-485接口实战避坑指南:从终端电阻到EMC防护的完整配置流程

RS-485接口实战避坑指南:从终端电阻到EMC防护的完整配置流程 在工业自动化现场调试中,RS-485总线的稳定性往往决定着整个系统的可靠性。记得去年参与某钢铁厂轧机控制系统改造时,一个简单的终端电阻配置错误导致整条产线通信中断8小时——这种…...

PP-DocLayoutV3技术解析:其视觉Transformer骨干网络设计

PP-DocLayoutV3技术解析:其视觉Transformer骨干网络设计 文档智能处理,比如从一张扫描的合同或报告里自动识别出标题、段落、表格和图片,听起来简单,做起来却不容易。传统的模型在处理复杂的版面,尤其是那些元素之间距…...

RMBG-2.0AR内容准备:为Unity/Unreal引擎快速提供带Alpha通道素材

RMBG-2.0:为Unity/Unreal引擎快速提供带Alpha通道素材 你是不是也遇到过这样的场景?在Unity或Unreal引擎里做项目,好不容易找到一张完美的角色原画、一个酷炫的武器模型贴图,或者一个绝佳的环境素材,结果发现它没有透…...

科研助手:OpenClaw+Qwen3-32B自动整理文献与生成综述

科研助手:OpenClawQwen3-32B自动整理文献与生成综述 1. 为什么需要AI科研助手? 作为一名经常需要阅读大量文献的研究者,我发现自己花费在文献整理和综述写作上的时间越来越多。每次开始一个新课题,都要经历下载几十篇PDF、快速浏…...

Pixel Dimension Fissioner保姆级教学:离线环境部署像素工坊及本地模型缓存策略

Pixel Dimension Fissioner保姆级教学:离线环境部署像素工坊及本地模型缓存策略 1. 工具介绍与核心价值 Pixel Dimension Fissioner(像素语言维度裂变器)是一款基于MT5-Zero-Shot-Augment核心引擎构建的文本改写与增强工具。它将传统AI工具…...

Step3-VL-10B-Base辅助计算机组成原理教学:CPU架构图智能讲解

Step3-VL-10B-Base辅助计算机组成原理教学:CPU架构图智能讲解 1. 引言:当图解助教走进课堂 计算机组成原理这门课,很多同学都有过类似的体验:面对教材里那些密密麻麻的CPU微架构图、数据通路图,感觉就像在看一张复杂…...

ESP32高精度时间同步数据记录组件esp_datalogger

1. 项目概述esp_datalogger是一个专为 ESP32 系列微控制器(基于 ESP-IDF 开发框架)设计的轻量级、高精度数据记录与时间同步组件。它并非通用型日志库,而是面向工业测量与控制(M&C)场景深度优化的嵌入式数据处理中…...

ESP32专用VEML6040四通道环境光传感器驱动详解

1. 项目概述esp_veml6040是专为 ESP32 系列微控制器(兼容 ESP-IDF v4.4)设计的高性能 IC 外设驱动组件,面向 Vishay 公司推出的 VEML6040 四通道环境光与色彩传感器。该组件并非简单封装,而是深度适配 ESP-IDF 架构的工程化实现&a…...

Harmonyos应用实例154:平行四边形性质探索器

应用实例四:平行四边形性质探索器 知识点:第十八章《平行四边形》—— 平行四边形的性质与判定。 功能:学生拖动顶点改变四边形形状。应用实时检测并显示:是否为平行四边形。若不是,显示需要满足什么条件(如“对边不平行”或“对角不相等”),辅助理解判定定理。 @En…...

Python3.9镜像作品展示:多项目环境管理,效果一目了然

Python3.9镜像作品展示:多项目环境管理,效果一目了然 1. Python3.9镜像核心价值 Python3.9镜像是一个轻量级的Python环境管理工具,它能帮助开发者快速创建独立的开发环境,有效避免软件包之间的版本冲突。这个镜像自带pip等基本工…...

SAMD21 DAC音频播放库:8位PCM单声道嵌入式实现

1. SAMD21 Audio Player 库深度解析:基于Arduino Nano 33 IoT的8位单声道音频播放实现1.1 项目定位与工程价值SAMD21 Audio Player 是一个面向资源受限嵌入式平台的轻量级音频播放库,专为基于ATSAMD21G微控制器(如Arduino Nano 33 IoT、MKR Z…...

RexUniNLU在VSCode智能编程插件中的实践:代码注释自动生成

RexUniNLU在VSCode智能编程插件中的实践:代码注释自动生成 1. 引言 作为一名每天要与代码打交道的开发者,你是否曾经为编写代码注释而头疼?那些看似简单却耗费时间的注释工作,往往让我们的开发效率大打折扣。传统的注释方法要么…...

嵌入式C全局变量工程化约束与替代方案

1. 嵌入式C开发中全局变量的工程化约束原则在资源受限的单片机无操作系统(OS-less)环境中,全局变量的滥用已成为系统性缺陷的首要技术诱因。本文不讨论语法层面的“能否使用”,而是从硬件资源约束、软件可维护性、实时性保障三个维…...

Phi-3 Forest Lab应用场景:学生自主学习解题思路教练

Phi-3 Forest Lab应用场景:学生自主学习解题思路教练 1. 引言:当学生遇到难题时,他们需要什么? 想象一下这个场景:一个学生深夜坐在书桌前,面对一道复杂的数学题或物理题,已经思考了半小时&…...

手把手教你用Z3求解器破解GXYCTF2019的CPP逆向题(附完整脚本)

用Z3求解器高效破解CTF逆向题的实战指南 在CTF竞赛中,逆向工程类题目往往需要选手分析二进制程序,理解其内部逻辑并提取关键信息。本文将深入探讨如何利用Z3求解器这一强大的数学工具,高效解决复杂的逆向题目。我们以GXYCTF2019的一道典型CPP…...

Hackintool实战指南:零基础掌握黑苹果系统配置

Hackintool实战指南:零基础掌握黑苹果系统配置 【免费下载链接】Hackintool The Swiss army knife of vanilla Hackintoshing 项目地址: https://gitcode.com/gh_mirrors/ha/Hackintool 黑苹果系统配置过程中,硬件识别不准确、驱动不匹配、启动参…...

STM32L476G-DISCO BSP驱动库深度解析与低功耗实战

1. BSP_DISCO_L476VG:STM32L476G-Discovery开发板底层驱动库深度解析1.1 项目定位与工程价值BSP_DISCO_L476VG 是 STMicroelectronics 官方为 STM32L476G-DISCO 开发板提供的板级支持包(Board Support Package),版本号 V1.0.0。该…...

Pulse1:轻量级NEC红外协议嵌入式解码库

1. 项目概述Pulse1 是一个面向嵌入式系统的轻量级红外(IR)遥控协议解析库,专为 NEC(Nuclear Electronic Corporation)红外通信协议设计与实现而优化。该库由开发者 tony63 原创编写,并明确声明“Usada bajo…...

B端拓客号码核验困境破解:行业痛点审视与技术赋能路径氪迹科技法人股东号码核验系统

在B端客户拓展的实践过程中,企业法人、股东及核心决策人号码的核验与筛选,是所有拓客团队都必须面对的关键前置工作。人工手动筛选不仅消耗大量人力与时间成本,更无法适配规模化拓客的发展需求;而借助工具开展核验,又往…...

收藏!小白程序员必看:轻松分清 Automation/Workflow/Agent,AI 应用不再难!

很多团队现在最容易犯的错,不是不会做 AI,而是一上来就说自己要做 Agent。 结果最后做出来的,可能只是: 一个固定规则的自动化脚本一个接了几个大模型节点的工作流一个看起来很聪明、实际上既贵又不稳的半成品系统 问题往往不在模…...

Windows触控板驱动终极指南:让苹果设备在Windows上完美运行

Windows触控板驱动终极指南:让苹果设备在Windows上完美运行 【免费下载链接】mac-precision-touchpad Windows Precision Touchpad Driver Implementation for Apple MacBook / Magic Trackpad 项目地址: https://gitcode.com/gh_mirrors/ma/mac-precision-touchp…...

MLX90614红外测温模块的SMBus驱动与嵌入式实现

1. MLX90614红外测温模块技术解析与嵌入式驱动实现1.1 非接触式测温原理与器件选型依据在工业控制、医疗设备及消费电子领域,温度测量的精度、响应速度与测量方式直接影响系统可靠性。传统接触式测温依赖热传导建立热平衡,存在响应滞后(典型值…...

跨模态融合Transformer在多光谱目标检测中的技术深度解析与应用实践

跨模态融合Transformer在多光谱目标检测中的技术深度解析与应用实践 【免费下载链接】multispectral-object-detection Multispectral Object Detection with Yolov5 and Transformer 项目地址: https://gitcode.com/gh_mirrors/mu/multispectral-object-detection 多光…...

CH9329串口转键鼠实战:从硬件对接到HID指令解析

1. CH9329模块初探:串口转键鼠的神奇桥梁 第一次拿到CH9329这个拇指大小的模块时,我完全没想到它能通过串口指令精准控制电脑的键鼠操作。这个由南京沁恒推出的USB转串口芯片,本质上是个HID协议翻译器——它把串口传来的原始数据包转换成电脑…...

RK3566 SPI设备节点实战:从内核配置到用户空间spidev3.0测试

1. RK3566 SPI开发基础与实战意义 SPI总线作为嵌入式系统中最常用的通信协议之一,在RK3566这类高性能处理器上的应用尤为广泛。我最近在立创泰山派开发板上折腾SPI设备时,发现很多新手都会卡在内核配置和用户空间测试的衔接环节。这篇文章就来手把手带你…...

FPGA设计效率翻倍:深度拆解Quartus中RAM与FIFO IP核的选型、配置与在DDS中的实战应用

FPGA设计效率翻倍:深度拆解Quartus中RAM与FIFO IP核的选型、配置与在DDS中的实战应用 在FPGA开发中,IP核的高效利用往往是区分普通工程师与资深专家的关键分水岭。当项目复杂度提升到需要处理高速数据流、多时钟域交互或大容量存储时,RAM和FI…...

ESP32实战:SD卡存储与HUB75点阵屏的GIF动态播放系统

1. ESP32与HUB75点阵屏的完美组合 ESP32作为一款功能强大的微控制器,凭借其双核处理器、丰富的外设接口和出色的无线连接能力,已经成为物联网和嵌入式开发的热门选择。而HUB75接口的LED点阵屏,则以其高亮度、高刷新率和模块化拼接特性&#x…...

【技术干货】Google 全新 AI Studio Build Mode 深度解析:从多人与物理仿真到全栈应用的自动生成

摘要 Google 全新升级的 AI Studio(构建模式 / Agent 模式)已经从“写点前端 Demo”进化为“自动搭建可上线的全栈应用平台”:支持实时多人游戏、三维粒子交互、物理仿真、Firebase 深度集成、GitHub 自动发布等。本文结合视频内容&#xff0…...