Політики планування PodGroup
Kubernetes v1.35 [alpha](стандартно вимкнено)Кожна PodGroup повинна оголосити політику планування у своєму полі spec.schedulingPolicy. Ця політика визначає, як планувальник обробляє колекцію Podʼів у групі.
Типи політик
Поле schedulingPolicy підтримує два типи політик: basic та gang. Ви повинні вказати лише одну.
Політика basic
Політика basic вказує планувальнику оцінювати всі Pod за принципом «наскільки це можливо». На відміну від політики gang, PodGroup, що використовує політику basic, вважається реалізованою незалежно від того, скільки її Podʼів на даний момент підлягають плануванню.
Основною причиною використання політики basic є організація Podʼів у групу для кращої спостережуваності та управління, при цьому вони все одно оцінюються разом у рамках єдиного атомарного циклу планування PodGroup.
Ця політика підходить для груп, які не потребують одночасного запуску, але логічно належать до одного цілого, або для створення можливості для обмежень на рівні групи, які не передбачають розміщення за принципом «все або нічого».
schedulingPolicy:
basic: {}
Політика gang
Політика gang забезпечує планування «все або нічого». Це необхідно для сильно звʼязаних робочих навантажень, де частковий запуск призводить до блокувань або втрати ресурсів.
Цю політику можна використовувати для Jobs або будь-якого іншого пакетного процесу, де всі працівники повинні працювати одночасно, щоб зробити прогрес.
Політика gang вимагає параметра minCount, який визначає мінімальну кількість Podʼів, які повинні бути заплановані одночасно, щоб група була прийнятною:
schedulingPolicy:
gang:
# Кількість Podʼів, які повинні бути заплановані одночасно
# для того, щоб група була прийнята.
minCount: 4
Встановлення політик через PodGroupTemplates
Під час використання Workload API, ви визначаєте політики планування всередині PodGroupTemplates. Контролер робочого навантаження копіює політику з шаблону в кожну створену PodGroup, роблячи PodGroup самодостатньою. Зміни в шаблонах Workload впливають лише на новостворені PodGroup, а не на наявні.
Для автономних PodGroup (створених без Workload) ви встановлюєте spec.schedulingPolicy безпосередньо на самій PodGroup.
Що далі
- Дізнайтеся про PodGroup API для того щоб зрозуміти, як політики застосовуються під час виконання.
- Дізнайтеся про Workload API, який визначає PodGroupTemplates.
- Прочитайте про планування PodGroup.
- Прочитайте про алгоритм групового планування.