
Сообщество написало рабочий инструмент, а в CNCF решили сделать «свой, официальный». В итоге забуксовали. А тем временем хитрый оператор etcd продолжает обрастать фичами и успешно крутиться в продакшене.
Проект etcd-operator, разрабатывающий инструмент для развертывания и обслуживания кластеров etcd в Kubernetes, стал частью экосистемы Cozystack. Вместе с передачей прав авторы представили полностью переписанную реализацию под новым API: etcd-operator.cozystack.io/v1alpha2. Она пришла на смену предыдущей версии etcd.aenix.io/v1alpha1.
Главное архитектурное новшество — отказ от управления узлами через StatefulSet. Теперь оператор работает с кластером напрямую через нативный Membership API самого etcd, используя операции MemberAdd, MemberPromote и MemberRemove. Это дает полный и предсказуемый контроль над составом кластера. Код с нуля написал Тимофей Ларкин, один из мейнтейнеров оригинальной версии (ее исходники сохранены в ветке v1alpha1). Проект написан на Go и доступен под лицензией Apache 2.0.
Как работает новая архитектура управление кластерами. Она строится вокруг двух ресурсов.
EtcdClusterописывает желаемое состояние: количество реплик, версиюetcd, параметры хранилища, TLS, аутентификацию и тюнинг.EtcdMemberсоздается оператором индивидуально для каждого узла и управляет его Pod’ом и PVC.
Здесь нет привычного StatefulSet — каждый узел синхронизируется (reconcile) независимо. Изменения состава проходят строго через API: новые участники добавляются в режиме обучения (MemberAdd) и только потом получают право голоса (MemberPromote). Удаление происходит через аккуратный вывод из кворума (MemberRemove). Если кластер ставится на паузу, идентификаторы узлов не теряются. Подробное обоснование такой архитектуры можно найти в файле concepts.md репозитория.

Хотите выиграть призы и бонусы на аренду серверов?
Приглашаем решить ИТ-кроссворд! Более 100 вопросов на разные темы из мира ИИ и машинного обучения — ежедневно с 6 по 9 июля.
Что изменилось по сравнению с v1alpha1
API-группа переехала с
etcd.aenix.ioнаetcd-operator.cozystack.io.На смену монолитному
StatefulSetпришли независимые ресурсыEtcdMember.Опасный свободный словарь spec.options заменен на строго типизированный набор параметров (
quota-backend-bytes, настройкиauto-compaction,snapshot-count). Раньше неверные флаги могли сломать логику оператора.Ресурс
EtcdBackupпереименован вEtcdSnapshotпри сохранении логики работы.Валидация манифестов перенесена из вебхука в CEL-правила.
Serviceкластера переведен в headless-режим — это обязательное условие для стабильных DNS-имен узлов.
Для бесшовного перехода написана утилита etcd-migrate. Она проводит in-place миграцию: подхватывает живой кластер старого оператора без перемещения данных, перезапуска подов или потери кворума. Инструмент просто меняет владельцев объектов, лейблы и аннотации, после чего управление переходит к v1alpha2. Клиенты, обращающиеся к кластеру по DNS, даже не замечают подмены (подробнее процесс описан в migration.md).
Текущая реализация закрывает подавляющее большинство пунктов из дорожной карты оператора etcd. При этом v1alpha2 умеет делать вещи, которых в официальном плане вообще нет.
Масштабирование в ноль (пауза/возобновление) с сохранением идентичности.
Хранение данных в памяти (tmpfs) с автоматической заменой узлов силами самого оператора.
CEL-валидация на стороне apiserver без лишних компонентов (ни вебхуков, ни сертификатов).
Автоматический PodDisruptionBudget, нацеленный строго на голосующие узлы.
Сабресурс /scale с заполненным status.selector, благодаря которому kubectl scale и VerticalPodAutoscaler.targetRef работают «из коробки».
Сквозной проброс правил планировщика (affinity, topologySpreadConstraints) и слияние additionalMetadata для всех дочерних объектов.
Инструмент для безопасной in-place миграции.
Плагин kubectl-etcd для повседневного обслуживания.
Подробности — на странице CNCF.
Напишите, что думаете, в комментариях. Например, что принесет отказ от StatefulSet? Управление через Membership API не идет вразрез с классическими туториалами Kubernetes?
