详解ZNS SSD基本原理

图片

ZNS SSD的原理是把namespace空间划分多个zone空间,zone空间内部执行顺序写。这样做的优势:

  • 降低SSD内部的写放大,提升SSD的寿命

  • 降低OP空间,host可以获得更大的使用空间

  • 降低SSD内部DRAM的容量,降低整体的SSD成本

  • 降低SSD写延迟

  • ZNS写入了标准NVME协议,更易于打造软件生态,利于普及

图片

与SMR架构类似,ZNS SSD的zone空间内部,也是追加写。每次顺序写完成后,有一个标记位“Write Pointer”来记录已经写过数据所在的LBA位置。

图片

Zone的状态有以下几个:

  • Full:zone写满的状态

  • Empty:zone数据空的状态

  • Explicitly Opened:对zone执行open zone命令成功后的状态

  • Implicitly Opened:对处于Empty或者Closed状态的zone完成写数据后的状态

  • Closed:还未写满的zone,在close zone命令成功后的状态

  • Read Only:处于只读状态的zone

  • Offline:zone处于异常状态,可能是介质异常或者其他的问题

图片

在Linux内核适配方面,针对zoned设备,之前针对SMR已经有ZAC/ZBC命令规范,并在4.10内核已经支持。针对ZNS SSD,在内核5.10以后也支持了ZNS SSD,软件生态已经基本完善。

图片

在传统的SSD中,SSD控制器会搭配10-100个NAND Die存储介质,管理这些NAND介质就需要一个强大的算法,这里就有一个FTL管理层。

图片

在这个过程中,ZNS SSD最大的优势是取消了块接口税(Block Inteface Tax)

图片

图片

与传统Block SSD相比,性能更加稳定,不受OP的影响。

图片

如果在文件系统层删除一个文件,比如下图文件C,在没有GC搬迁的情况下,会在无效数据C会占用大量的存储空间。

图片

GC搬迁有效数据到空的block后,之前无效文件C所在数据块block就可以被整个block擦除了。

图片

整个GC的过程最终导致写放大WAF的增加。写放大的增加相应对SSD带来的负面效应就是写带宽下降、读延迟升高、使用寿命下降等问题

在ZNS的场景下,不同应用按照Zone配置信息,相应存放业务数据。主要集中在顺序读写的workload场景。由于是Host管理数据的摆放和存取位置,会最大程度减少GC垃圾回收。

图片

减少SSD的DRAM空间和去掉OP冗余空间,提升用户可用的容量。

图片

二者具体的优劣对比:

图片

扩展阅读:NVMe SSD:ZNS与FDP对决,你选谁?

### ZNS SSD 的定义 Zone Namespaces (ZNS) SSD 是一种新型的固态硬盘技术,旨在通过重新设计存储接口来优化闪存介质的工作方式。与传统的基于块的传统 NVMe SSD 不同,ZNS SSD 将物理 NAND 闪存划分为多个独立区域(zones),每个区域都具有固定的大小并支持顺序写入操作[^1]。 这种分区方法使得主机能够更好地控制数据放置位置,并减少了垃圾回收过程中所需的额外开销。此外,由于采用了更高效的地址映射机制,ZNS SSD 可以显著减少 DRAM 使用量和过度配置比例(OP),从而降低了整体成本[^2]。 ### ZNS SSD 的工作原理 #### 数据写入流程 当应用程序向 ZNS SSD 发起写请求时: - 主机首先会查询哪些 zone 处于可写状态; - 接着选择一个合适的可用 zone 进行连续的数据写入; - 如果当前 zone 写满,则自动切换到下一个未使用的 zone 继续写入过程; 这种方式确保了所有新数据都被追加到现有内容之后,而不是随机分布在各个地方,这有助于提高读取性能并延长设备寿命。 #### 垃圾回收机制 对于已经完成写周期或包含无效扇区的 zones: - 设备内部维护了一个列表用于跟踪这些不可再用的空间; - 当某个 zone 被标记为空闲后,它会被清理以便再次接受新的写入命令; - 清理过程中只涉及有效数据搬移而不影响其他正常工作的 zones; 这种方法不仅简化了磨损均衡算法的设计难度,同时也提高了整个系统的稳定性和可靠性。 ```python def write_data_to_zns_ssd(data_chunk): available_zones = get_available_zones() for chunk in data_chunk: current_zone = select_next_writeable_zone(available_zones) while not is_zone_full(current_zone): append_data(chunk, current_zone) mark_as_used(current_zone) update_zone_state() def garbage_collection(): stale_zones = identify_stale_or_invalid_zones() for zone in stale_zones: valid_data = move_valid_data_from(zone) erase_and_reset_zone(zone) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

古猫先生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值