Sparse files (разряженные файлы): различия между версиями

Материал из sysadm
Перейти к навигации Перейти к поиску
Строка 12: Строка 12:
  
 
# сейчас утилита копирования cp поддерживает sparse файлы
 
# сейчас утилита копирования cp поддерживает sparse файлы
# --sparse=auto    (сейчас по умолчанию) если источник является sparse, то файл назначения тоже будет sparse
+
# --sparse=auto    (по умолчанию в RHEL10, в других дистрибутивах не проверялось) если источник является sparse, то файл назначения тоже будет sparse
 
# --sparse=never    файл назначения будет не sparse
 
# --sparse=never    файл назначения будет не sparse
 
# --sparse=always  файл назначения будет sparse
 
# --sparse=always  файл назначения будет sparse
Строка 30: Строка 30:
 
# даже если они не были sparse и архивировались без опции --sparse
 
# даже если они не были sparse и архивировались без опции --sparse
 
tar --sparse -xJvf /path/to/file.tar.xz
 
tar --sparse -xJvf /path/to/file.tar.xz
 +
 +
# утилита du (disk usage)
 +
du /path/to/file                  # объем занимаемый на диске, в том числе с учетом sparse
 +
du --apparent-size /path/to/file  # логический размер файла, то что отображает ls -l --block-size=K
 +
 +
# утилита ls
 +
ls -ls /path/to/file    # отдельно в первом столбце отображает размер занимаемый на диске в блоках, в том числе с учетом sparse
  
 
</pre>
 
</pre>

Версия 01:09, 24 июля 2025

Ссылки по теме

Если файл содержит большие фрагменты заполненные нулями, то они могут быть вырезаны и место занимаемое файлом частично освободится, при этом логический размер не изменится.

# вырезание пустот (преобразование обычного файла в sparse файл)
fallocate -d </path/to/file>

# сейчас утилита копирования cp поддерживает sparse файлы
# --sparse=auto     (по умолчанию в RHEL10, в других дистрибутивах не проверялось) если источник является sparse, то файл назначения тоже будет sparse
# --sparse=never    файл назначения будет не sparse
# --sparse=always   файл назначения будет sparse
# пример конвертации в sparse
cp --sparse=always /path/to/file1 /path/to/file2

# к сожалению dar исключен из репозитория RHEL10

# актуальная версия tar поддерживает sparse
# пример архивации с конвертацией в sparse
tar --sparse -cJvf /path/to/file.tar.xz /path/to/file.dat

# если файл архива был создан с конвертацией в sparse, то при распаковке он будет восстановлен как sparse не зависимо от наличия опции --sparse
tar -xJvf /path/to/file.tar.xz

# (нужно проверить) возможно так все восстанавливаемые файлы будут конвертироваться в sparse
# даже если они не были sparse и архивировались без опции --sparse
tar --sparse -xJvf /path/to/file.tar.xz

# утилита du (disk usage)
du /path/to/file                   # объем занимаемый на диске, в том числе с учетом sparse
du --apparent-size /path/to/file   # логический размер файла, то что отображает ls -l --block-size=K

# утилита ls
ls -ls /path/to/file    # отдельно в первом столбце отображает размер занимаемый на диске в блоках, в том числе с учетом sparse