Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
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.
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
fleetAzure versão 1.6.0 ou posterior, que pode ser instalada executando o seguinte comando:az extension add --name fleetExecute o comando
az extension updatepara 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
memberSelectorpara 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.
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
memberSelectorpara selecionar clusters por seus rótulos e inclui configurações opcionaismaxConcurrency:- O estágio
stagingusa ummemberSelectorem nível de estágio para selecionar todos os clusters com o rótuloenv=staginge criar um grupo implícito. - A etapa
productionutiliza um filtro no nível da etapamemberSelectorpara pré-filtrar todos os clusters com o rótuloenv=production, e, em seguida, define dois grupos, cada um com seu própriomemberSelectorpara selecionar os clusters com base no rótulotier.
Quando
memberSelectoré definido em um grupo, o camponamedesse 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" } ] } ] }- O estágio
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).
Crie uma nova estratégia de atualização usando o comando
az fleet updatestrategy createcom o sinalizador--stagesdefinido 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
No portal do Azure, navegue até o recurso do Gerenciador de Frota de Kubernetes do Azure.
No menu de serviço, em Configurações, selecione Cluster membros>Adicionar.
Selecione o cluster que você deseja adicionar e selecione Avançar: Examinar + adicionar.
Insira o nome do grupo de atualização ao qual deseja atribuir o cluster e selecione Adicionar.
Atribuir um membro da frota existente a um grupo de atualização
No portal do Azure, navegue até o recurso do Gerenciador de Frota de Kubernetes do Azure.
No menu de serviço, em Configurações, selecione Cluster membros.
Selecione os clusters que você deseja atribuir a um grupo de atualização e selecione Atribuir grupo de atualização
Insira o nome do grupo de atualização ao qual deseja atribuir o cluster e selecione Atribuir.
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.
No portal do Azure, navegue até o recurso do Gerenciador de Frota de Kubernetes do Azure.
No menu de serviço, em Configurações, selecione Atualização de múltiplos clusters>Estratégias e, em seguida, Criar.
Insira um nome para a estratégia.
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.
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.
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.
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:
- Instruções: Atualizar vários clusters usando execuções de atualização do Gerenciador de Frota de Kubernetes do Azure.
- Instruções: adicionar aprovações às estratégias de atualização do Azure Kubernetes Fleet Manager.
- Instruções: Atualizar automaticamente vários clusters usando o Gerenciador de Frota de Kubernetes do Azure.
- Perguntas frequentes sobre atualizações de vários clusters.