Как определить тяжелую запись на диск?

У меня есть эта проблема с сервером, на котором запущено приложение CakePHP. Сервер работает безумно медленно, я сначала подумал, что это проблема приложения, но потом я обнаружил постоянную скорость записи 5-6 МБ / с на диск.

Какой самый простой способ найти причину такой тяжелой записи?

Сервер работает под управлением Gentoo.

6 ответов

Решение

Установите iotop и найдите, какая программа это делает.

Как автор Dstat я бы указал на дополнительные опции. Вы можете легко увидеть, какой процесс потребляет наибольшую пропускную способность ввода / вывода:

dstat -ta --top-bio

или dstat -ta --top-io

Первый - это верхний блок ввода-вывода, а второй - верхний блок ввода-вывода (включая кэшированный). Это может помочь вам проверить, соответствует ли это ожиданиям (как потребителю, так и потреблению).

Есть несколько других плагинов, которые могут помочь вам определить степень использования дисков:

dstat -tdf --disk-util

Поэтому, если у вас есть узкие места ввода / вывода, это скажет вам, какие диски задействованы, чтобы вы могли увидеть, можно ли что-то сделать с этой целью.

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

Однако, если вам нужна помощь, вы хотите внести свой вклад или у вас есть отличная новая идея, свяжитесь со мной, чтобы узнать, как мы можем действовать...

Попробуй вмстать и иостат

Из справочной страницы dstat - 'dstat -M time,cpu,net,disk,sys,load,proc,topcpu'. dstat устанавливается с большинством дистрибутивов, поэтому быстрее, чем установка iotop.

Вы можете использовать модный инструмент dstat

Вы можете сбросить действия диска (вместе с генерирующим его pid) в системный журнал с помощью следующей команды:

echo 1 > /proc/sys/vm/block_dump

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

Другие вопросы по тегам