Kubernetes

10 вопросов

Kubernetes - оркестрация контейнеров. Pod, Deployment, StatefulSet, Service, Ingress, ConfigMap/Secret, liveness/readiness probes, HPA, Namespace, Helm. Стандарт для production-инфраструктуры.

1 Что такое Pod в Kubernetes? 🟢 Лёгкий
Ответ: B) Минимальная единица развёртывания - один или несколько контейнеров

Pod - минимальная единица в Kubernetes. Содержит один или несколько контейнеров, разделяющих сеть (localhost) и volumes. Обычно один Pod = один основной контейнер + sidecar'ы. Pod'ы эфемерны - могут быть убиты и пересозданы.

Подробнее →
2 Для чего используются Namespace? 🟢 Лёгкий
Ответ: B) Для логической изоляции ресурсов внутри кластера

Namespace - логическая изоляция ресурсов: разные команды, среды (dev/staging/prod) в одном кластере. Ресурсы в разных namespace могут иметь одинаковые имена. Можно задавать квоты (ResourceQuota) и сетевые политики.

Подробнее →
3 Что такое Helm? 🟢 Лёгкий
Ответ: B) Пакетный менеджер для Kubernetes

Helm - пакетный менеджер. Charts (пакеты) описывают набор ресурсов с шаблонизацией и переменными (values.yaml). helm install redis bitnami/redis установит Redis со всеми ресурсами. Упрощает повторное развёртывание.

Подробнее →
4 Чем blue-green deployment отличается от canary deployment? 🟢 Лёгкий
Ответ: B) Blue-green: два полных окружения, мгновенное переключение трафика; Canary: постепенное направление процента трафика на новую версию

Blue-green: две идентичные среды, переключение 100% трафика разом (быстрый откат). Canary: сначала 5% трафика на новую версию, потом 25%, 50%, 100% - постепенная проверка.

Подробнее →
5 Когда использовать StatefulSet вместо Deployment? 🟡 Средний
Ответ: B) Для stateful-приложений с постоянными именами и хранилищем (БД, Kafka)

Deployment - для stateless (веб-серверы, API). Pod'ы взаимозаменяемы. StatefulSet - для stateful: постоянные имена (pod-0, pod-1), стабильные сетевые идентификаторы, персональные тома (PVC). Используется для PostgreSQL, Redis, Kafka.

Подробнее →
6 Какой тип Service делает приложение доступным за пределами кластера? 🟡 Средний
Ответ: B) NodePort или LoadBalancer

ClusterIP - только внутри кластера (по умолчанию). NodePort - открывает порт на каждой ноде (30000-32767). LoadBalancer - создаёт внешний балансировщик (в облаке). На практике используют Ingress Controller для HTTP-трафика.

Подробнее →
7 Чем liveness probe отличается от readiness probe? 🟡 Средний
Ответ: B) Liveness перезапускает контейнер, readiness убирает из балансировки

Liveness: 'жив ли контейнер?' - при неудаче перезапускает. Readiness: 'готов ли принимать трафик?' - при неудаче убирает из Service (не получает запросы, но не перезапускается). Startup probe - для приложений с долгим стартом.

Подробнее →
8 Чем Secret отличается от ConfigMap? 🟡 Средний
Ответ: B) Secret хранит данные в base64 и предназначен для чувствительных данных

ConfigMap - нечувствительные конфигурации (plain text). Secret - пароли, токены, ключи в base64 (но НЕ шифрует по умолчанию!). Для шифрования нужен EncryptionConfiguration или Vault. Secret'ы можно монтировать как файлы или env.

Подробнее →
9 Что такое Ingress в Kubernetes? 🟡 Средний
Ответ: B) Правила маршрутизации HTTP-трафика к сервисам

Ingress - набор правил для маршрутизации внешнего HTTP/HTTPS-трафика к сервисам кластера. Поддерживает path-based и host-based routing, TLS. Требует Ingress Controller (nginx-ingress, traefik). Пример: /api -> api-service, /web -> web-service.

Подробнее →
10 Что делает Horizontal Pod Autoscaler (HPA)? 🟡 Средний
Ответ: B) Автоматически меняет количество Pod в зависимости от нагрузки

HPA автоматически меняет количество реплик Pod'а на основе метрик (CPU, RAM, custom). При CPU > 70% - добавляет Pod'ы, при < 30% - убирает. VPA (Vertical) меняет ресурсы Pod. Cluster Autoscaler масштабирует ноды.

Подробнее →
🧠Квиз 🏆Лидеры 🎯Собесед. 📖Вопросы 📚База зн.