AliOS Things KV组件的写平衡特性

简介: KV组件的写平衡(磨损平衡)特性就是通过异地更新、垃圾回收等策略来平衡flash介质各个存储区块的磨损程度,以避免某些“特定”存储区块因过度使用而形成坏区,从而延长flash的使用寿命。

前言


KV组件是AliOS Things中一个以Key-Value方式进行持久化存储的轻量级组件,主要为基于nor flash的小型MCU设备(Micro Control Unit)提供通用的Key-Value持久化存储接口。KV组件支持写平衡(磨损平衡)、掉电保护特性,且具有相当低的footprint。这里主要介绍KV组件在设计写平衡特性时的一些考量。

What -- KV组件的写平衡特性是什么


对于flash介质而言,它是有一定的擦写次数限制的。如果针对介质上一个固定地址进行重复的擦除、写入,将会导致该区域的使用寿命降低,甚至出现介质损坏的情况。KV组件的写平衡(磨损平衡)特性就是通过 异地更新、垃圾回收等策略来平衡flash介质各个存储区块的磨损程度,以避免某些“特定”存储区块因过度使用而形成坏区,从而延长flash的使用寿命。

Why -- KV组件为何需要写平衡特性

KV组件的设计初衷是为了给基于nor flash的小型MCU设备提供一个可以存储配置信息的模块。对于单个配置信息而言,一般所需存储的字节数大多在十几个字节~几百个字节量级,而一般nor flash的最小擦除单位(sector)都在4K字节以上,且根据flash介质需先擦再写的特点,如果没有写平衡特性,每次新写入或更新配置信息都会带来一次flash介质擦除操作,这将大大影响flash介质的使用寿命(一般nor flash的擦除次数限制大约10万次左右)。

下表是flash介质在有无写平衡特性下重复写入使用寿命的理论计算对比:
(限制条件:flash擦除sector大小为4k, 擦除次数限制为10W次,每日写入次数5000次)
有无写平衡特性 每次写入数据量(byte) 平均每日擦除次数 使用寿命
yes 50 ≈62 ≈4.4年
no 50 5000 20天
yes 500 610 ≈163天
no 500 5000 20天


根据上表的对比,KV组件的写平衡特性在几百个字节量级的写入情况下起码可以延长flash 8倍以上的使用寿命。

How -- KV组件写平衡特性的实现考量

由于小型物联网嵌入式设备的硬件资源较为匮乏,对code size以及RAM的占用size比较敏感。所以基于资源消耗的考量,写平衡特性在KV组件中的实现遵循make it simple原则,主要依赖以下两个策略来实现:

1. 异地更新策略:
Key-Value键值对采用顺序写入、异地更新的方式,即不再在原存储位置擦除重写,而是在其余空闲位置写入新键值并将原键值标记无效等待回收。这样既可以减少flash的擦除操作次数,又可以提高flash的空间利用率,也避免了对“特定”存储区块过度使用的问题。
示意图如下:

ea52cecb633d6303425c1e3c7242179fafd0327b

2. 垃圾回收策略:
当flash存储区块的剩余可用空间达到阈值时,会触发垃圾回收机制。垃圾回收机制采用基础的SGC算法进行资源回收释放,即当系统触发垃圾回收时,从当前写入块的下一个存储块开始依次检查存储块的管理状态,若存储块的管理状态为Dirty状态,则将该存储块中的有效数据依次挪向垃圾回收预留的空闲存储块,当数据迁移完成后,会擦除Dirty存储块并标记可用空闲状态。
示意图如下:

eafefafe8c7177b8aa3c4a23dd669b634c506bf7

小结

KV组件的写平衡特性,在兼顾footprint需求的同时,也能有效的提升flash的使用寿命。不过也是由于footprint的要求,写平衡特性在算法的实现相对较为简单,在资源更丰富的场景下,可以采用更复杂高效一些的平衡算法。以上是个人的一些拙见,有什么需求或者意见建议,欢迎访问github官网 https://github.com/alibaba/AliOS-Things
目录
相关文章
|
安全 物联网 API
AliOS Things组件功能介绍(三)
AliOS Things组件功能介绍(三)
221 0
|
缓存 网络协议 物联网
AliOS Things 3.3.0 : http组件介绍
HTTP(HyperText Transfer Protocol)是一款用于传输超文本的应用层协议。
AliOS Things 3.3.0 : http组件介绍
|
存储 安全 物联网
AliOS Things 3.3.0 : KV组件介绍
对于嵌入式系统应用中,频繁使用的参数存储,过程变量存储等操作,AliOS-Things为用户提供了一种更加直观易于理解的基于键值对的存储方式,如报警温度=50度,可以通过定义一个键值对:{“AlarmTemp”:50}来进行存储。
AliOS Things 3.3.0 : KV组件介绍
|
编解码 物联网 Linux
AliOS Things 3.3.0 : A2SA组件介绍
A2SA是Advanced AliOS Things Sound Architucture的缩写,是AliOS Things音频系统服务框架,包括音频驱动层、音频服务接口层以及音频插件管理等。
AliOS Things 3.3.0 : A2SA组件介绍
|
编解码 算法 物联网
【直播回放已上传】AliOS Things 组件玩法大爆炸,提需求有礼!!
1、2020年6月16日(周二)钉钉群直播,为您全面介绍AliOS Things组件能力。 2、AliOS Things产品研发团队喊你提需求啦,102个AOS-CUBE Cheat Sheet鼠标垫大放送!
【直播回放已上传】AliOS Things 组件玩法大爆炸,提需求有礼!!
|
安全 物联网 Java
AliOS Things 组件系统(uCube)
AliOS Things 是阿里巴巴提供的物联网操作系统,可以在不同的设备上运行不同的功能,甚至相同的设备运行不同的功能,AliOS Things 基于组件管理: 1、 组件功能单一,复用组件提供的功能,比如通道、升级等功能。
4377 0
|
物联网 Linux
【AliOS Things学习笔记】为你的AliOS Things应用增加自定义cli命令
怎么才能在RTOS系统中,通过 串口shell控制LED的开关。
3680 0
|
AliOS-Things 物联网 编译器
使用HaaS Studio开发AliOS Things C/C++应用
本文章将介绍使用HaaS Studio 进行AliOS-Things C/C++应用开发。
使用HaaS Studio开发AliOS Things C/C++应用
|
传感器 监控 算法
使用AliOS Things快速构建温度计应用 |《AliOS Things快速开发指南》
本文是基于AliOS Things 3.1快速构建温度计的应用场景。涉及AliOS Things组件开发,构建AliOS Things用户项目,AliOS Things HAL API使用,向AliOS Things中添加并使用组件。用到的硬件设备有半导体开发板、温度传感器、数码管显示器。
使用AliOS Things快速构建温度计应用 |《AliOS Things快速开发指南》
|
域名解析 移动开发 数据可视化
使用 AliOS Things 3.0 快速构建用户应用 BlinkAPP
AliOS Things 3.0版本于去年9月份在云栖大会正式发布,在新版本中带来了全新的应用开发框架,帮助用户快速构建自己的应用。使用户可以更专注于自身应用的开发。本文将已BlinkAPP为例,为大家演示如何快速使用应用开发框创建项目并完成应用代码编写。
972 0
使用 AliOS Things 3.0 快速构建用户应用 BlinkAPP

热门文章

最新文章

下一篇
无影云桌面