AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 499577
Accepted
MrCalvin
MrCalvin
Asked: 2019-02-09 15:10:46 +0800 CST2019-02-09 15:10:46 +0800 CST 2019-02-09 15:10:46 +0800 CST

文件系统 (ext4) 如何“存储”TRIM 信息?

  • 772

建议启用每周运行一次的 TRIM cron 作业。当调用 fstrim 命令时,文件系统会将 TRIM 信息发送到驱动器以丢弃已删除的数据(我希望我做对了)

到目前为止这么好,这个描述很多地方。

但是我找不到有关这些 TRIM 信息在 fstrim 命令之间的文件系统中“存储”方式/位置的任何信息?

是否可以以某种方式“清除”这些 TRIM 信息,以便 SSD 不会获得所有必须丢弃的页面/块的信息?

或者 fstrim 命令会比较文件系统和 SSD 的实际删除数据吗?

ssd trim
  • 1 1 个回答
  • 1975 Views

1 个回答

  • Voted
  1. Best Answer
    frostschutz
    2019-02-09T15:42:43+08:002019-02-09T15:42:43+08:00

    我不知道 ext4 是否真的将它存储在任何地方。其他文件系统当然不会。

    ext4 仅在当前会话中避免它已经修剪的内容 - 当它仍然安装时。一旦您重新启动或重新挂载文件系统,它就会再次修剪空白空间。

    所以这可能是一个根本不存储的内存结构。我没有深入研究非常精细的源代码来找出答案。

    一个小测试:

    # truncate -s 1G /dev/shm/foobar.img
    # losetup --find --show /dev/shm/foobar.img
    /dev/loop9
    # mkfs.ext4 /dev/loop9
    # mkdir /mnt/loop
    

    给定一个 1G 的文件系统,让我们挂载和修剪它:

    # mount /dev/loop9 /mnt/loop/
    # fstrim -v /mnt/loop
    /mnt/loop: 973.4 MiB (1020678144 bytes) trimmed
    # fstrim -v /mnt/loop
    /mnt/loop: 0 B (0 bytes) trimmed
    

    所以它首先修剪所有......毕竟,这已经很可疑了:mkfs 也已经修剪过(哎哟),所以它应该知道它仍然是空的和修剪过的,对吧?好吧,如果它知道,它不在乎:

    # umount /mnt/loop
    # mount /dev/loop9 /mnt/loop
    # fstrim -v /mnt/loop
    /mnt/loop: 973.4 MiB (1020678144 bytes) trimmed
    

    因此,重新安装后,它只会再次修剪所有可用空间。

    创建和删除文件时,也不是精确的:

    # dd bs=1M count=10 if=/dev/zero of=/mnt/loop/zerofile
    10+0 records in
    10+0 records out
    10485760 bytes (10 MB, 10 MiB) copied, 0.0124641 s, 841 MB/s
    # sync
    # rm /mnt/loop/zerofile
    # fstrim -v /mnt/loop
    /mnt/loop: 117.5 MiB (123203584 bytes) trimmed
    

    因此,写入 10M 会导致重新修剪 117M。它只是没有任何意义。

    只有 SSD 本身才真正知道当前修剪了什么,没有修剪什么,当被要求修剪已经修剪的区域时,它应该什么都不做。所以没有伤害,也不需要真正将这些信息存储在文件系统中。

    • 7

相关问题

  • 命名此功能 - 自动将块从一种磁盘类型移动到另一种磁盘类型?

  • M.2 NVMe PCIe 启动时间比旧的 SATA SSD 慢得多

  • Duplicity 是否在备份时修改时间?

  • BtrFS 快照会杀死我的 SSD 吗?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve