SLABINFO(5) Руководство программиста Linux SLABINFO(5)

ИМЯ

slabinfo - сводная таблица использования блоков кэша (slab) ядра

ОБЗОР

cat /proc/slabinfo

ОПИСАНИЕ

Часто используемые объекты в ядре Linux (заголовки буферов, иноды, элементы dentry и тп.) имеют свои собственные кэши. В файле /proc/slabinfo отражена статистика их работы. Пример (отредактированный) содержимого этого файла:

$ sudo cat /proc/slabinfo
slabinfo - version: 2.1
# name    <active_objs> <num_objs> <objsize> <objperslab> <pagesperslab> ...
sigqueue      100  100  160   25  1 : tunables  0  0  0 : slabdata   4   4  0
sighand_cache 355   405 2112  15  8 : tunables  0  0  0 : slabdata  27  27  0
kmalloc-8192   96   96  8192   4  8 : tunables  0  0  0 : slabdata  24  24  0
...

В первой строке содержится номер версии, который позволяет приложению, читающему файл, определить формат файла (смотрите ВЕРСИИ ниже). В следующей строке перечисляются имена столбцов в оставшихся строках.

В каждой оставшейся строке выводится информация об определённом кэше. После имени данные каждого кэша делятся на три компонента:

  • статистика
  • регулировки (tunables)
  • slabdata

Поля статистики:

Количество активных (т. е., использующихся) в данный момент объектов.
Общее количество выделенных объектов (т. е., используемых и не используемых объектов).
Размер объектов в этом кэше (slab), в байтах.
Количество объектов, хранящихся в каждом кэше (slab).
Количество страниц, выделенных для каждого кэша (slab).

Элементы регулировок в каждой строке содержат подстроечные параметры соответствующего кэша. При использовании выделителя по умолчанию SLUB они отсутствуют, файл /proc/slabinfo недоступен для записи и в этих полях показываются значения 0. При использовании старого выделителя SLAB регулировки определённого кэша можно изменять посредством записи строк в формате /proc/slabinfo:

# echo 'name limit batchcount sharedfactor' > /proc/slabinfo

Здесь name — имя кэша, limit, batchcount и sharedfactor — целые числа, задающие новые значения соответствующих регулировок. Значение limit должно быть положительным, batchcount должно быть положительным числом меньшим или равным limit, а sharedfactor должно быть неотрицательным. Если одно из значений некорректно, то настройки кэша не изменяются.

Записи регулировок в каждой строке имеют следующие поля:

Максимальное количество объектов, которые будут кэшироваться.
Для многопроцессорных систем здесь задаётся количество объектов передаваемых одновременно, происходит наполнение списка доступных объектов.
[Будет описано]

Записи slabdata в каждой строке имеют следующие поля:

Количество активных кэшей (slabs).
Общее количество активных кэшей (slabs).
[Будет описано]

Заметим, что из-за выравнивания объектов и заголовков блоков кэша объекты обычно не упакованы ровно по страницам. Страницы даже с единственным используемым объектом уже сами считаются используемыми и не могут быть высвобождены.

Ядра с включённым параметром CONFIG_DEBUG_SLAB также будут выдавать в каждой дополнительные поля статистики, а в первой строке файла будет слово «(statistics)». Поля статистики: максимальная отметка по активным объектам, количество раз, когда был выделен объект, количество раз, когда кэш рос (в этот кэш добавлялись новые страницы), количество раз, когда кэш урезался (из этого кэша удалялись неиспользуемые страницы), количество раз, когда возникала ошибка при выделении новых страниц для кэша.

ВЕРСИИ

Фай /proc/slabinfo впервые появился в Linux 2.1.23. Файл содержит номер версии, которых было создано несколько с разными форматами:

1.0
В ядрах Linux 2.2.x.
1.1
В ядрах Linux 2.4.x.
1.2
Формат, существовавший короткое время в разрабатываемых версиях Linux 2.5.
2.0
В ядрах Linux 2.6.x по Linux 2.6.9, включительно.
2.1
Текущий формат, появился в Linux 2.6.10.

ЗАМЕЧАНИЯ

Только суперпользователь может читать и (если ядро собрано с CONFIG_SLAB) изменять файл /proc/slabinfo.

Общее количество памяти, выделенное под кэш SLAB/SLUB, показано в поле Slab файла /proc/meminfo.

СМОТРИТЕ ТАКЖЕ

slabtop(1)

Файл из дерева исходного кода ядра Documentation/vm/slub.txt и tools/vm/slabinfo.c.

2017-09-15