Visão geral
O Anthos Service Mesh gerenciado com asmcli
é um plano de controle gerenciado e um
plano de dados
gerenciado opcional que basta você configurar. O Google lida com a confiabilidade, os upgrades, o escalonamento e a segurança deles de maneira compatível com versões anteriores. Neste
guia, explicamos como configurar ou migrar aplicativos para o Anthos Service Mesh gerenciado em
uma configuração de um ou vários clusters com asmcli
.
Para saber mais sobre os recursos e limitações compatíveis com o Anthos Service Mesh gerenciado, consulte Recursos compatíveis com o Anthos Service Mesh gerenciado.
Pré-requisitos
Como ponto de partida, neste guia presume-se que você:
- Um projeto do Cloud
- Uma Conta de faturamento do Cloud.
- Recebeu as permissões necessárias para provisionar o Anthos Service Mesh gerenciado
- A ferramenta de instalação
asmcli
,kpt
e outras ferramentas especificadas em Como instalar as ferramentas necessárias
Para uma instalação mais rápida, a Identidade da carga de trabalho precisa estar ativada nos clusters. Se a identidade da carga de trabalho não estiver ativada, ela será ativada pela instalação automaticamente.
Requisitos
- Um ou mais clusters com uma versão compatível do GKE, em uma das regiões com suporte.
- Verifique se o cluster tem capacidade suficiente para os componentes necessários que
gerenciaram as instalações do Anthos Service Mesh no cluster.
- A implantação
mdp-controller
no namespacekube-system
solicita CPU: 50m, memória: 128Mi. - O daemonset
istio-cni-node
no namespacekube-system
solicita cpu: 100m, memória: 100Mi em cada nó.
- A implantação
- Verifique se a máquina cliente da qual você instala o Anthos Service Mesh gerenciado tem conexão de rede com o servidor de API.
- Os clusters precisam estar registrados em uma frota.
Isso pode ser feito separadamente antes da instalação ou como parte da
instalação, com a transmissão das sinalizações
--enable-registration
e--fleet-id
. O projeto precisa ter o recurso da frota Service Mesh ativado. Você pode ativá-lo como parte da instalação transmitindo
--enable-gcp-components
ou executando o seguinte comando:gcloud container fleet mesh enable --project=FLEET_PROJECT_ID
FLEET_PROJECT_ID é o ID do projeto host da frota.
O GKE Autopilot é compatível apenas com a versão 1.21.3 ou mais recente do GKE.
A CNI do Istio é necessária e instalada por padrão ao provisionar o Anthos Service Mesh gerenciado.
O Anthos Service Mesh gerenciado pode usar vários clusters do GKE em um ambiente de rede única de projeto único ou de vários projetos.
- Se você mesclar clusters que não estejam no mesmo projeto, eles vão precisar ser registrados no mesmo projeto host da frota, e será preciso que os clusters estejam em um projeto de VPC compartilhada na mesma rede.
- Para um ambiente de vários clusters com um único projeto, o projeto da frota pode ser o mesmo que o do cluster. Para mais informações sobre frotas, consulte Informações gerais das frotas.
- Para um ambiente de vários projetos, recomendamos que você hospede a frota em um projeto separado dos projetos do cluster. Se as políticas da organização e a configuração atual permitirem, recomendamos que você use o projeto da VPC compartilhada como o projeto host da frota. Para mais informações, consulte Como configurar clusters com a VPC compartilhada.
- Se a organização usa o VPC Service Controls e você está provisionando o Anthos Service Mesh gerenciado nos clusters do GKE, também é necessário seguir as etapas em VPC Service Controls para Anthos Service Mesh.
Limitações
Recomendamos que você analise a lista de recursos e limitações gerenciados do Anthos Service Mesh. Observe especificamente o seguinte:
Não há suporte para a API
IstioOperator
porque a finalidade principal dela é controlar componentes no cluster.As migrações do Anthos Service Mesh gerenciado com
asmcli
para o Anthos Service Mesh com a API Fleet não são compatíveis. Da mesma forma, não é possível configurar o Anthos Service Mesh gerenciado com a API Fleet de--management manual
para--management automatic
.Nos clusters do GKE Autopilot, a configuração entre projetos é compatível apenas com o GKE 1.23 e posterior.
Para que os clusters do GKE Autopilot se adaptem ao limite de recursos do Autopilot do GKE, as solicitações e os limites de recursos de proxy padrão são definidos como 500m de CPU e 512MB de memória. É possível modificar os valores padrão usando a injeção personalizada.
Os recursos reais disponíveis no Anthos Service Mesh gerenciado dependem do canal de lançamento. Saiba mais na lista completa de recursos e limitações compatíveis com o Anthos Service Mesh.
Durante o processo de provisionamento de um plano de controle gerenciado, os CRDs do Istio correspondentes ao canal selecionado são instalados no cluster especificado. Se houver CRDs atuais do Istio no cluster, eles serão substituídos.
A CNI do Istio não é compatível com o GKE Sandbox. O Anthos Service Mesh é gerenciado no Autopilot, portanto, não funciona com o GKE Sandbox, já que a CNI gerenciada do Istio é necessária.
A ferramenta
asmcli
precisa ter acesso ao endpoint do Google Kubernetes Engine (GKE). É possível configurar o acesso por meio de um servidor"salto", como uma VM do Compute Engine na nuvem privada virtual (VPC) que dá acesso específico.
Antes de começar
Configurar a gcloud
Siga as etapas abaixo mesmo se estiver usando o Cloud Shell.
Faça a autenticação com a Google Cloud CLI:
gcloud auth login --project PROJECT_ID
Atualize os componentes:
gcloud components update
Configure
kubectl
para apontar para o cluster.gcloud container clusters get-credentials CLUSTER_NAME \ --zone CLUSTER_LOCATION \ --project PROJECT_ID
Fazer o download da ferramenta de instalação
Faça o download da versão mais recente da ferramenta para o diretório de trabalho atual:
curl https://storage.googleapis.com/csm-artifacts/asm/asmcli > asmcli
Torne a ferramenta executável:
chmod +x asmcli
Configurar cada cluster
Siga as etapas abaixo para configurar o Managed Service Mesh para cada cluster na sua malha.
Aplicar o plano de controle gerenciado
Antes de aplicar o plano de controle gerenciado, é preciso selecionar um canal de lançamento.
Execute a ferramenta de instalação para cada cluster que usará o Anthos Service Mesh gerenciado. Recomendamos que você inclua as duas opções a seguir:
--enable-registration --fleet_id FLEET_PROJECT_ID
Essas duas sinalizações registram o cluster em uma frota, em que FLEET_ID é o ID do projeto host da frota. Se você estiver usando um único projeto, FLEET_PROJECT_ID será o mesmo que PROJECT_ID. O projeto host de frota e o projeto de cluster também serão iguais. Em configurações mais complexas, como vários projetos, recomendamos o uso de um projeto host de frota separado.--enable-all
. Essa sinalização ativa os componentes necessários e o registro.
A ferramenta asmcli
configura o plano de controle gerenciado diretamente usando ferramentas e lógica
dentro da ferramenta CLI. Use o conjunto de instruções abaixo de acordo com
sua CA preferencial.
Autoridades certificadoras
Selecione uma autoridade certificadora para usar na malha.
CA da malha
Execute o comando a seguir para instalar o plano de controle com recursos padrão
e CA da malha. Digite seus valores nos marcadores fornecidos. Substitua
RELEASE_CHANNEL pelo canal adequado:
regular
, stable
ou rapid
.
./asmcli install \
-p PROJECT_ID \
-l LOCATION \
-n CLUSTER_NAME \
--fleet_id FLEET_PROJECT_ID \
--managed \
--verbose \
--output_dir DIR_PATH \
--enable-all
Serviço de CA
- Siga as etapas em Configurar o Certificate Authority Service.
- Execute o comando a seguir para instalar o plano de controle com recursos
padrão e o Certificate Authority Service.
Digite seus valores nos marcadores fornecidos. Substitua
RELEASE_CHANNEL pelo canal adequado:
regular
,stable
ourapid
.
./asmcli install \
-p PROJECT_ID \
-l LOCATION \
-n CLUSTER_NAME \
--fleet_id FLEET_PROJECT_ID \
--managed \
--verbose \
--output_dir DIR_PATH \
--enable-all \
--ca gcp_cas \
--ca_pool pool_name
A ferramenta faz o download de todos os arquivos para configurar o plano de controle gerenciado
para o --output_dir
especificado, instalando a ferramenta istioctl
e os aplicativos de
amostra. Para seguir as etapas deste guia, é necessário executar istioctl
no local
--output_dir
especificado ao executar asmcli install
, com
istioctl
presente no subdiretório <Istio release dir>/bin
.
Se você executar novamente asmcli
no mesmo cluster, ele substituirá a configuração do plano de controle existente. Especifique as mesmas opções e
sinalizações, se quiser a mesma configuração.
Verificar se o plano de controle foi provisionado
Após alguns minutos, verifique se o status no plano de controle é ACTIVE
:
gcloud container fleet mesh describe --project FLEET_PROJECT_ID
A resposta é semelhante a:
membershipStates: projects/746296320118/locations/us-central1/memberships/demo-cluster-1: servicemesh: controlPlaneManagement: details: - code: REVISION_READY details: 'Ready: asm-managed' state: ACTIVE ... state: code: OK description: 'Revision(s) ready for use: asm-managed.'
Se o status não atingir ACTIVE
em alguns minutos, consulte
Verificar o status do plano de controle gerenciado
para mais informações sobre possíveis erros.
Upgrades sem toque
Depois que o plano de controle gerenciado for instalado, o Google fará upgrade automaticamente dele quando novas versões ou patches forem disponibilizados.
Plano de dados gerenciado
Se você usa o Anthos Service Mesh gerenciado, o Google gerencia totalmente os upgrades dos proxies, a menos que você o desative no nível de namespace, carga de trabalho ou revisão.
Com o plano de dados gerenciado, os proxies sidecar e os gateways injetados são atualizados automaticamente em conjunto com o plano de controle gerenciado reiniciando cargas de trabalho para injetar novas versões do proxy novamente. Isso normalmente é concluído de uma a duas semanas após o upgrade do plano de controle gerenciado.
Se desativado, o gerenciamento de proxy é determinado pelo ciclo de vida natural dos pods no cluster e precisa ser acionado manualmente pelo usuário para controlar a taxa de atualização.
O plano de dados gerenciado faz upgrade dos proxies removendo os pods que estão executando versões anteriores do proxy. As remoções são feitas gradualmente, honrando o orçamento de interrupção do pod e controlando a taxa de mudança.
O plano de dados gerenciado não gerencia o seguinte:
- Pods não injetados
- Pods injetados manualmente
- Jobs
- StatefulSets
- DaemonSets
Se você tiver provisionado o Anthos Service Mesh gerenciado em um cluster mais antigo, poderá ativar o gerenciamento do plano de dados para todo o cluster:
kubectl annotate --overwrite controlplanerevision -n istio-system \
REVISION_LABEL \
mesh.cloud.google.com/proxy='{"managed":"true"}'
Como alternativa, é possível ativar seletivamente o plano de dados gerenciado para uma revisão específica do plano de controle, o namespace ou o pod, anotando-o com a mesma anotação. Se você controla componentes individuais de forma seletiva, a ordem de precedência é a revisão do plano de controle, o namespace e o pod.
O serviço pode levar até 10 minutos para gerenciar os proxies no cluster. Execute o seguinte comando para verificar o status:
gcloud container fleet mesh describe --project FLEET_PROJECT_ID
Resposta esperada
membershipStates:
projects/PROJECT_NUMBER/locations/global/memberships/CLUSTER_NAME:
servicemesh:
dataPlaneManagement:
details:
- code: OK
details: Service is running.
state: ACTIVE
state:
code: OK
description: 'Revision(s) ready for use: asm-managed-rapid.'
Se o serviço não ficar pronto em 10 minutos, consulte Status do plano de dados gerenciado para ver as próximas etapas.
Desativar o plano de dados gerenciado (opcional)
Se você estiver provisionando o Anthos Service Mesh gerenciado em um novo cluster, poderá desativar completamente o plano de dados gerenciado ou para namespaces ou pods individuais. O plano de dados gerenciado continuará desativado para os clusters atuais em que foi desativado por padrão ou manualmente.
Para desativar o plano de dados gerenciado no nível do cluster e voltar a gerenciar os proxies sidecar, altere a anotação:
kubectl annotate --overwrite controlplanerevision -n istio-system \
REVISION_LABEL \
mesh.cloud.google.com/proxy='{"managed":"false"}'
Para desativar o plano de dados gerenciado de um namespace:
kubectl annotate --overwrite namespace NAMESPACE \
mesh.cloud.google.com/proxy='{"managed":"false"}'
Para desativar o plano de dados gerenciado de um pod:
kubectl annotate --overwrite pod POD_NAME \
mesh.cloud.google.com/proxy='{"managed":"false"}'
Ativar notificações de manutenção
É possível solicitar uma notificação sobre a futura manutenção do plano de dados gerenciados até uma semana antes do horário de manutenção. As notificações de manutenção não são enviadas por padrão. Você também precisa configurar uma janela de manutenção do GKE antes de receber notificações. Quando ativadas, as notificações são enviadas pelo menos dois dias antes da operação de upgrade.
Para ativar as notificações de manutenção do plano de dados gerenciado:
Acesse a página Comunicação.
Acesse a página Comunicação.
Na linha Anthos Service Mesh Upgrade, na coluna E-mail, selecione o botão de opção para ativar as notificações de manutenção.
Cada usuário que quer receber notificações precisa aceitar separadamente. Se você quiser definir um filtro de e-mail para essas notificações, a linha de assunto será:
Upcoming upgrade for your Anthos Service Mesh cluster "CLUSTER_LOCATION/CLUSTER_NAME"
.
O exemplo a seguir mostra uma notificação típica de manutenção do plano de dados gerenciados:
Assunto: Futuro upgrade para o cluster do ASM "
<location/cluster-name>
"Olá, usuário do Anthos Service Mesh,
O upgrade dos componentes do Anthos Service Mesh no seu cluster ${instance_id} (https://console.cloud.google.com/kubernetes/clusters/details/${instance_id}/details?project=${project_id}) está programado para upgrade em ${scheduled_date_human_readable} at ${scheduled_time_human_readable}.
É possível conferir as notas da versão (https://cloud.google.com/service-mesh/docs/release-notes) para saber mais sobre a nova atualização.
Caso essa manutenção seja reprogramada, você receberá outro e-mail com informações.
Até mais,
Equipe do Anthos Service Mesh
(c) 2022 Google LLC, 1600, Amphitheater Parkway, Mountain View, CA 94043 Enviamos este aviso para informar sobre mudanças importantes no Google Cloud Platform ou na sua conta. Para desativar as notificações sobre janelas de manutenção, altere suas preferências de usuário: https://console.cloud.google.com/user-preferences/communication?project=
Configurar a descoberta de endpoint (somente para instalações de vários clusters)
Antes de prosseguir, você precisa ter configurado o Anthos Service Mesh gerenciado em cada cluster, conforme descrito nas etapas anteriores. Não há necessidade de indicar que um cluster é primário, pois esse é o comportamento padrão.
Além disso, verifique se você
fez o download de asmcli
(somente se quiser verificar sua configuração com o aplicativo de amostra) e
defina as variáveis do projeto e do cluster.
Clusters públicos
Configurar a descoberta de endpoints entre clusters públicos
Se você estiver operando em clusters públicos (clusters não particulares), será possível Configurar a descoberta de endpoints entre clusters públicos ou simplesmente Ativar a descoberta de endpoints entre clusters públicos.
Clusters particulares
Configurar a descoberta de endpoints entre clusters particulares
Ao usar os clusters particulares do GKE, configure o endpoint do plano de controle do cluster para ser o endpoint público, e não o particular. Consulte Configurar a descoberta de endpoints entre clusters particulares.
Para um aplicativo de exemplo com dois clusters, veja Exemplo de serviço HelloWorld.
Implantar aplicativos
Para implantar aplicativos, use o rótulo correspondente ao canal que você
configurou durante a instalação ou istio-injection=enabled
se estiver usando
rótulos de injeção padrão.
Rótulo de injeção padrão
kubectl label namespace NAMESPACE istio-injection=enabled istio.io/rev- --overwrite
Rótulo de revisão
Antes de implantar aplicativos, remova os rótulos istio-injection
anteriores
dos namespaces e defina o rótulo istio.io/rev=REVISION_LABEL
.
Para alterá-lo para um identificador de revisão específico, clique em REVISION_LABEL
e substitua-o pelo identificador aplicável: asm-managed-rapid
para Rápido, asm-managed
para Regular ou asm-managed-stable
para Estável.
O rótulo de revisão corresponde a um canal de lançamento:
Rótulo de revisão | Channel |
---|---|
asm-managed |
Normal |
asm-managed-rapid |
Rápido |
asm-managed-stable |
Canal Stable |
kubectl label namespace NAMESPACE istio-injection- istio.io/rev=REVISION_LABEL --overwrite
Você já configurou o Anthos Service Mesh gerenciado. Se você tiver cargas de trabalho em namespaces rotulados, reinicie-os para que possam ser injetados os proxies.
Agora está tudo pronto para implantar os aplicativos ou implantar o aplicativo de amostra Bookinfo.
Se você implantar um aplicativo em uma configuração de vários clusters, replique a configuração do Kubernetes e do plano de controle em todos os clusters, a menos que pretenda limitar essa configuração específica a um subconjunto de clusters. A configuração aplicada a um determinado cluster é a fonte da verdade desse cluster.
Personalizar injeção (opcional)
A configuração por pod está disponível para substituir essas opções em pods individuais.
Para fazer isso, adicione um contêiner istio-proxy
ao seu pod. A injeção
de sidecar vai tratar qualquer configuração definida aqui como uma substituição do
modelo de injeção padrão.
Por exemplo, a configuração a seguir personaliza várias configurações, incluindo a redução das solicitações de CPU, adição de uma montagem de volume e adição de um hook preStop
:
apiVersion: v1
kind: Pod
metadata:
name: example
spec:
containers:
- name: hello
image: alpine
- name: istio-proxy
image: auto
resources:
requests:
cpu: "200m"
memory: "256Mi"
limites:
cpu: "200m"
memory: "256Mi"
volumeMounts:
- mountPath: /etc/certs
name: certs
lifecycle:
preStop:
exec:
command: ["sleep", "10"]
volumes:
- name: certs
secret:
secretName: istio-certs
Em geral, qualquer campo em um pod pode ser definido. No entanto, é preciso ter cuidado com alguns campos:
- O Kubernetes exige que o campo
image
seja definido antes da execução da injeção. Embora seja possível definir uma imagem específica para substituir a padrão, recomendamos definir aimage
comoauto
, o que fará com que o injetor do sidecar selecione a imagem automaticamente. - Alguns campos em
containers
dependem de configurações relacionadas. Por exemplo, a solicitação da CPU precisa ser menor que o limite da CPU. Se os dois campos não estiverem configurados corretamente, o pod pode não ser iniciado. - O Kubernetes permite definir
requests
elimits
para recursos noPodSpec
. O GKE Autopilot só considerarequests
. Para mais informações, consulte Como definir limites de recursos no Autopilot.
Além disso, alguns campos podem ser configurados por anotações no pod, mas é recomendável usar a abordagem acima para personalizar as configurações. É preciso ter cuidado com algumas anotações:
- Para o GKE Standard, se
sidecar.istio.io/proxyCPU
estiver definido, defina explicitamentesidecar.istio.io/proxyCPULimit
. Caso contrário, o limite de CPU do arquivo secundário será definido como ilimitado. - Para o GKE Standard, se
sidecar.istio.io/proxyMemory
estiver definido, defina explicitamentesidecar.istio.io/proxyMemoryLimit
. Caso contrário, o limite de memória do arquivo secundário será definido como ilimitado. - No GKE Autopilot, configurar o recurso
requests
elimits
usando anotações pode superprovisionar recursos. Use a abordagem de modelo de imagem para evitar. Consulte Exemplos de modificação de recursos no Autopilot.
Por exemplo, consulte a configuração da anotação de recursos abaixo:
spec:
template:
metadata:
annotations:
sidecar.istio.io/proxyCPU: "200m"
sidecar.istio.io/proxyCPULimit: "200m"
sidecar.istio.io/proxyMemory: "256Mi"
sidecar.istio.io/proxyMemoryLimit: "256Mi"
Verificar as métricas do plano de controle
É possível ver a versão do plano de controle e do plano de dados no Metrics Explorer.
Para verificar se configuração funciona corretamente:
No Console do Google Cloud, veja as métricas do plano de controle:
Escolha o espaço de trabalho e adicione uma consulta personalizada usando os seguintes parâmetros:
- Tipo de recurso: contêiner do Kubernetes
- Métrica: clientes proxy
- Filtro:
container_name="cr-REVISION_LABEL"
- Agrupar por: marcador
revision
eproxy_version
marcador - Soma do agregador
- Período: 1 minuto
Ao executar o Anthos Service Mesh com um plano de controle gerenciado pelo Google e outro no cluster, é possível diferenciar as métricas pelo nome do contêiner. Por exemplo, as métricas gerenciadas têm
container_name="cr-asm-managed"
, enquanto métricas não gerenciadas têmcontainer_name="discovery"
. Para exibir métricas de ambos, remova o filtro emcontainer_name="cr-asm-managed"
.Verifique a versão do plano de controle e a versão do proxy inspecionando os seguintes campos no Metrics Explorer:
- O campo revisão indica a versão do plano de controle.
- O campo proxy_version indica o
proxy_version
. - O campo valor indica o número de proxies conectados.
Para o canal atual para o mapeamento de versão do Mesh Service Mesh, consulte Versões do Anthos Service Mesh por canal.
Migrar aplicativos para o Anthos Service Mesh gerenciado
Preparar para a migração
Para preparar a migração de aplicativos do Anthos Service Mesh no cluster para o Anthos Service Mesh gerenciado, execute as seguintes etapas:
Execute a ferramenta conforme indicado na seção Aplicar o plano de controle gerenciado pelo Google.
(Opcional) Para usar o plano de dados gerenciado pelo Google, ative o gerenciamento:
kubectl annotate --overwrite controlplanerevision REVISION_TAG \ mesh.cloud.google.com/proxy='{"managed":"true"}'
Migrar aplicativos
Para migrar aplicativos do Anthos Service Mesh no cluster para o Anthos Service Mesh gerenciado, execute as seguintes etapas:
Substitua o rótulo de namespace atual. As etapas necessárias dependem do uso de rótulos de injeção padrão (por exemplo,
istio-injection enabled
) ou do identificador de revisãoRótulo de injeção padrão
Execute o seguinte comando para mover a tag padrão para a revisão gerenciada:
istioctl tag set default --revision REVISION_LABEL
Execute o seguinte comando para rotular o namespace usando
istio-injection=enabled
, se ele ainda não tiver sido feito:kubectl label namespace NAMESPACE istio-injection=enabled istio.io/rev- \ --overwrite
Rótulo de revisão
Se você usou o rótulo
istio.io/rev=REVISION_LABEL
, execute o seguinte comando:kubectl label namespace NAMESPACE istio-injection- istio.io/rev=REVISION_LABEL \ --overwrite
Execute um upgrade contínuo das implantações no namespace:
kubectl rollout restart deployment -n NAMESPACE
Teste o aplicativo para verificar se as cargas de trabalho funcionam corretamente.
Se você tiver cargas de trabalho em outros namespaces, repita os passos anteriores para cada namespace.
Se você implantou o aplicativo em uma configuração de vários clusters, replique a configuração do Kubernetes e do Istio em todos os clusters, a menos você pretenda limitar essa configuração apenas a um subconjunto de clusters. A configuração aplicada a um determinado cluster é a fonte da verdade desse cluster.
Verifique se as métricas aparecem conforme esperado seguindo as etapas em Verificar métricas do plano de controle.
Se o aplicativo funcionar como esperado, é possível remover o
cluster istiod
interno depois de alternar todos os namespaces para o plano de controle gerenciado
pelo cliente ou mantê-los como backup. istiod
reduzirá automaticamente
para usar menos recursos. Para remover, pule para
Excluir o plano de controle antigo.
Se você encontrar problemas, identifique e resolva-os seguindo as informações em Como resolver problemas do plano de controle gerenciado. Se necessário, reverta para a versão anterior.
Excluir o plano de controle antigo
Depois de instalar e confirmar que todos os namespaces usam o plano de controle gerenciado pelo Google, é possível excluir o plano de controle antigo.
kubectl delete Service,Deployment,HorizontalPodAutoscaler,PodDisruptionBudget istiod -n istio-system --ignore-not-found=true
Se você usou istioctl kube-inject
em vez da injeção automática ou se
instalou outros gateways, verifique as métricas do plano de controle
e verifique se o número de endpoints conectados é zero.
Reverter
Siga estas etapas se precisar reverter para a versão anterior do plano de controle:
Atualize as cargas de trabalho a serem injetadas com a versão anterior do plano de controle: No comando a seguir, o valor de revisão
asm-191-1
é usado apenas como exemplo. Substitua o valor de exemplo pelo rótulo da revisão do plano de controle anterior.kubectl label namespace NAMESPACE istio-injection- istio.io/rev=asm-191-1 --overwrite
Reinicie os pods para acionar a reinjeção para que os proxies tenham a versão anterior:
kubectl rollout restart deployment -n NAMESPACE
O plano de controle gerenciado será escalonado automaticamente para zero e não usará nenhum recurso quando não estiver em uso. Os webhooks e o provisionamento mutáveis não serão afetados e não afetarão o comportamento do cluster.
O gateway agora está definido para a revisão asm-managed
. Para reverter, execute novamente
o comando de instalação do Anthos Service Mesh, que implantará novamente o gateway que aponta para
o plano de controle no cluster:
kubectl -n istio-system rollout undo deploy istio-ingressgateway
Esta é a resposta esperada em caso de êxito:
deployment.apps/istio-ingressgateway rolled back
Desinstalar
O plano de controle gerenciado reduz a escala a zero automaticamente quando nenhum namespace está usando esse recurso. Para etapas detalhadas, consulte Desinstalar o Anthos Service Mesh.
Solução de problemas
Para identificar e resolver problemas ao usar um plano de controle gerenciado, consulte Como resolver problemas do plano de controle gerenciado.
A seguir
- Saiba mais sobre os canais de lançamento.
- Migrar de
IstioOperator
. - Migrar um gateway para o plano de controle gerenciado.
- Saiba como ativar recursos opcionais do Anthos Service Mesh gerenciado, como: