Hier werden die Unterschiede zwischen zwei Versionen gezeigt.
Nächste Überarbeitung | Vorherige Überarbeitung | ||
lpi2:ssd [2019/01/02 14:33] 127.0.0.1 Externe Bearbeitung |
lpi2:ssd [2024/05/20 16:11] (aktuell) |
||
---|---|---|---|
Zeile 4: | Zeile 4: | ||
Geräte mit 1 in der Spalte "ROTA" liegen auf rotierenden Geräten, Geräte mit 0 nicht. | Geräte mit 1 in der Spalte "ROTA" liegen auf rotierenden Geräten, Geräte mit 0 nicht. | ||
- | ====== Daten auf einer Partition oder SSD löschen & TRIM auslösen ====== | + | ===== alle Blockgeräte die discard unterstützen ===== |
+ | z.B. virtio (( | ||
+ | <file xml> | ||
+ | <disk type="file" device="disk"> | ||
+ | <driver name="qemu" type="qcow2" discard="unmap"/> | ||
+ | <target dev="vda" bus="virtio"/> | ||
+ | </file> | ||
+ | )) | ||
+ | lsblk -bo NAME,DISC-MAX | ||
+ | oder | ||
+ | grep -vxl 0 /sys/block/*/queue/discard_max_hw_bytes | sed -r 's:/sys/block/(.*)/queue/discard_max_hw_bytes:/dev/\1:' | ||
+ | (( | ||
+ | "__A discard_max_hw_bytes value of 0 means that the device does not support discard functionality.__" | ||
+ | https://www.kernel.org/doc/html/latest/block/queue-sysfs.html#discard-max-bytes-rw | ||
+ | )) | ||
+ | ====== Ganzen Inhalt einer Partition oder SSD löschen & TRIM auslösen ====== | ||
((Optional (damit man es besser sieht) Einsen auf die Partition schreiben: | ((Optional (damit man es besser sieht) Einsen auf die Partition schreiben: | ||
tr '\0' '\377' < /dev/zero | dd of=/dev/sda2 bs=1MiB status=progress | tr '\0' '\377' < /dev/zero | dd of=/dev/sda2 bs=1MiB status=progress | ||
Zeile 55: | Zeile 70: | ||
hdparm --read-sector 14884863 /dev/sda | hdparm --read-sector 14884863 /dev/sda | ||
-> sollte lauter Nullen ausgeben)) | -> sollte lauter Nullen ausgeben)) | ||
+ | |||
===== regelmäßig "trimmen" ===== | ===== regelmäßig "trimmen" ===== | ||
- | Laut [[https://wiki.debian.org/SSDOptimization#Mounting_SSD_filesystems|Debian Wiki]] ab Version 10 (Buster) nicht mehr nötig, unter Ubuntu 18.04 default: | + | |
+ | Ab Debian 10 und Ubuntu 18.04 default: | ||
systemctl edit --force fstrim.timer | systemctl edit --force fstrim.timer | ||
<file txt /etc/systemd/system/fstrim.timer> | <file txt /etc/systemd/system/fstrim.timer> | ||
Zeile 86: | Zeile 103: | ||
====== kontinuierlich freie Bereiche eines Dateisystems "trimmen" ====== | ====== kontinuierlich freie Bereiche eines Dateisystems "trimmen" ====== | ||
- | TODO: verlangsamt laut diversen Webseiten die Geschwindikeit in der Dateien gelöscht werden, da nach dem Löschen jeder Datei die SSD informiert wird -> prüfen | + | TODO: verlangsamt laut diversen Webseiten die Geschwindigkeit in der Dateien gelöscht werden, da nach dem Löschen jeder Datei die SSD informiert wird -> prüfen |
mount -o discard /dev/sda2 /mnt/ext4 | mount -o discard /dev/sda2 /mnt/ext4 | ||
- | |||
((Prüfen: | ((Prüfen: | ||
Datei mit lauter Einsen anlegen und wieder löschen: | Datei mit lauter Einsen anlegen und wieder löschen: | ||
Zeile 113: | Zeile 129: | ||
watch hdparm --read-sector 14874624 /dev/sda | watch hdparm --read-sector 14874624 /dev/sda | ||
-> sollte (spätestens nach ein paar Minuten) lauter Nullen ausgeben)) | -> sollte (spätestens nach ein paar Minuten) lauter Nullen ausgeben)) | ||
+ | BTRFS: "Since kernel 6.2 the discard=async mount option is automatically enabled on devices that support that" -> "freed file extents are first tracked in memory and after a period or enough ranges accumulate the trim is started, expecting the ranges to be much larger and allowing to throttle the number of IO requests which does not interfere with the rest of the filesystem activity" | ||
====== kontinuierlich freie Bereiche im LVM "trimmen" ====== | ====== kontinuierlich freie Bereiche im LVM "trimmen" ====== | ||
- | Beim löschen und verkleinern von Logical Volumes frei werdende Bereiche "trimmen": TODO: warum ist das nicht default? | + | Beim Löschen und verkleinern von Logical Volumes frei werdende Bereiche "trimmen": (( |
+ | warum ist das nicht default? | ||
+ | |||
+ | Aus https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=717313 : | ||
+ | "Even with the automatic backups of the lvm metadata, it is impossible to recover from the wrongly removed LV. This is the reason why this feature is off by default." und "The discards commands will also be issued when shrinking or moving a LV to an other PV, if something is going wrong during these operations, the data will be lost. So it's not only when explicitly removing an LV." | ||
+ | |||
+ | Alternative: so ähnlich wie man regelmäßig fstrim aufruft, kann man die leeren Blöcke einer Volume Group behandeln: | ||
+ | |||
+ | <file txt /etc/systemd/system/fstrim.service.d/vg.conf> | ||
+ | [Service] | ||
+ | ExecStart=lvcreate -l100%FREE -n trim your_volume_group | ||
+ | ExecStart=blkdiscard /dev/your_volume_group/trim | ||
+ | ExecStart=lvremove your_volume_group/trim | ||
+ | </file> | ||
+ | )) | ||
<file txt /etc/lvm/lvm.conf> | <file txt /etc/lvm/lvm.conf> | ||
… | … |