Тестируем VirtioFS в Docker

Уже 2 месяца использую Docker для разработки.
Это очень удобно, если ты работаешь в команде - у всех разные рабочие окружения, версии операционных системы и т.д., а Docker позволяет убрать эту разницу и автоматизировать создание проекта. Я уж молчу про всякое legacy, когда нужно работать с древними версиями библиотек, которые уже не устанавливаются.
Но есть проблема - работа Docker на MacOS не отличается высокой скоростью из-за особенностей файловой системы. В прошлой заметке я советовал использовать Mutagen для обхода этой проблемы, но и с ним не всё так радужно. Например, я словил несколько неприятных проблем с синхронизацией файлов, когдя они уже удалены в исходниках, но как-то сохраняются в контейнере из-за кэша Mutagen.
Скорость выше, да, но подобные особенности не радуют.
А тут оказалось, что аж с марта в Docker на MacOS Monterey доступны эксперементальные функции, как раз для улучшения работы с файловой системой.
Немедленно включил и замерил разницу, на этот раз не на установке пакетов, которые кэшируются по всякому, а на сборке фронтенда Vesp текущей версии.
git clone https://github.com/bezumkin/vesp.git
cd vesp/docker/
cp .env.dist .env

rm -rf ../frontend/dist && docker-compose up --build
Все тесты прогоняем по 3 раза.
Стандартный Docker:
  • 83.92s
  • 80.40s
  • 88.51s
Docker + Mutagen
rm -rf ../frontend/dist && mutagen-compose up --build
  • 80.24s
  • 81.69s
  • 81.42s
Никакой особой разницы для сборки не видно - примерно такая же скорость, как и без Mutagen, в пределах погрешности. Видимо в прошлый раз Mutagen быстро ставил зависимости с помощью своего кэширования.
Docker + новый VirtioFS
  • 27.88s
  • 29.36s
  • 29.66s
А вот тут уже впечатляющие результаты - почти в 3 раза быстрее!
Docker + VirtioFS + Mutagen
  • 31.55s
  • 29.93s
  • 28.98s
Получается, что при включении VirtioFS вы можете смело выбрасывать Mutagen - никакой прибавки в скорости он не даёт, но зато занимает больше места на диске из-за дополнительных volumes, и может добавить проблем с кэшем.
Сборка вообще без Docker, для понимания сколько мы теряем на виртуализации:
cd ../frontend/
rm -rf ./dist && yarn generate
  • 17.14s
  • 15.14s
  • 14.51s
VirtioFS - отличный шаг вперёд для Docker на MacOS, надеюсь на выходе в релиз он станет еще быстрее.

1 комментарий

Сергей Лелеко
Тоже задействовал! Прекрасная функция!
bezumkin.ru
Personal website of Vasily Naumkin
Прямой эфир
Василий Наумкин
01.07.2024, 11:56:41
Да, верно, именно так. А в контроллере, скорее всего, ловить данные методом post.
Василий Наумкин
26.06.2024, 09:38:15
О, точно, вылезает если не залогинен. Спасибо, исправил!
Василий Наумкин
09.04.2024, 04:45:01
> Ошибка 500 Это не похоже на ошибку Nginx, это скорее всего ошибка PHP - надо смотреть его логи. ...
Futuris
04.04.2024, 08:56:12
Я просто немного запутался. Когда в абзаце "Vesp/Core" ты пишешь про "новый trait FileModel", я поду...
Василий Наумкин
20.03.2024, 21:21:52
Volledig!
Андрей
14.03.2024, 13:47:10
Василий! Как всегда очень круто! Моё почтение!
russel gal
09.03.2024, 20:17:18
> А этот стоило написать хотя бы затем, чтобы получить комментарий от юзера, который ничего не писал...
Александр Наумов
27.01.2024, 03:06:18
Василий, спасибо! Извини, тупанул.
Василий Наумкин
22.01.2024, 07:43:20
Давай-давай!
Василий Наумкин
24.12.2023, 14:26:13
Спасибо!