Migração de políticas de segurança de pod (PSP) herdadas - Amazon EKS

Migração de políticas de segurança de pod (PSP) herdadas

PodSecurityPolicy foi descontinuado no Kubernetes1.21 e removido em Kubernetes 1.25. Se você estiver usando o PodSecurityPolicy no seu cluster, deverá migrar para os padrões de segurança de pods incorporados Kubernetes (PSS) ou para uma solução de política como código antes de atualizar o cluster para a versão *1.25 para evitar interrupções nas workloads.* Selecione qualquer pergunta frequente para saber mais.

O PodSecurityPolicy é um controlador de admissão integrado que permite que um administrador de cluster controle os aspectos sensíveis à segurança da especificação do Pod. Se um Pod atender aos requisitos do PSP, o Pod será admitido no cluster como de costume. Se um Pod não atender aos requisitos de PSP, o Pod será rejeitado e não poderá ser executado.

Essa é uma mudança upstream no projeto do Kubernetes, e não uma mudança feita no Amazon EKS. O PSP foi descontinuado no Kubernetes 1.21 e removido no Kubernetes 1.25. A comunidade Kubernetes identificou sérios problemas de usabilidade com o PSP. Isso incluiu a concessão acidental de permissões mais amplas do que o pretendido e a dificuldade de inspecionar quais PSPs se aplicam a uma determinada situação. Esses problemas não poderiam ser resolvidos sem fazer alterações significativas. Esse é o principal motivo pelo qual a comunidade Kubernetes decidiu remover o PSP.

Para verificar se você está usando PSPs em seu cluster, execute o seguinte comando:

kubectl get psp

Para ver os Pods que o PSPs do cluster está afetando, execute o seguinte comando: Esse comando gera o nome do Pod, o namespace e o PSPs:

kubectl get pod -A -o jsonpath='{range.items[?(@.metadata.annotations.kubernetes\.io/psp)]}{.metadata.name}{"\t"}{.metadata.namespace}{"\t"}{.metadata.annotations.kubernetes\.io/psp}{"\n"}'

Antes de atualizar seu cluster para 1.25, migre o PSPs para uma das seguintes alternativas:

  • Kubernetes PSS.

  • Soluções de política como código do ambiente do Kubernetes.

Em resposta à depreciação do PSP e à necessidade contínua de controlar a segurança do Pod desde o início, a comunidade Kubernetes criou uma solução integrada com o (PSS) e o Pod Security Admission (PSA). O webhook do PSA implementa os controles definidos no PSS.

Você pode revisar as melhores práticas para migrar PSPs para as PSS incorporadas no Guia de melhores práticas do EKS. Também recomendamos que você consulte nosso blog Implementing Pod Security Standards in Amazon EKS (Implementar padrões de segurança no Amazon EKS). Outras referências incluem Migrar do PodSecurityPolicy para o controlador de admissão PodSecurity integrado e o Mapeamento das PodSecurityPolicies para os padrões de segurança do Pod.

As soluções de política como código fornecem barreiras para orientar os usuários do cluster e evitam comportamentos indesejados por meio de controles automatizados prescritos. As soluções de política como código normalmente usam os Controladores de Admissão Dinâmicos do Kubernetes para interceptar o fluxo de solicitações do servidor da API Kubernetes usando uma chamada de webhook. As soluções de política como código alteram e validam as cargas de solicitação com base nas políticas escritas e armazenadas como código.

Existem várias soluções de política como código de código aberto disponíveis para o Kubernetes. Para analisar as melhores práticas para migrar PSPs para uma solução de política como código, consulte a seção Política como código da página de Segurança do Pod no GitHub.

Os clusters do Amazon EKS com a versão 1.13 do Kubernetes e posteriores têm uma política de segurança de PSP padrão denominada eks.privileged. Essa política é criada em clusters 1.24 e anteriores. Não é usado no 1.25 e em clusters posteriores. O Amazon EKS migra automaticamente essa PSP para uma fiscalização baseada na PSS. Não é necessária nenhuma ação da sua parte.

Não. Além disso, eks.privileged que é uma PSP criada pelo Amazon EKS, nenhuma alteração será feita a outras PSPs no cluster quando você fizer o upgrade para o 1.25.

Não. O Amazon EKS não impedirá a atualização do cluster para a versão 1.25 se você ainda não tiver migrado da PSP.

Quando um cluster que contém a PSP é atualizado para o Kubernetes versão 1.25, o servidor da API não reconhece o recurso PSP na versão 1.25. Isso pode fazer com que os Pods obtenham escopos de segurança incorretos. Para obter uma lista completa de implicações, consulte Migrar da PodSecurityPolicy para o controlador de admissão PodSecurity integrado.

Não esperamos nenhum impacto específico nas cargas de trabalho do Windows. PodSecurityContext tem um campo chamado windowsOptions na API PodSpec v1 para Pods do Windows. Isso usa o PSS no Kubernetes 1.25. Para obter mais informações e as práticas recomendadas para a imposição de PSS em workloads do Windows, consulte o Guia de práticas recomendadas do EKS e a documentação do Kubernetes.