Изучая на просторах сети различные кастомные реализации собственных аналогов
И решил составить свой небольшой топ проблем подобных решений:
- Малый набор поддерживаемых ресурсов - как правило только
- Собственный, ограниченный синтаксис для правил, который применяется только там и нигде более.
- Возможность обхода проверок на уровне
Policy Engine (для проверки Kubernetes ресурсов), частенько встречаю такое как на скриншоте.И решил составить свой небольшой топ проблем подобных решений:
- Малый набор поддерживаемых ресурсов - как правило только
native ресурсы для workloads. В итоге работают те же обходы, что и для PSP.- Собственный, ограниченный синтаксис для правил, который применяется только там и нигде более.
- Возможность обхода проверок на уровне
Pods за счет, промежуточной модификации родительского ресурса через тот же Mutating Admission Controller👍5
Стали доступны материалы с OSS Japan 2022 - все видео тут. В рамках данного мероприятия были отдельные направления и я особенно выделю: ContainerCon и OpenSSF Day.
На последнем было четкое попадание в тематику нашего канала - "Protecting Kubernetes Resource Manifests in End-to-end SDLC".
А так как я топлю не только за
На последнем было четкое попадание в тематику нашего канала - "Protecting Kubernetes Resource Manifests in End-to-end SDLC".
А так как я топлю не только за
security, но и realiability (по мне они не отделимы), то так же хочу поделиться информацией, что стали доступны доклады с SREcon22 Europe/Middle East/Africa. Там, кстати, тоже не забывают про безопасность, на пример, доклад - "How Can SRE Help Security Governance? Sub-noscript: How to Unstuck GRC with SRE".👍5
Сегодня продолжу знакомить вас с внутренней кухней Luntry.
Один из самых сложных вопрос, который меня периодически спрашивают: сколько времени вы занимаетесь/разрабатываете
По сути тогда и сейчас мы имеем дело с
Один из самых сложных вопрос, который меня периодически спрашивают: сколько времени вы занимаетесь/разрабатываете
Luntry? Тяжелый он для меня, потому что смотря с какого момента вести отсчет... В основе нашего решения по защите контейнеров и Kubernetes, есть мысли и идеи, которые были в моем другом проекте (который не выстрелил) по защите IoT, embedded devices и т.д. Так что сейчас у нас есть немного кода, который был и лет 5 назад =)По сути тогда и сейчас мы имеем дело с
ОС Linux, также, тогда мы работали с иммутабельными прошивками устройств, а сейчас с иммутабельными образами контейнеров! Вот так нам удалось идеи из одной сферы перенести в другую ;)Telegram
k8s (in)security
Всех поздравляю с 1 сентября! С Днем Знаний!
И хотел бы сегодня поделиться знанием, почему наше решение по безопасности для Kubernetes называется Luntry ("Лантри"). Хотя некоторые нас порой называют "Люнтри" и как вы увидите дальше это в принципе тоже верно.…
И хотел бы сегодня поделиться знанием, почему наше решение по безопасности для Kubernetes называется Luntry ("Лантри"). Хотя некоторые нас порой называют "Люнтри" и как вы увидите дальше это в принципе тоже верно.…
🔥11👍3👏1
Используете ли вы антивирус на Nodes кластера Kubernetes?
Final Results
11%
Да
80%
Нет
10%
Нет, но будем
Пост из рубрики "Знали ли вы?" =)
Детали по этому поводу тут и тут.
Пояснение от разработчиков
"It's not quite the same (and thank goodness). This does not generate local endpoints for you. You can't get an automatic LB from it. It generally can't be used behind an Ingress.
All it produces is the equivalent of a CNAME record."
Это также на тему использования
Детали по этому поводу тут и тут.
Пояснение от разработчиков
k8s:"It's not quite the same (and thank goodness). This does not generate local endpoints for you. You can't get an automatic LB from it. It generally can't be used behind an Ingress.
All it produces is the equivalent of a CNAME record."
Это также на тему использования
NetworkPolicy и PolicyEngine ;)👍8❤3🔥1👌1
Вот и в новой блоговой записи появилась информация о новой security фичи "Kubernetes 1.26: Introducing Validating Admission Policies". О данной фичи я уже писал ранее и об этом можно почитать тут.
Из нового тут можно у знать о следующих моментах:
Во-первых, для работы с этим механизмом появился не один новый ресур, а два, которые работают в связке:
- ValidatingAdmissionPolicy - описание политики.
- ValidatingAdmissionPolicyBinding - где политика должна применяться (
Во-вторых, стало известно о возможности параметризировать политики за счет связей/отсылок на другие
В-третьих, появлении в официальной документации раздела "Validating Admission Policy", где можно обо всем узнать еще более подробно о данной фиче, на основании различных примеров.
Из нового тут можно у знать о следующих моментах:
Во-первых, для работы с этим механизмом появился не один новый ресур, а два, которые работают в связке:
- ValidatingAdmissionPolicy - описание политики.
- ValidatingAdmissionPolicyBinding - где политика должна применяться (
namespaceSelector, objectSelector).Во-вторых, стало известно о возможности параметризировать политики за счет связей/отсылок на другие
Kubernetes ресурсы (ну прям полная Policy-as-Code).В-третьих, появлении в официальной документации раздела "Validating Admission Policy", где можно обо всем узнать еще более подробно о данной фиче, на основании различных примеров.
Kubernetes
Kubernetes 1.26: Introducing Validating Admission Policies
In Kubernetes 1.26, the 1st alpha release of validating admission policies is available!
Validating admission policies use the Common Expression Language (CEL) to offer a declarative, in-process alternative to validating admission webhooks.
CEL was first…
Validating admission policies use the Common Expression Language (CEL) to offer a declarative, in-process alternative to validating admission webhooks.
CEL was first…
👍4
Недавно помогали одному из клиентов с такой задачей.
Задача: На каждой
Важно, что это
Единого, встроенного ресурса, выполняющего такую логику в
- #36601
- #64623
Вариантов реализации разного уровня упоротости я нашел аж
1) BroadcastJob
2) AdvancedCronJob
В комментариях, можно поделиться как вы подходите к решению подобной задачи у себя.
Задача: На каждой
Node (с учетом ее типа Master/Worker) с определенной периодичностью, необходимо запускать тот или иной workload, выполняющий определённую логику (установка параметров, сбор данных и т.д.).Важно, что это
Oneshot задача, на каждой Node (не забываем, что они могут появляться и исчезать), выполняющаяся по какому-то расписанию. То есть, по сути, это такое сочетание DaemonSet (гарантирует присутствие на каждой Node) и CronJob (запускает задачу по расписанию и по завершению исчезает). Единого, встроенного ресурса, выполняющего такую логику в
Kubernetes НЕТ! Обсуждение этого момента можно найти, на пример, тут:- #36601
CronJob daemonset (previously ScheduledJob) - #64623
Run job on each node once to help with setup Вариантов реализации разного уровня упоротости я нашел аж
6 штук. Но хотел бы тут поделиться одним, реализованным сторонним проектом OpenKruise. Там есть operator, который управляет 2 новыми сущностями (Custom Resources), решающими как раз данную задачу:1) BroadcastJob
2) AdvancedCronJob
В комментариях, можно поделиться как вы подходите к решению подобной задачи у себя.
GitHub
CronJob daemonset (previously ScheduledJob) · Issue #36601 · kubernetes/kubernetes
Feature Request: Ability to run a scheduled job as a daemonset so it can run on each node. e.g. image garbage collection with something like docker-gc Kubernetes version (use kubectl version): Clie...
🔥21👍4
Сегодня хочу всех познакомить с одним удивительным проектом о котором я узнал достаточно недавно - Nixery.
Данный проект позволяет легко, на лету запросить образ контейнера с необходимым набором инструментов в нем, просто перечислив их через слеш в
-
-
Базируется это все на Nix package manager и optimized layering strategy.
Очень удобно когда нужен образ с каким-то утилитами, а готовить его самостоятельно долго. Вот тут есть классный пример применения для отладки
Данный проект позволяет легко, на лету запросить образ контейнера с необходимым набором инструментов в нем, просто перечислив их через слеш в
URL - вот в такой вот манере:-
docker run -ti nixery.dev/shell/git/htop bash - образ с интерактивными шелом, git и htop утилитами.-
docker pull nixery.dev/shell/ps/findutils/tshark - образ с интерактивным шелом, ps, findutils и tshark утилитами.Базируется это все на Nix package manager и optimized layering strategy.
Очень удобно когда нужен образ с каким-то утилитами, а готовить его самостоятельно долго. Вот тут есть классный пример применения для отладки
distroless образов.🔥23🤔4😁1
https://ima.ge.cx/ - простенький
В общем, полезно как для ленивых, так может и для тех кто работает в закрытых контурах, чтобы зря ничего не качать ;)
online проект для быстрого просмотра содержимого образа из публичного реджистри. Для этого достаточно просто прямо в URL указать интересующий образ.В общем, полезно как для ленивых, так может и для тех кто работает в закрытых контурах, чтобы зря ничего не качать ;)
👍21🔥5
Сегодня в фокусе нашего внимания исследование "Supply-Chain Security: Evaluation of Threats and Mitigations" об атаках и методах защиты цепочки поставки с оценкой их эффективности. Понравилось, что это все на примерах с реальной оценкой, а не просто на теории.
Содержимое:
-
-
-
Содержимое:
-
Review and re-evaluation of supply chain
- Model of modern typical CI/CD pipeline
- Attack injection point versus attack execution point
- Supply chain attacks and mitigations
- Summary of threat model (PDF)-
Summary of Mitigations (PDF)-
Source Repository
- Secrets
- Signing
- Dependency Tracking (SBOM)
- Attestation
- Example of a Centralized CI Pipeline
Как один из выводов это важность centralized CI pipeline для обеспечения Supply-Chain Security.👍11
Если начинать потихоньку подводить итоги
1) Тема
2) Chainguard images -
3) Фичи в новых версиях
-
- Поддержка
-
2022 года, то самыми интересными для меня (IMHO) и нашей команды Luntry открытиями/прорывами/адаптациями/... года в области Kubernetes security стали:1) Тема
container specific OS - в этом году поглубже погрузился в данную тему и вообще по индустрии видно пристальный взгляд на это направление2) Chainguard images -
distroless images набирают обороты и становятся все доступнее, как раз благодаря вот таким вот проектам3) Фичи в новых версиях
Kubernetes - в этом году вышли 1.24, 1.25, 1.26:-
UserNamespacesSupport
- Forensic Container Checkpointing - Поддержка
cgroup v2 -
Admission Policies
А как у вас в этом вопросе?)luntry.ru
Luntry — защита контейнеров и Kubernetes-сред от угроз на всех этапах жизненного цикла
Kubernetes-native платформа для полного контроля и безопасности контейнерной инфраструктуры, без замедления
🔥9👍4
Вообще я не любитель давать какие-то прогнозы, но тут что-то самому захотелось (самого себя проверить что ли через год) немного заглянуть в будущее и посмотреть, что нас ждет с в техническом плане с безопасностью контейнеров и
Кратко:
1) Повышенное внимание регуляторов к контейнерам
2) Платформизация систем компаний
3) В
4) Ориентир на
Есть еще Нострадамусы? То welcome в комментарии!
Kubernetes в новом 2023 году. Возможно, сказывается то, что за этот год пришлось взаимодействовать с огромным количеством разных компаний из различных отраслей по вопросом контейнеризации (чего раньше в таких масштабах у меня не было). А также, участие в программном комитете DevOpsCоnf и еще более шире увидеть, что и в каком состоянии сейчас находится в индустрии в целом.Кратко:
1) Повышенное внимание регуляторов к контейнерам
2) Платформизация систем компаний
3) В
DevSecOps развитие Security Gate и ASOC систем4) Ориентир на
Security Observability
5) Рост атак на контейнерезированные окружения, важность безопасности supply chain
Более подробно с разъяснениями вот тут.Есть еще Нострадамусы? То welcome в комментарии!
🔥7👍2🥰1🤩1
И сегодня подведем итоги
1) Наш проект Лантри постепенно начинает помогать все большему и большему количеству компаний, использующих
2) Данный канал продолжает расти (
3) Наша небольшая команда в этом году приняла участие более чем в
4) Мой тренинг по безопасности
5) Есть определённые новые идеи/мысли запустить и попробовать что-то новое в следующем году как в виде форматов, так и по части различных активностей в образовательной деятельности. Главное, чтобы хватило на все времени и сил.
Всем большое спасибо, что читаете, комментируете, спрашиваете!
Всем хорошо встретить Новый Год, отдохнуть в праздники и не болеть!
2022 года и немного заглянем в 2023:1) Наш проект Лантри постепенно начинает помогать все большему и большему количеству компаний, использующих
Kubernetes!2) Данный канал продолжает расти (
> +1600) и надеюсь радовать вас интересным и качественным контентом. 3) Наша небольшая команда в этом году приняла участие более чем в
12 мероприятиях по безопасности Kubernetes [1,2,3,4,5,6,7,8,9,...], а также были и различные подкасты [1,2,3] и вебинары!4) Мой тренинг по безопасности
Kubernetes все обновляется и расширяется и, кажется, такими темпами скоро перестанет укладываться в 3 дня =)5) Есть определённые новые идеи/мысли запустить и попробовать что-то новое в следующем году как в виде форматов, так и по части различных активностей в образовательной деятельности. Главное, чтобы хватило на все времени и сил.
Всем большое спасибо, что читаете, комментируете, спрашиваете!
Всем хорошо встретить Новый Год, отдохнуть в праздники и не болеть!
❤🔥23👍9❤3🎄2👎1
Начнем год с забавной познавательной стать "Fun with SSRF - Turning the Kubernetes API Server into a port scanner" полезной как для атакующих, так и для защищающих.
Тут важно сразу понять, что все описанное в данной заметке это стандартная функциональность, а не какие-то уязвимости! Так все крутиться вокруг ресурса
Тут важно сразу понять, что все описанное в данной заметке это стандартная функциональность, а не какие-то уязвимости! Так все крутиться вокруг ресурса
Validating Admission Webhooks (частью спецификации является service или URL). Помимо создания данного ресурса нужны будут права создавать еще и Namespace и Pod.PoC сканера можно взять тут.🔥6🤔3🥰1👏1
Сегодня я бы хотел привлечь ваше внимание к блоговой записи и репозитарию на канале одного моего товарища.
Сразу скажу, что речь в данной работе пойдет не про
И так, моему товарищу понадобилось захерденить
P.S. Если тема интересная то в комментах можно подробнее расспросить автора об успешности работы все этого (Spoiler: не все так гладко как хотелось бы) ...
Сразу скажу, что речь в данной работе пойдет не про
Kubernetes, а про Docker в чистом его проявлении в сочетании с OPA, а не как обычно принято на данном канале про OPA Gatekeeper =) И так, моему товарищу понадобилось захерденить
Docker executor и для этого нашелся Docker OPA Plugin, а вот правил проверок для него не нашлось, что в итоге и было реализовано!P.S. Если тема интересная то в комментах можно подробнее расспросить автора об успешности работы все этого (Spoiler: не все так гладко как хотелось бы) ...
Telegram
Нарыл
Мы уже обсуждали аспекты безопасности разных типов экзекьютеров в CI/CD. Предположим разработчикам необходимо использовать общий Docker executor, по какой либо причине и мы ничего не можем с этим сделать. Хочется такой экзекьютор захарденить. Но прежде давайте…
👍5🤔3👎1
Компания
Помимо добавления новых техник (
Еще появился и маппинг на техники
А также, что более важно, появилась отдельная вкладка с Mitigations, которая на сегодняшний день включает в себя
Microsoft в очередной раз обновила свою Threat matrix for Kubernetes (по сути это уже 3 редакция)!Помимо добавления новых техник (
Static pods,Collecting data from pod) и расширения уже имеющихся (Container service account,Exposed sensitive interfaces) появилась и удобная интерактивная версия матрицы.Еще появился и маппинг на техники
MITRE ATT&CK, что удобно при использовании интерактивной матрицы. А также, что более важно, появилась отдельная вкладка с Mitigations, которая на сегодняшний день включает в себя
32 пункта, каждый из которых привязан к той или иной тактике!🔥23❤1👏1👌1
Сегодня из каждого утюга слышно про
А чем сообщество
Также подумали одни ребята и запилили ChatGPT bot for Kubernetes issues! В общем помощника/подсказавальщика на базе ChatGPT для
Текущий алгоритм работы:
1)
3) Результат отправляется в
Ввиду того что система
P.S. У нас даже уже есть определенные мысли и для Luntry, но всему свое время.
ChatGPT ...А чем сообщество
Kubernetes хуже?! Также подумали одни ребята и запилили ChatGPT bot for Kubernetes issues! В общем помощника/подсказавальщика на базе ChatGPT для
troubleshooting.Текущий алгоритм работы:
1)
Prometheus перенаправляет alerts на бота, используя webhook receiver
2) Бот спрашивает ChatGPT: "How to fix your alerts"3) Результат отправляется в
Slack
Подробнее можно посмотреть в этом видео ;)Ввиду того что система
Kubernetes декларативная и вся состоит из описанных YAML ресурсов, то для нее в данной области можно еще много чего интересного придумать =)P.S. У нас даже уже есть определенные мысли и для Luntry, но всему свое время.
GitHub
GitHub - robusta-dev/kubernetes-chatgpt-bot: A ChatGPT bot for Kubernetes issues.
A ChatGPT bot for Kubernetes issues. Contribute to robusta-dev/kubernetes-chatgpt-bot development by creating an account on GitHub.
👍19👎1
Мини исследование "Attack of the clones - Stealthy Kubernetes persistence with eathar, tòcan and teisteanas".
Автор проанализировал матрицу угроз для
Идея в том что имея краткосрочный доступ к привилегированному аккаунту превратить его в долгосрочный.
Рассматриваемые сценарии:
1) Кража
2) Использование CSR API
3) Использование TokenRequest API
4) Кража
-
В заметке упоминаются такие полезные инструменты для пентеста как eathar, teisteanas, tocan, view-serviceaccount-kubeconfig.
Автор проанализировал матрицу угроз для
Kubernetes от Microsoft, а конкретнее стадию Persistence. И там обратил внимание что там совсем не покрыто "use of Kubernetes APIs to use or create long-lived credentials which clone system accounts." (Никогда не устану говорить, что все эти матрицы всегда на шаг позади от возможностей атакующий - будьте внимательны!)Идея в том что имея краткосрочный доступ к привилегированному аккаунту превратить его в долгосрочный.
Рассматриваемые сценарии:
1) Кража
cluster CA certificate и key 2) Использование CSR API
3) Использование TokenRequest API
4) Кража
service account token secrets от system accounts
Все эксперименты проводились на:-
Kubeadm 1.25 (KinD)
- AKS 1.24.6
- EKS v1.23.13-eks-fb459a0
- GKE v1.24.7-gke.900 В заметке упоминаются такие полезные инструменты для пентеста как eathar, teisteanas, tocan, view-serviceaccount-kubeconfig.
👍4
Как я уже неоднократно писал - технология
Сегодня я хотел бы вас познакомить с технической статей "How Universal Profiling unwinds stacks without frame pointers and symbols" от моих знакомых. Кстати, мне довелось немного приложить руку к их стартапу (поучаствовать в закрытом
Если совсем кратко, то они позволяют производить
eBPF открывает очень много новых возможностей как для ИБ, так и для ИТ.Сегодня я хотел бы вас познакомить с технической статей "How Universal Profiling unwinds stacks without frame pointers and symbols" от моих знакомых. Кстати, мне довелось немного приложить руку к их стартапу (поучаствовать в закрытом
beta тестировании), который как вы можете сейчас заметить уже куплен Elastic.Если совсем кратко, то они позволяют производить
system-wide continuous profiling без какой-либо предварительной подготовки приложений (как раз благодаря eBPF) и даже без символов (если что ребята очень крутые reverse engineer'ы - так то мы и познакомились с ними)! В статье как раз и рассказывается как этого можно достичь. Это все точно работает и работает хорошо - я в этом лично убедился, запуская их в нашем k8s окружении (мой feedback в основном его и касался).🔥16
Мой коллега Сергей Канибор в процессе исследования безопасности
Сама
Более детально о данной проблеме и как ее воспроизвести (
Kubernetes наткнулся недавно на GitHub на один интересный баг и при этом еще НЕ ИСПРАВЛЕННЫЙ, который позволяет обходить определенный момент при работе PSP или Policy Engines!Сама
issue называется так - "Can bypass PodSecurityContext.SupplementalGroups by custom container image although PSP(or other policy engines) enforces the field". Название говорящее и сразу становится ясно, что речь идет только о SupplementalGroups. Наиболее критично это для multi-tenant Kubernetes cluster так как "can get access to some private directory in the hostPath volume.". И для самого обхода требуется собрать image специальным образом.Более детально о данной проблеме и как ее воспроизвести (
PoC) можно почитать в данном исследовании автора - "strict-supplementalgroups-container-runtime".🔥9
На глаза попалась статья с интересным названием “Abusing ETCD to Inject Resources and Bypass RBAC and Admission Controller Restrictions”.
Внутри разбираетcя что такое
Громкое название, автор оправдывает в конце, напоминая, что любые ресурсы, которые деплоятся в кластер, проходят через
Как по мне, статья будет полезна тем, кто хочет понять как работать с
Внутри разбираетcя что такое
ETCD и как оно работает, как взаимодействовать с ним напрямую, а также как забрать и положить значение из key-value хранилища, так чтобы ничего не сломалось. В примере демонстрируется как можно записать значение Pod и какие ошибки при этом могут возникнуть (ну и как их пофиксить).Громкое название, автор оправдывает в конце, напоминая, что любые ресурсы, которые деплоятся в кластер, проходят через
kube-api server и соответственно подвергаются как валидации RBAC, так и Admission Controller, например в лице Policy Engine. Помещая ресурсы напрямую в ETCD, эти проверки можно обойти.Как по мне, статья будет полезна тем, кто хочет понять как работать с
ETCD, и тем, кто проводит пентест, при этом обложен различными средствами безопасности внутри кластера, но в тоже время обнаруживает Unauthenticated Access в ETCD :)👍9