Плохое чтение SSD-данных на Linux

Недавно у меня был SSD-накопитель на базе Intel 320 , и у меня возникли трудности с рекламой 38K IOPS для случайных чтений 4K.

Как с fio и с моей собственной программой взлома, я вижу около 6K IOPS. Это почти так же, как размер глубины ввода-вывода не имеет значения, и ядро ​​пытается получить один блок за раз.

Пример:

 $ cat job [randread] filename=/dev/sdb2 rw=randread size=128m blocksize=4k ioengine=libaio iodepth=64 direct=1 $ sudo fio job randread: (g=0): rw=randread, bs=4K-4K/4K-4K, ioengine=libaio, iodepth=64 Starting 1 process Jobs: 1 (f=1): [r] [100.0% done] [25423K/0K /s] [6207/0 iops] [eta 00m:00s] randread: (groupid=0, jobs=1): err= 0: pid=4678 read : io=131072KB, bw=24852KB/s, iops=6213, runt= 5274msec slat (usec): min=1, max=94, avg= 5.00, stdev= 2.88 clat (usec): min=312, max=13070, avg=10290.25, stdev=1399.78 bw (KB/s) : min=23192, max=24464, per=97.08%, avg=24125.60, stdev=383.70 cpu : usr=15.74%, sys=22.57%, ctx=31642, majf=0, minf=88 IO depths : 1=0.1%, 2=0.1%, 4=0.1%, 8=0.1%, 16=0.1%, 32=0.1%, >=64=99.8% submit : 0=0.0%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.0%, 64=0.0%, >=64=0.0% complete : 0=0.0%, 4=100.0%, 8=0.0%, 16=0.0%, 32=0.0%, 64=0.1%, >=64=0.0% issued r/w: total=32768/0, short=0/0 lat (usec): 500=0.01%, 750=0.01%, 1000=0.03% lat (msec): 2=0.05%, 4=0.10%, 10=20.10%, 20=79.70% Run status group 0 (all jobs): READ: io=131072KB, aggrb=24852KB/s, minb=25448KB/s, maxb=25448KB/s, mint=5274msec, maxt=5274msec Disk stats (read/write): sdb: ios=30453/0, merge=850/0, ticks=319060/0, in_queue=319060, util=98.09% 

Система Linux 2.6.35-31-generic #63-Ubuntu SMP Mon Nov 28 19:29:10 UTC 2011 x86_64 GNU/Linux . /dev/sdb2 выше – это раздел размером 10 ГБ на SSD на 80 ГБ. fio – версия 1.38.

По-настоящему оценил бы мысли о том, что может быть неправильно.

PS: раздел в вышеупомянутом тесте (/ dev / sdb2) выровнен по границе 4K. Чтение большего размера (размер = 10 г) не помогает.

  • Я должен иметь 500 гб пространства, но я могу использовать только 250
  • Документация mbcache
  • fstrim, похоже, не обрезает раздел, который использует lvm и dm-crypt
  • Установите второй накопитель ssd на centos. Как я могу определить, который является неиспользуемым диском?
  • Установите Linux на SSD или жесткий диск для виртуализации Windows с QEMU?
  • Spanning RAID на SSD и механическом HD
  • hdparm не показывает раздел «безопасность»
  • независимо убедитесь, что TRIM действительно работает на SSD
  • 2 Solutions collect form web for “Плохое чтение SSD-данных на Linux”

    Правильно ли совпадают ваши разделы? Если вы не начинаете свой раздел на границе 4k, ни одно из ваших 4k-считываний не будет выстраиваться в линию, создавая пограничные переходы и, в худшем случае, удваивает ваш ввод-вывод.

    См. Обсуждение. Могу ли я настроить свою систему Linux для более агрессивного кэширования файловой системы?

    Короче говоря, вам, вероятно, придется настроить некоторые настройки очереди устройств. Я предполагаю, что планировщик или настройка очереди неправильно догадались ядром или вручную.

    Пытаться

     head /sys/block/sd*/{queue/{nr_requests,nomerges,rotational,scheduler},device/queue_depth} 

    для отладки проблемы. Вы должны иметь queue_depth и nr_requests установленные рядом с 31, если вы можете терпеть латентность для одного чтения, вызванного NCQ, nomerges должны быть равны нулю, а rotational должно быть равным нулю для SSD. Выбор правильного scheduler будет сложнее, но для raw IOPS noop должен быть достаточно хорошим. Я считаю, что правильно настроенный cfq справляется с требованиями реального мира.

    И убедитесь, что диск подключен к SATA + AHCI, и вы включили NCQ. В противном случае у вас мало надежды на то, чтобы вытащить все с вашего диска.

    Interesting Posts

    Как получить сетевую маску от bash?

    В чем преимущество файлов .desktop без бита исполняемого бита?

    zfs-fuse: включение сжатия не влияет

    Заменить шаблон, если перед вторым шаблоном – сохранить строку между двумя

    Удаляются ли ссылки в / tmp-файлы?

    Почему Chromium не кэширует DNS больше минуты?

    Windows Server 2012 R2 и Centos 7 с двойной загрузкой: Windows ушла из меню загрузки

    Меню Alt-tab, не отображаемое в полноэкранном режиме

    Что такое красная звезда в Ranger?

    Сценарий оболочки, в котором выполняется mono_service.exe в качестве фоновой задачи

    В чем разница между использованием переменных оболочки и переменных среды?

    umount занятое устройство без процесса убийства?

    Как уменьшить влияние изменения значения массива `fpath` на время запуска zsh?

    Абсолютно заключить в тюрьму пользователя с минимальными правами доступа к IP, файлу и командам

    Как восстановить эту ошибку клиента NIS и NFS?

    Linux и Unix - лучшая ОС в мире.