Назад | Перейти на главную страницу

найти: одинаковый предел размера файла, но другой блок возвращает другой результат

Я заметил, что эти две команды для вывода списка файлов размером менее 5 ГиБ дают разные результаты:

find . -type f -size -5368709120c
find . -type f -size -5G

В частности, тот, который использует килобайтную единицу (5368709120c) возвращает дополнительные файлы, размер которых превышает максимальный размер файла, возвращаемый тем файлом, который использует блок ГиБ (5G).

Из find страницу руководства я прочитал следующее:

-size n[cwbkMG]
          File uses n units of space.  The following suffixes can be used:
          `b'    for 512-byte blocks (this is the default if no suffix is used)
          `c'    for bytes
          `w'    for two-byte words
          `k'    for Kilobytes (units of 1024 bytes)
          `M'    for Megabytes (units of 1048576 bytes)
          `G'    for Gigabytes (units of 1073741824 bytes)

The size does not count indirect blocks, but it does count blocks 
in sparse files that are not actually allocated.  Bear in mind that the `%k'
and `%b' format specifiers of -printf handle sparse files differently.   The 
`b'  suffix always denotes 512-byte blocks and never 1 Kilobyte blocks, 
which is different to the behaviour of -ls.

Итак, учитывая, что единица G это 1073741824, 5G должно быть 5368709120c. Проблема в том, как подсчитываются редкие или непрямые блоки?

Заранее спасибо за помощь.

** ОБНОВИТЬ **

Нашел что-то еще странное. Порог, при котором возвращаемые файлы различаются, составляет ровно 4 ГиБ:

Самый большой файл, найденный -5G:

4285018593 bytes = 3.990734548 GiB

Самый большой не файл найден -5G:

4299230968 bytes = 4.003970854 GiB

Файлы хранятся в разделе XFS:

meta-data=/dev/mapper/vg_XXXXX_lv isize=256    agcount=197, agsize=268435440 blks
         =                       sectsz=4096  attr=2, projid32bit=1
         =                       crc=0        finobt=0
data     =                       bsize=4096   blocks=52739701760, imaxpct=1
         =                       sunit=16     swidth=256 blks
naming   =version 2              bsize=4096   ascii-ci=0 ftype=0
log      =internal               bsize=4096   blocks=521728, version=2
         =                       sectsz=4096  sunit=1 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0

См. Ответ на суперпользователя Камил

https://superuser.com/a/1351674/27340