As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.
Crie e gerencie EKS clusters da Amazon com Step Functions
Saiba como integrar o Step Functions com EKS a Amazon para gerenciar clusters Kubernetes. O Step Functions fornece dois tipos de integração de serviços APIs para integração com o Amazon Elastic Kubernetes Service. Uma delas permite que você use a Amazon EKS APIs para criar e gerenciar um EKS cluster da Amazon. A outra permite que você interaja com seu cluster usando o Kubernetes API e execute trabalhos como parte do fluxo de trabalho do seu aplicativo.
Você pode usar as API integrações do Kubernetes com clusters da EKS Amazon criados usando Step Functions, com clusters da EKS Amazon criados pela ferramenta eksctl ou pelo console da EKS Amazon
Para saber mais sobre a integração com AWS serviços no Step Functions, consulte Integração de produtos da e. Passando parâmetros para um serviço API em Step Functions
Principais recursos da EKS integração otimizada com a Amazon
-
O padrão de integração Executar um trabalho (.sync) é compatível.
-
Não há otimizações para o padrão de integração Resposta de solicitação.
-
O padrão de integração Aguardar um retorno de chamada com um token de tarefa não é compatível.
nota
A EKS integração do Step Functions oferece suporte somente ao Kubernetes APIs com acesso público ao endpoint. Por padrão, os endpoints API do servidor de EKS clusters têm acesso público. Para obter mais informações, consulte Controle de acesso ao endpoint de EKS cluster da Amazon no Guia do EKS usuário da Amazon.
O Step Functions não encerra um EKS cluster da Amazon automaticamente se a execução for interrompida. Se sua máquina de estado parar antes do EKS encerramento do cluster da Amazon, seu cluster poderá continuar funcionando indefinidamente e poderá acumular cobranças adicionais. Para evitar isso, certifique-se de que qualquer EKS cluster da Amazon que você criar seja encerrado corretamente. Para obter mais informações, consulte:
-
Excluindo um cluster no Guia do EKS usuário da Amazon.
-
Executar um trabalho (.sync) nos Padrões de Integração de Serviço.
nota
Há uma cota para o tamanho máximo de dados de entrada ou resultado para uma tarefa no Step Functions. Isso restringe você a 256 KiB de dados como uma string codificada em UTF -8 quando você envia ou recebe dados de outro serviço. Consulte Cotas relacionadas a execuções de máquina de estado.
Integrações com o Kubernetes API
O Step Functions é compatível com os seguintes APIs Kubernetes:
RunJob
A integração do eks:runJob
serviço permite que você execute um trabalho em seu EKS cluster da Amazon. A variante eks:runJob.sync
permite que você aguarde a conclusão do trabalho e, opcionalmente, recupere os registros.
Seu API servidor Kubernetes deve conceder permissões para a IAM função usada pela sua máquina de estado. Para obter mais informações, consulte Permissões.
Para o padrão Executar um trabalho (.sync
), o status do trabalho é determinado por meio de pesquisa. O Step Functions pesquisa inicialmente a uma taxa de aproximadamente 1 pesquisa por minuto. Por fim, essa taxa diminui para aproximadamente 1 pesquisa a cada 5 minutos. Se você precisar de pesquisas mais frequentes ou precisar de mais controle sobre a estratégia de pesquisa, poderá usar a integração eks:call
para consultar o status do trabalho.
A integração eks:runJob
é específica para batch/v1
Tarefas no Kubernetes. Para obter mais informações, consulte Tarefaseks:call
. Você pode usar o Step Functions para criar ciclos de pesquisa, conforme demonstrado no projeto de exemplo de Pesquisa sobre a situação do trabalho na Lambda e AWS Batch.
Os parâmetros compatíveis incluem:
-
ClusterName
: o nome do EKS cluster da Amazon que você deseja chamar.-
Type
:String
-
Obrigatório: sim
-
-
CertificateAuthority
: os dados de certificado codificados em Base64 necessários para se comunicar com o cluster. Você pode obter esse valor no EKSconsole da Amazonou usando a Amazon EKS DescribeClusterAPI. -
Type
:String
-
Obrigatório: sim
-
-
Endpoint
: o endpoint do seu URL servidor KubernetesAPI. Você pode obter esse valor no EKSconsole da Amazonou usando a Amazon EKS DescribeClusterAPI. -
Type
:String
-
Obrigatório: sim
-
-
Namespace
: o namespace em que a tarefa será executada. Se não for fornecido, o namespacedefault
será usado.-
Type
:String
-
Obrigatório: não
-
-
Job
: A definição da Tarefa do Kubernetes. Consulte Tarefasna documentação do Kubernetes. -
Type
:JSON
ouString
-
Obrigatório: sim
-
-
LogOptions
: um conjunto de opções para controlar a recuperação opcional de logs. Aplicável somente se o padrão de integração do serviço Executar um trabalho (.sync) for usado para aguardar a conclusão do trabalho.-
Type
:JSON
-
Obrigatório: não
-
Os registros são incluídos na resposta abaixo da chave
logs
. Pode haver vários pods na tarefa, cada uma com vários contêineres.{ ... "logs": { "pods": { "pod1": { "containers": { "container1": { "log":
<log>
}, ... } }, ... } } -
A recuperação do log é realizada com base no melhor esforço. Se houver um erro ao recuperar um log, no lugar do campo
log
estarão os camposerror
ecause
.
-
-
LogOptions.RetrieveLogs
: habilite a recuperação de log após a conclusão da tarefa. Por padrão, os logs não são recuperados.-
Type
:Boolean
-
Obrigatório: não
-
-
LogOptions.RawLogs
: seRawLogs
for definido como verdadeiro, os registros serão retornados como strings brutas sem tentar analisá-los. JSON Por padrão, os registros são desserializados, JSON se possível. Em alguns casos, essa análise pode introduzir alterações indesejadas, como limitação da precisão de números contendo muitos dígitos.-
Type
:Boolean
-
Obrigatório: não
-
-
LogOptions.LogParameters
: o registro de leitura do Kubernetes API oferece suporte API a parâmetros de consulta para controlar a recuperação de registros. Por exemplo, você pode usartailLines
oulimitBytes
para limitar o tamanho dos logs recuperados e permanecer dentro da cota de tamanho de dados do Step Functions. Para obter mais informações, consulte a seção Registro de leiturada Referência do KubernetesAPI. -
Type:
Mapa deString
atéList of Strings
-
Obrigatório: não
-
Exemplo: .
"LogParameters": { "tailLines": [ "6" ] }
-
O exemplo a seguir inclui um estado Task
que executa um trabalho, aguarda sua conclusão e, em seguida, recupera os logs do trabalho:
{
"StartAt": "Run a job on EKS",
"States": {
"Run a job on EKS": {
"Type": "Task",
"Resource": "arn:aws:states:::eks:runJob.sync",
"Parameters": {
"ClusterName": "MyCluster",
"CertificateAuthority": "ANPAJ2UCCR6DPCEXAMPLE",
"Endpoint": "https://AKIAIOSFODNN7EXAMPLE.yl4.us-east-1.eks.amazonaws.com",
"LogOptions": {
"RetrieveLogs": true
},
"Job": {
"apiVersion": "batch/v1",
"kind": "Job",
"metadata": {
"name": "example-job"
},
"spec": {
"backoffLimit": 0,
"template": {
"metadata": {
"name": "example-job"
},
"spec": {
"containers": [
{
"name": "pi-2000",
"image": "perl",
"command": [ "perl" ],
"args": [
"-Mbignum=bpi",
"-wle",
"print bpi(2000)"
]
}
],
"restartPolicy": "Never"
}
}
}
}
},
"End": true
}
}
}
Call
A integração do eks:call
serviço permite que você use o Kubernetes para ler e gravar objetos de recursos do Kubernetes API por meio de um endpoint do Kubernetes. API
Seu API servidor Kubernetes deve conceder permissões para a IAM função usada pela sua máquina de estado. Para obter mais informações, consulte Permissões.
Para obter mais informações sobre as operações disponíveis, consulte a Referência do Kubernetes API
Os parâmetros compatíveis para Call
incluem:
-
ClusterName
: o nome do EKS cluster da Amazon que você deseja chamar.-
Type
: string -
Obrigatório: sim
-
-
CertificateAuthority
: os dados de certificado codificados em Base64 necessários para se comunicar com o cluster. Você pode obter esse valor no EKSconsole da Amazonou usando a Amazon EKS DescribeClusterAPI. -
Type
:String
-
Obrigatório: sim
-
-
Endpoint
: o endpoint do seu URL servidor KubernetesAPI. Você pode encontrar esse valor no EKSconsole da Amazonou usando Amazon EKS ' DescribeCluster API. -
Type
:String
-
Obrigatório: sim
-
-
Method
: O HTTP método da sua solicitação. Um destes:GET
,POST
,PUT
,DELETE
,HEAD
ouPATCH
.-
Type
:String
-
Obrigatório: sim
-
-
Path
: o HTTP caminho da operação do Kubernetes RESTAPI.-
Type
:String
-
Obrigatório: sim
-
-
QueryParameters
: os parâmetros de HTTP consulta da operação do Kubernetes RESTAPI.-
Type:
Mapa deString
atéList of Strings
-
Obrigatório: não
-
Exemplo: .
"QueryParameters": { "labelSelector": [ "job-name=example-job" ] }
-
-
RequestBody
: o corpo da HTTP mensagem da operação do Kubernetes RESTAPI.-
Type
:JSON
ouString
-
Obrigatório: não
-
Veja a seguir um estado Task
que utiliza eks:call
para listar os pods pertencentes à tarefa example-job
.
{
"StartAt": "Call EKS",
"States": {
"Call EKS": {
"Type": "Task",
"Resource": "arn:aws:states:::eks:call",
"Parameters": {
"ClusterName": "MyCluster",
"CertificateAuthority": "ANPAJ2UCCR6DPCEXAMPLE",
"Endpoint": "https://444455556666.yl4.us-east-1.eks.amazonaws.com",
"Method": "GET",
"Path": "/api/v1/namespaces/default/pods",
"QueryParameters": {
"labelSelector": [
"job-name=example-job"
]
}
},
"End": true
}
}
}
Veja a seguir um estado Task
que utiliza eks:call
para excluir a tarefa example-job
e define o propagationPolicy
para garantir que os pods da tarefa também sejam excluídos.
{
"StartAt": "Call EKS",
"States": {
"Call EKS": {
"Type": "Task",
"Resource": "arn:aws:states:::eks:call",
"Parameters": {
"ClusterName": "MyCluster",
"CertificateAuthority": "ANPAJ2UCCR6DPCEXAMPLE",
"Endpoint": "https://444455556666.yl4.us-east-1.eks.amazonaws.com",
"Method": "DELETE",
"Path": "/apis/batch/v1/namespaces/default/jobs/example-job",
"QueryParameters": {
"propagationPolicy": [
"Foreground"
]
}
},
"End": true
}
}
}
Amazon compatível EKS APIs
A Amazon EKS APIs e a sintaxe suportadas incluem:
-
-
Quando um EKS cluster da Amazon é criado usando a integração de
eks:createCluster
serviços, a IAM função é adicionada à tabela de RBAC autorização do Kubernetes como administrador (com permissões system:masters). Inicialmente, somente essa IAM entidade pode fazer chamadas para o servidor KubernetesAPI. Para obter mais informações, consulte:-
Gerenciando usuários ou IAM funções para seu cluster no Amazon EKS User Guide
-
A Permissões seção
A Amazon EKS usa funções vinculadas a serviços que contêm as permissões que a Amazon EKS exige para chamar outros serviços em seu nome. Se essas funções vinculadas ao serviço ainda não existirem em sua conta, você deverá adicionar a
iam:CreateServiceLinkedRole
permissão à IAM função usada pelo Step Functions. Para obter mais informações, consulte Usando funções vinculadas ao serviço no Guia EKS do usuário da Amazon.A IAM função usada pelo Step Functions deve ter
iam:PassRole
permissões para passar a IAM função de cluster para a AmazonEKS. Para obter mais informações, consulte a IAMfunção de EKS cluster da Amazon no Guia EKS do usuário da Amazon. -
-
-
Você deve excluir todos os perfis ou grupos de nós do Fargate antes de excluir um cluster.
-
-
A Amazon EKS usa funções vinculadas a serviços que contêm as permissões que a Amazon EKS exige para chamar outros serviços em seu nome. Se essas funções vinculadas ao serviço ainda não existirem em sua conta, você deverá adicionar a
iam:CreateServiceLinkedRole
permissão à IAM função usada pelo Step Functions. Para obter mais informações, consulte Usando funções vinculadas ao serviço no Guia EKS do usuário da Amazon.A Amazon EKS on Fargate pode não estar disponível em todas as regiões. Para obter informações sobre a disponibilidade da região, consulte a seção sobre Fargate no Guia EKS do usuário da Amazon.
A IAM função usada pelo Step Functions deve ter
iam:PassRole
permissões para passar a IAM função de execução do pod para a AmazonEKS. Para obter mais informações, consulte a função de execução do pod no Guia EKS do usuário da Amazon.
-
-
A Amazon EKS usa funções vinculadas a serviços que contêm as permissões que a Amazon EKS exige para chamar outros serviços em seu nome. Se essas funções vinculadas ao serviço ainda não existirem em sua conta, você deverá adicionar a
iam:CreateServiceLinkedRole
permissão à IAM função usada pelo Step Functions. Para obter mais informações, consulte Usando funções vinculadas ao serviço no Guia EKS do usuário da Amazon.A IAM função usada pelo Step Functions deve ter
iam:PassRole
permissões para passar a IAM função do nó para a AmazonEKS. Para obter mais informações, consulte Usando funções vinculadas ao serviço no Guia EKS do usuário da Amazon.
O seguinte inclui um Task
que cria um EKS cluster da Amazon.
{
"StartAt": "CreateCluster.sync",
"States": {
"CreateCluster.sync": {
"Type": "Task",
"Resource": "arn:aws:states:::eks:createCluster.sync",
"Parameters": {
"Name": "MyCluster",
"ResourcesVpcConfig": {
"SubnetIds": [
"subnet-053e7c47012341234",
"subnet-027cfea4b12341234"
]
},
"RoleArn": "arn:aws:iam::123456789012:role/MyEKSClusterRole"
},
"End": true
}
}
}
O seguinte inclui um Task
estado que exclui um EKS cluster da Amazon.
{
"StartAt": "DeleteCluster.sync",
"States": {
"DeleteCluster.sync": {
"Type": "Task",
"Resource": "arn:aws:states:::eks:deleteCluster.sync",
"Parameters": {
"Name": "MyCluster"
},
"End": true
}
}
}
Veja a seguir um estado Task
que cria um perfil do Fargate.
{
"StartAt": "CreateFargateProfile.sync",
"States": {
"CreateFargateProfile.sync": {
"Type": "Task",
"Resource": "arn:aws:states:::eks:createFargateProfile.sync",
"Parameters": {
"ClusterName": "MyCluster",
"FargateProfileName": "MyFargateProfile",
"PodExecutionRoleArn": "arn:aws:iam::123456789012:role/MyFargatePodExecutionRole",
"Selectors": [{
"Namespace": "my-namespace",
"Labels": { "my-label": "my-value" }
}]
},
"End": true
}
}
}
Veja a seguir um estado Task
que exclui um perfil do Fargate.
{
"StartAt": "DeleteFargateProfile.sync",
"States": {
"DeleteFargateProfile.sync": {
"Type": "Task",
"Resource": "arn:aws:states:::eks:deleteFargateProfile.sync",
"Parameters": {
"ClusterName": "MyCluster",
"FargateProfileName": "MyFargateProfile"
},
"End": true
}
}
}
Veja a seguir um estado Task
que cria um grupo de nós.
{
"StartAt": "CreateNodegroup.sync",
"States": {
"CreateNodegroup.sync": {
"Type": "Task",
"Resource": "arn:aws:states:::eks:createNodegroup.sync",
"Parameters": {
"ClusterName": "MyCluster",
"NodegroupName": "MyNodegroup",
"NodeRole": "arn:aws:iam::123456789012:role/MyNodeInstanceRole",
"Subnets": ["subnet-09fb51df01234", "subnet-027cfea4b1234"]
},
"End": true
}
}
}
Veja a seguir um estado Task
que exclui um grupo de nós.
{
"StartAt": "DeleteNodegroup.sync",
"States": {
"DeleteNodegroup.sync": {
"Type": "Task",
"Resource": "arn:aws:states:::eks:deleteNodegroup.sync",
"Parameters": {
"ClusterName": "MyCluster",
"NodegroupName": "MyNodegroup"
},
"End": true
}
}
}
Permissões
Quando um EKS cluster da Amazon é criado usando a integração eks:createCluster
de serviços, a IAM função é adicionada à tabela de RBAC autorização do Kubernetes como administrador, com permissões. system:masters
Inicialmente, somente essa IAM entidade pode fazer chamadas para o servidor KubernetesAPI. Por exemplo, você não poderá usar o kubectl para interagir com seu API servidor Kubernetes, a menos que assuma a mesma função da sua máquina de estado Step Functions ou configure o Kubernetes para conceder permissões a entidades adicionais. IAM Para obter mais informações, consulte Gerenciamento de usuários ou IAM funções para seu cluster no Guia EKS do usuário da Amazon.
Você pode adicionar permissão para IAM entidades adicionais, como usuários ou funções, adicionando-as aws-auth
ConfigMap
ao namespace kube-system. Se você estiver criando seu cluster a partir do Step Functions, use a integração de serviços eks:call
.
O seguinte inclui um Task
estado que cria aws-auth
ConfigMap
e concede system:masters
permissão ao usuário arn:aws:iam::123456789012:user/my-user
e à IAM funçãoarn:aws:iam::123456789012:role/my-role
.
{
"StartAt": "Add authorized user",
"States": {
"Add authorized user": {
"Type": "Task",
"Resource": "arn:aws:states:::eks:call",
"Parameters": {
"ClusterName": "MyCluster",
"CertificateAuthority": "LS0tLS1CRUd...UtLS0tLQo=",
"Endpoint": "https://444455556666.yl4.us-east-1.eks.amazonaws.com",
"Method": "POST",
"Path": "/api/v1/namespaces/kube-system/configmaps",
"RequestBody": {
"apiVersion": "v1",
"kind": "ConfigMap",
"metadata": {
"name": "aws-auth",
"namespace": "kube-system"
},
"data": {
"mapUsers": "[{ \"userarn\": \"arn:aws:iam::123456789012:user/my-user\", \"username\": \"my-user\", \"groups\": [ \"system:masters\" ] } ]",
"mapRoles": "[{ \"rolearn\": \"arn:aws:iam::123456789012:role/my-role\", \"username\": \"my-role\", \"groups\": [ \"system:masters\" ] } ]"
}
}
},
"End": true
}
}
nota
Você pode ver o ARN para uma IAM função exibido em um formato que inclui o caminho /service-role/, como. arn:aws:iam::123456789012:role/
Esse token do caminho service-role não deve ser incluído ao listar a função em service-role
/my-roleaws-auth
Quando seu cluster for criado pela primeira vez, o aws-auth
ConfigMap
não existirá, mas será adicionado automaticamente se você criar um perfil do Fargate. Você pode recuperar o valor atual deaws-auth
, adicionar as permissões adicionais e PUT
uma nova versão. Normalmente, é mais fácil criar aws-auth
antes do perfil do Fargate.
Se seu cluster foi criado fora do Step Functions, você pode configurar o kubectl para se comunicar com seu servidor API Kubernetes. Em seguida, crie um novo aws-auth
ConfigMap
usando kubectl apply -f aws-auth.yaml
ou edite um que já exista usandokubectl edit -n kube-system configmap/aws-auth
. Para obter mais informações, consulte:
-
Crie um kubeconfig para a Amazon EKS no Guia do usuário da Amazon EKS.
-
Gerenciando usuários ou IAM funções para seu cluster no Amazon EKS User Guide.
Se sua IAM função não tiver permissões suficientes no Kubernetes, as integrações eks:call
ou eks:runJob
serviços falharão com o seguinte erro:
Error:
EKS.401
Cause:
{
"ResponseBody": {
"kind": "Status",
"apiVersion": "v1",
"metadata": {},
"status": "Failure",
"message": "Unauthorized",
"reason": "Unauthorized",
"code": 401
},
"StatusCode": 401,
"StatusText": "Unauthorized"
}
IAMpolíticas para ligar para a Amazon EKS
Os modelos de exemplo a seguir mostram como AWS Step Functions gera IAM políticas com base nos recursos em sua definição de máquina de estado. Para ter mais informações, consulte Como o Step Functions gera políticas do IAM para serviços integrados e Descobrir padrões de integração de serviços no Step Functions.
CreateCluster
Recursos
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"eks:CreateCluster"
],
"Resource": "*"
},
{
"Effect": "Allow",
"Action": [
"eks:DescribeCluster",
"eks:DeleteCluster"
],
"Resource": "arn:aws:eks:sa-east-1:444455556666:cluster/*"
},
{
"Effect": "Allow",
"Action": "iam:PassRole",
"Resource": [
"arn:aws:iam::444455556666:role/StepFunctionsSample-EKSClusterManag-EKSServiceRole-ANPAJ2UCCR6DPCEXAMPLE"
],
"Condition": {
"StringEquals": {
"iam:PassedToService": "eks.amazonaws.com"
}
}
}
]
}
CreateNodeGroup
Recursos
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"ec2:DescribeSubnets",
"eks:CreateNodegroup"
],
"Resource": "*"
},
{
"Effect": "Allow",
"Action": [
"eks:DescribeNodegroup",
"eks:DeleteNodegroup"
],
"Resource": "arn:aws:eks:sa-east-1:444455556666:nodegroup/*"
},
{
"Effect": "Allow",
"Action": [
"iam:GetRole",
"iam:ListAttachedRolePolicies"
],
"Resource": "arn:aws:iam::444455556666:role/*"
},
{
"Effect": "Allow",
"Action": "iam:PassRole",
"Resource": [
"arn:aws:iam::444455556666:role/StepFunctionsSample-EKSClusterMan-NodeInstanceRole-ANPAJ2UCCR6DPCEXAMPLE"
],
"Condition": {
"StringEquals": {
"iam:PassedToService": "eks.amazonaws.com"
}
}
}
]
}
DeleteCluster
Recursos
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"eks:DeleteCluster",
"eks:DescribeCluster"
],
"Resource": [
"arn:aws:eks:sa-east-1:444455556666:cluster/ExampleCluster"
]
}
]
}
DeleteNodegroup
Recursos
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"eks:DeleteNodegroup",
"eks:DescribeNodegroup"
],
"Resource": [
"arn:aws:eks:sa-east-1:444455556666:nodegroup/ExampleCluster/ExampleNodegroup/*"
]
}
]
}
Para obter mais informações sobre o uso da Amazon EKS com Step Functions, consulteCrie e gerencie EKS clusters da Amazon com Step Functions.