'Docker start' параллельно?

Я раскручиваю 1000 контейнеров в одной сети Docker, все из одного образа Docker.

В настоящее время развертывание занимает много времени. Я разделил процесс на docker create а также docker startв отличие от монолитного docker run,

Есть ли способ раскрутить контейнеры параллельно? - Рад работать в интерфейсе программирования (Go, C, что угодно), или использовать команды CLI.

Связанный: Может Docker Engine запускать контейнеры параллельно [спросил и ответил 3 года назад]

2 ответа

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

Команда run является оболочкой для создания / запуска. И все эти команды docker являются небольшими обертками вокруг REST API для dockerd. Вы можете перейти непосредственно к этому API, но, вероятно, время потрачено на настройку пространств имен, включая правила IPAM и iptables для работы в сети. Я не знаю ни одного параллельного API, который бы ускорил запуск большого количества контейнеров. Один из способов ускорить это - удалить часть изоляции пространства имен или посмотреть другие варианты драйверов, используемых для создания пространства имен. Переключение на хост-сеть полностью пропускает сеть моста контейнера и правила iptables, помещая ваш контейнер в то же пространство имен сети, что и хост.

Или с сетью, вы можете настроить контейнер с сетью "none", чтобы избежать каких-либо подключений к мостовой сети и правилам iptables, хотя у вас все еще будет адрес обратной связи. У вас есть возможность подключить работающий контейнер к сети после его запуска, поэтому, если у вас нет опубликованных портов, это может быть возможностью отделить команду запуска от настройки сети, в зависимости от вашего варианта использования.

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

1000 контейнеров в одной виртуальной машине (или машине Baremetal) не похоже на масштабируемое решение.

Я бы предложил контейнерную систему оркестрации, такую ​​как Kubernetes,Docker Swarm, Nomad (в порядке моих личных предпочтений) с многоузловой конфигурацией High Availability. Docker Swarm гораздо проще в настройке, чем его популярный аналог, Kubernetes (K8s)

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