SSD固态硬盘的GC与Trim

操作系统:其实并没有删除数据;

 事实上,它只是在硬盘前的索引区里标记这块文件占用的区域为无效的,

 所以等该区域被擦除后,下次数据将要再次写入的时候,可以写入这块被标记的区域。

 这也就是为啥那 些所谓的文件恢复软件能恢复的道理。(数据依然存在)。

固态硬盘:在固态硬盘闪存内,数据存储一般是以page(页)为最小单位存储的(典型的为4KB),而128个page组成了一个block(块),

数据以页(page)为单位来读取和写入,但却只能以块(Block)为单位来删除。

 当读取数据或者写入到一个没有被使用过的page上时,固态硬盘的速度是很快的,

 但是在无效数据区上的话,就比较复杂了,需要许多步骤来完成。

*注意:硬盘本身是不知道当前数据的状态的,他只是被控制着做这做那。

 上面这一套在普通的机械硬盘上工作起来非常完美,因为他们可以直接覆写旧的区域,

 但是当用到NAND闪存上就行不通了,当全部闪存被写满一遍后,没有空余 (从未写过)的块可以被使用的情况下,速度就下来了。

GC:要覆写(这里指在无效数据区域写)一个4KB 页的文件系统,首先要把整个512KB 块复制进缓存里。

 然后,在缓存里删除这个4KB页,替换成新的数据。

 接下来,清空整个闪存内的这个512KB区域,并从缓存里把新的数据写回去。

Trim:SSD一样会复制整个包含删除数据的块到缓存,清空块并写入有效数据的页回去,

区别是这样等于把这个延迟时间从覆写数据的那个时间提前到了删除数据的时候

简而言之,这个问题是因为操作系统和文件系统不能和SSD的主控进行删除文件的交流造成的,

 如果有之前没清除干净的数据,所有写入的页的操作都要先清除块再改写,将严重影响写入速度。

 有2种途径来修复这个问题:

第一个:定期运行垃圾回收程序(GC)

 这个操作有点像整理,在SSD空闲时,全盘扫描有效的页并合并整理起来变为一个包含全部有效页的块,而那些无效的页和块都将被完全的清除。

第二个:更好的途径就是当数据删除时候让系统告诉SSD数据没了,让SSD立即擦掉那些数据占用的块,这就是Trim命令做的事。

 当一个文件在支持Trim的系统里被删除后,操作系统会发个命令给SSD,

 让他知道这个数据所在的这个page可以直接被写入,

 等于把控制权从操作系统变 为了SSD主控制器固件。

总结:Trim保证速度不下跌的真正秘密是: 把将来要做的事提前做掉了, 但是这件事迟早要做,所以基本不会影响SSD原有的写入次数(寿命)。

Trim的三要素:

  1. 系统: Win7, 2008R2 , Linux核心2.6.28以上。

  2. 固件: SSD的厂商在固件里要放有Trim算法。

  3. 驱动: MS的驱动,Intel的AHCI驱动目前支持。 别的要看之后的更新了。

以上3点缺一不可。

RAID阵列里的盘明确不支持TRIM,不过RAID可以支持GC。

参考:http://blog.csdn.net/dayancn/article/details/52054664

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏枕边书

PHP 调用 Go 服务的正确方式 - Unix Domain Sockets

问题 可能是由于经验太少,工作中经常会遇到问题,探究和解决问题的过程总想记录一下,所以我写博客经常是问题驱动,首先介绍一下今天要解决的问题: 服务耦合 我们在开...

24911
来自专栏原创

五个最佳案例带你解读Node.js的前后之道

Node.js 是什么? Node.js采用C++语言编写而成,浏览器内核V8做为执行引擎;Node不是JS应用、而是一个Javascript的运行环境。Nod...

36010
来自专栏分布式系统进阶

Kafka Manager实现原理与填坑

props.put("group.id", "KafkaManagerOffsetCache")这句说明不管启动了几个kafka manager, 消费"__c...

2622
来自专栏高性能服务器开发

(八)高性能服务器架构设计总结4——以flamigo服务器代码为例

一个项目的服务器端往往由很多服务组成,就算单个服务在性能上做到极致,支持的并发数量也是有限的。举个简单的例子,假如一个聊天服务器,每个用户的信息是1k,那对于一...

865
来自专栏Kevin-ZhangCG

J2EE规范总结

1465
来自专栏Golang语言社区

golang插件化方案

业务线的活动,每一次新活动都做独立项目开发,有大量重复代码,并且浪费数据服务的连接资源;排序服务也许要经常添加业务代码,目前是停服务发布……这些场景为了开发维护...

1382
来自专栏JetpropelledSnake

Python Web学习笔记之WebSocket 通信过程与实现

1266
来自专栏恰同学骚年

.NET Core微服务之服务间的调用方式(REST and RPC)

  微服务之间的接口调用通常包含两个部分,序列化和通信协议。常见的序列化协议包括json、xml、hession、protobuf、thrift、text、by...

1196
来自专栏喵了个咪的博客空间

1.开发规范-- 常用的版本控制

#常用的版本控制# ##前言## 这里版本控制是经过笔者在项目中实践总结得出的,有比较广的适用范围, 当然也要根据不同的业务有取舍应为笔者水平有限,其中有不足的...

36410
来自专栏哲学驱动设计

OEA 2.11 支持单机版数据库 - SQLite与SQLCE对比

在 OEA 平台 设计中,需要支持多种数据库,这至少包括了 SqlServer、Oracle、一个单机文件数据库。而之前对于这一块,我们一直没有实现,只是预留了...

1807

扫码关注云+社区