Definir estratégias de atualização reutilizáveis usando o Azure Kubernetes Fleet Manager

Os administradores podem controlar a sequência de atualizações para clusters gerenciados pela Frota definindo uma série de estágios e grupos. Eles podem configurar quando as aprovações e pausas devem ocorrer dentro desses estágios e grupos. Toda a configuração pode ser salva como uma estratégia de atualização que pode ser gerenciada independentemente de execuções de atualização ou atualizações automáticas, permitindo que as estratégias sejam reutilizados conforme necessário.

Este artigo aborda como definir estratégias de atualização usando grupos e estágios.

Um diagrama mostrando um exemplo de estratégia de atualização que contém dois estágios de atualização. Cada estágio de atualização contém dois grupos de atualização. Cada grupo de atualização contém dois clusters de membros.

Pré-requisitos

  • Leia a visão geral conceitual das atualizações da Frota, que fornece uma explicação das execuções de atualização, estágios, grupos e estratégias referenciadas neste guia.

  • Você tem um recurso de frota com um ou mais clusters membros. Caso contrário, siga o início rápido para criar um recurso de frota e ingressar clusters do AKS (Serviço de Kubernetes do Azure) como membros.

  • Defina as seguintes variáveis de ambiente:

    export GROUP=<resource-group>
    export FLEET=<fleet-name>
    export CLUSTERID=<aks-cluster-resource-id>
    export STRATEGY=<strategy-name>
    
  • Se você estiver seguindo as instruções da CLI do Azure neste artigo, precisará da CLI do Azure versão 2.70.0 ou posterior instalada. Para instalar ou atualizar, confira Instalar a CLI do Azure.

  • Você também precisa da extensão da CLI do fleet Azure versão 1.6.0 ou posterior, que pode ser instalada executando o seguinte comando:

    az extension add --name fleet
    

    Execute o comando az extension update para atualizar para a versão mais recente da extensão lançada:

    az extension update --name fleet
    

Selecionar clusters para sua estratégia

Há duas maneiras de selecionar quais clusters estão incluídos em cada estágio e grupo de sua estratégia de atualização para controlar a sequência de atualizações:

  • Rótulos de membro (recomendado): atribua rótulos a cada membro da frota e use memberSelector para selecionar membros por esses rótulos. Cada membro pode ter vários rótulos.
  • Atualizar grupos: atribua um grupo de atualizações a cada membro da frota e defina grupos em sua estratégia que correspondam a esses nomes de grupo. Cada membro só pode pertencer a um grupo.

Criar uma estratégia de atualização usando seletores de membro (versão prévia)

Os rótulos de membro são a abordagem recomendada para selecionar clusters em suas estratégias de atualização, pois fornecem mais flexibilidade. Para obter detalhes conceituais, consulte Clusters de grupo usando rótulos de membro.

Importante

Os recursos de visualização do Azure Kubernetes Fleet Manager estão disponíveis de forma autônoma, mediante adesão. As versões prévias são fornecidas “no estado em que se encontram” e “conforme disponíveis” e são excluídas dos contratos de nível de serviço e da garantia limitada. A versão prévia do Gerenciador de Frota de Kubernetes do Azure é parcialmente coberta pelo suporte ao cliente em regime de melhor esforço. Dessa forma, esses recursos não são destinados ao uso em produção.

Aplicar rótulos em clusters de membros

Aplique rótulos ao adicionar um cluster de membros à frota

Aplique rótulos aos membros da frota usando o az fleet member create comando. O exemplo a seguir aplica dois rótulos ao cluster membro: env=staging e tier=frontend:

az fleet member create \
    --resource-group $GROUP \
    --fleet-name $FLEET \
    --name member1 \
    --member-cluster-id $CLUSTERID \
    --labels "env=staging tier=frontend"

Aplicar rótulos a um membro da frota existente

Aplicar rótulos aos membros da frota usando o az fleet member update comando

az fleet member update \
 --resource-group $GROUP \
 --fleet-name $FLEET \
 --name member1 \
 --labels "env=staging tier=frontend"

Criar uma estratégia de atualização

Uma estratégia de atualização consiste em um ou mais estágios, em que um estágio pode conter um ou mais grupos de atualização.

  1. Crie um arquivo JSON para definir os estágios e grupos para a execução da atualização. Os estágios são executados sequencialmente na ordem em que aparecem no arquivo JSON. Os grupos funcionam em paralelo em cada etapa. O arquivo de exemplo a seguir (example-labels-strategy.json) define uma estratégia com dois estágios usando memberSelector para selecionar clusters por seus rótulos e inclui configurações opcionais maxConcurrency :

    • O estágio staging usa um memberSelector em nível de estágio para selecionar todos os clusters com o rótulo env=staging e criar um grupo implícito.
    • A etapa production utiliza um filtro no nível da etapa memberSelector para pré-filtrar todos os clusters com o rótulo env=production, e, em seguida, define dois grupos, cada um com seu próprio memberSelector para selecionar os clusters com base no rótulo tier.

    Quando memberSelector é definido em um grupo, o campo name desse grupo é utilizado apenas como um identificador de exibição para relatórios de status e registro em log, e deixa de ser usado para a seleção de membros da frota com base no grupo de atualização.

    {
        "stages": [
            {
                "name": "staging",
                "memberSelector": { "byLabel": "env=staging" },
                "maxConcurrency": "1",
                "afterStageWaitInSeconds": 600
            },
            {
                "name": "production",
                "memberSelector": { "byLabel": "env=production" },
                "maxConcurrency": "4",
                "groups": [
                    {
                        "name": "frontend",
                        "memberSelector": { "byLabel": "tier=frontend" },
                        "maxConcurrency": "3"
                    },
                    {
                        "name": "backend",
                        "memberSelector": { "byLabel": "tier=backend" },
                        "maxConcurrency": "3"
                    }
                ]
            }
        ]
    }
    

Observação

O maxConcurrency campo é opcional e controla quantos clusters podem ser atualizados simultaneamente no nível do estágio ou do grupo. Use um valor maior para atualizar clusters mais rapidamente em sua frota ou um valor menor para uma distribuição mais controlada que limita o raio de explosão se surgirem problemas.

Quando um estágio usa memberSelector sem grupos (como staging), todos os membros correspondentes formam um único grupo implícito e o estágio maxConcurrency controla a concorrência diretamente. Quando os grupos são definidos (como production), ao nível da etapa maxConcurrency funciona como um limite máximo geral para todos os grupos.

Neste exemplo, a etapa staging está definida como maxConcurrency de modo que os clusters de preparo "1" são atualizados um por vez. A etapa production permite até "4" clusters simultaneamente, com os grupos frontend e backend limitados a "3" cada um.

Os valores podem ser um inteiro fixo (por exemplo, "3") ou um percentual (por exemplo, "50%"). Se omitido, o sistema aplicará valores padrão. Para obter detalhes sobre como esses valores são resolvidos e seus limites superiores, consulte Máxima simultaneidade (versão prévia).

  1. Crie uma nova estratégia de atualização usando o comando az fleet updatestrategy create com o sinalizador --stages definido como o nome do seu arquivo JSON.

    az fleet updatestrategy create \
     --resource-group $GROUP \
     --fleet-name $FLEET \
     --name $STRATEGY \
     --stages example-labels-strategy.json
    

Criar uma estratégia de atualização usando grupos de atualização

Os clusters também podem ser selecionados em estratégias de atualização atribuindo-os a um único grupo de atualizações. Você pode definir uma estratégia de atualização que atribui esses grupos de atualização a estágios. Em um estágio de atualização, as atualizações são aplicadas a cada grupo de atualizações em paralelo. Em um grupo de atualização, os clusters membros são atualizados sequencialmente.

Observação

Um membro da frota só pode fazer parte de um grupo de atualização, mas um grupo de atualização pode ter vários membros da frota atribuídos a ele. Um grupo de atualização em si não é um tipo de recurso separado. Os grupos de atualizações são apenas cadeias de caracteres que representam referências dos membros da frota. Portanto, se todos os membros da frota com referências a um grupo de atualização comum forem excluídos, esse grupo de atualização específico deixará de existir também.

Atribuir clusters a grupos de atualização

Atribua ao grupo ao adicionar o cluster membro à frota

  1. No portal do Azure, navegue até o recurso do Gerenciador de Frota de Kubernetes do Azure.

  2. No menu de serviço, em Configurações, selecione Cluster membros>Adicionar.

    Captura de tela da página do portal do Azure para o Gerenciador de Frota de Kubernetes do Azure para adicionar clusters de membros.

  3. Selecione o cluster que você deseja adicionar e selecione Avançar: Examinar + adicionar.

  4. Insira o nome do grupo de atualização ao qual deseja atribuir o cluster e selecione Adicionar.

    Captura de tela da página do portal do Azure na etapa de revisão e adição do Gerenciador de Frota de Kubernetes do Azure para clusters membros.

Atribuir um membro da frota existente a um grupo de atualização

  1. No portal do Azure, navegue até o recurso do Gerenciador de Frota de Kubernetes do Azure.

  2. No menu de serviço, em Configurações, selecione Cluster membros.

  3. Selecione os clusters que você deseja atribuir a um grupo de atualização e selecione Atribuir grupo de atualização

    Captura de tela da página no portal do Azure para atribuir clusters de membros existentes a um grupo.

  4. Insira o nome do grupo de atualização ao qual deseja atribuir o cluster e selecione Atribuir.

    Captura de tela da página do portal do Azure para clusters membros que mostra o formulário para atualização do grupo de um cluster membro.

Criar uma estratégia de atualização

Uma estratégia de atualização consiste em um ou mais estágios, em que um estágio pode conter um ou mais grupos de atualização.

  1. No portal do Azure, navegue até o recurso do Gerenciador de Frota de Kubernetes do Azure.

  2. No menu de serviço, em Configurações, selecione Atualização de múltiplos clusters>Estratégias e, em seguida, Criar.

  3. Insira um nome para a estratégia.

  4. Na primeira vez que você exibir a página, um diagrama de explicação de estratégia de atualização é exibido, o que pode ajudar a visualizar como as estratégias funcionam.

    Captura de tela do portal do Azure mostrando a criação da estratégia de atualização.

  5. Selecione Criar Estágio e insira:

    • Nome do estágio - nome do estágio - deve ser único entre todos os nomes de estágio na estratégia.
    • (Opcional) Aprovações de estágio – selecione essa opção se você quiser aguardar uma aprovação antes que essa fase seja iniciada ou depois que ela for concluída. Para obter mais informações, confira Adicionar aprovações a grupos e etapas de atualização.
    • (Opcional) Pausar após o estágio – selecione essa opção se quiser definir uma pausa antes de passar para o próximo estágio.
    • (Opcional) Duração da pausa – selecione uma duração predefinida ou insira um valor personalizado em segundos.

    Uma captura de tela do portal do Azure mostrando a criação do estágio de estratégia de atualização do Gerenciador de Frota de Kubernetes do Azure.

  6. Atribua um ou mais Grupos de Atualização ao estágio e selecione Criar.

    Observação

    O número máximo de Grupos de Atualização em cada Estágio de Atualização é 50.

    Uma captura de tela do portal do Azure mostrando a criação do estágio de estratégia de atualização do Gerenciador de Frota de Kubernetes do Azure, selecionando grupos de atualização a serem incluídos.

Próximas etapas

Você pode usar uma estratégia de atualização como parte de uma execução de atualização manual ou de um perfil de atualização automática. Consulte: