Neste tutorial, você vai conferir um caso de uso comum: implantar uma implantação canário com o Cloud Service Mesh usando APIs do Istio.
O que é uma implantação canário?
Uma implantação canário encaminha uma pequena porcentagem do tráfego para uma nova versão de um microsserviço e, em seguida, aumenta essa porcentagem gradualmente, eliminando e desativando a versão antiga. Se algo der errado durante esse processo, o tráfego poderá ser retornado à versão anterior. Com o Cloud Service Mesh, é possível rotear o tráfego para garantir que novos serviços sejam introduzidos com segurança.
Custos
Neste documento, você usará os seguintes componentes faturáveis do Google Cloud:
Para gerar uma estimativa de custo baseada na projeção de uso deste tutorial, use a calculadora de preços.
Ao concluir este tutorial, exclua os recursos criados para evitar custos contínuos. Para mais informações, consulte Limpeza.
Antes de começar
Verifique se o faturamento está ativado para o projeto Google Cloud . Saiba como confirmar se o faturamento está ativado para o projeto.
Provisione o Cloud Service Mesh em um cluster do GKE ou em outro cluster do Kubernetes com suporte.
Clone o repositório:
git clone https://github.com/GoogleCloudPlatform/anthos-service-mesh-samples cd anthos-service-mesh-samples/docs/canary-service
Implantar Boutique on-line
Defina o contexto atual de
kubectl
no cluster em que você planeja implantar o Online Boutique. O comando depende se você provisionou o Cloud Service Mesh em um cluster do GKE ou um cluster do Kubernetes fora do GKE:GKE no Google Cloud
gcloud container clusters get-credentials CLUSTER_NAME \ --project=PROJECT_ID \ --zone=CLUSTER_LOCATION
GKE fora do Google Cloud
kubectl config use-context CLUSTER_NAME
Crie o namespace para o aplicativo de amostra e o gateway de entrada:
kubectl create namespace onlineboutique
Rotule o namespace
onlineboutique
para injetar automaticamente proxies do Envoy. Siga as etapas para ativar a injeção automática de arquivo secundário.Implante o app de amostra. Neste tutorial, você implanta o Online Boutique, um app de demonstração de microsserviço.
kubectl apply \ -n onlineboutique \ -f https://raw.githubusercontent.com/GoogleCloudPlatform/anthos-service-mesh-samples/main/docs/shared/online-boutique/kubernetes-manifests.yaml
Adicione um rótulo
version=v1
à implantação doproductcatalog
executando o seguinte comando:kubectl patch deployments/productcatalogservice -p '{"spec":{"template":{"metadata":{"labels":{"version":"v1"}}}}}' \ -n onlineboutique
Confira os serviços que você implantou:
kubectl get pods -n onlineboutique
Saída esperada:
NAME READY STATUS RESTARTS AGE adservice-85598d856b-m84m6 2/2 Running 0 2m7s cartservice-c77f6b866-m67vd 2/2 Running 0 2m8s checkoutservice-654c47f4b6-hqtqr 2/2 Running 0 2m10s currencyservice-59bc889674-jhk8z 2/2 Running 0 2m8s emailservice-5b9fff7cb8-8nqwz 2/2 Running 0 2m10s frontend-77b88cc7cb-mr4rp 2/2 Running 0 2m9s loadgenerator-6958f5bc8b-55q7w 2/2 Running 0 2m8s paymentservice-68dd9755bb-2jmb7 2/2 Running 0 2m9s productcatalogservice-84f95c95ff-c5kl6 2/2 Running 0 114s recommendationservice-64dc9dfbc8-xfs2t 2/2 Running 0 2m9s redis-cart-5b569cd47-cc2qd 2/2 Running 0 2m7s shippingservice-5488d5b6cb-lfhtt 2/2 Running 0 2m7s
Um
2/2
na colunaREADY
indica que um pod está ativo com um proxy do Envoy injetado com sucesso.Implante
VirtualService
eDestinationRule
para a v1 deproductcatalog
:kubectl apply -f destination-vs-v1.yaml -n onlineboutique
Observe que apenas
v1
está presente nos recursos.Confira a
Destination Rule
criada.kubectl get destinationrules -n onlineboutique
Saída esperada:
NAME HOST AGE productcatalogservice productcatalogservice 2m
Confira a
VirtualService
criada.kubectl get virtualservices -n onlineboutique
Resultado esperado:
NAME GATEWAYS HOSTS AGE productcatalogservice ["productcatalogservice"] 2m
Acesse o aplicativo no navegador usando o endereço IP externo do gateway de entrada:
kubectl get services -n GATEWAY_NAMESPACE
Esta próxima seção mostra a interface do Cloud Service Mesh e como visualizar suas métricas.
Acessar seus serviços no console do Google Cloud
No console do Google Cloud , acesse a página Serviços do Google Kubernetes Engine (GKE) edição Enterprise.
Acesse os Serviços do Google Kubernetes Engine (GKE) edição Enterprise
Por padrão, os serviços são exibidos na visualização Lista.
A Visão geral da tabela permite que você observe todos seus serviços, bem como métricas importantes rapidamente.
No canto superior direito, clique em Topologia. Aqui você pode ver seus serviços e a interação entre eles.
É possível expandir Serviços e conferir as Solicitações por segundo de cada um deles. Para isso, passe o cursor sobre eles.
Volte para a Visualização em tabela.
Na Tabela de serviços, selecione
productcatalogservice
. Isso leva você a uma visão geral do serviço.No lado esquerdo da tela, clique em Tráfego.
Verifique se 100% do tráfego de entrada para
productcatalogservice
vai para o serviço de carga de trabalho.
A próxima seção mostra como criar uma v2 do serviço productcatalog
.
Implantar a v2 de um serviço
Para este tutorial,
productcatalogservice-v2
introduz uma latência de três segundos nas solicitações com o campoEXTRA_LATENCY
. Isso simula uma regressão na nova versão do serviço.Aplique este recurso ao namespace
onlineboutique
.kubectl apply -f productcatalog-v2.yaml -n onlineboutique
Verifique os pods do aplicativo.
kubectl get pods -n onlineboutique
Resposta esperada:
NAME READY STATUS RESTARTS AGE adservice-85598d856b-8wqfd 2/2 Running 0 25h cartservice-c77f6b866-7jwcr 2/2 Running 0 25h checkoutservice-654c47f4b6-n8c6x 2/2 Running 0 25h currencyservice-59bc889674-l5xw2 2/2 Running 0 25h emailservice-5b9fff7cb8-jjr89 2/2 Running 0 25h frontend-77b88cc7cb-bwtk4 2/2 Running 0 25h loadgenerator-6958f5bc8b-lqmnw 2/2 Running 0 25h paymentservice-68dd9755bb-dckrj 2/2 Running 0 25h productcatalogservice-84f95c95ff-ddhjv 2/2 Running 0 25h productcatalogservice-v2-6df4cf5475-9lwjb 2/2 Running 0 8s recommendationservice-64dc9dfbc8-7s7cx 2/2 Running 0 25h redis-cart-5b569cd47-vw7lw 2/2 Running 0 25h shippingservice-5488d5b6cb-dj5gd 2/2 Running 0 25h
Observe que agora há dois
productcatalogservices
listados.Use
DestinationRule
para especificar os subconjuntos de um serviço. Neste cenário, há um subconjunto da v1 e um subconjunto separado da v2 doproductcatalogservice
.Observe o campo
labels
. As versões doproductcatalogservice
são diferenciadas depois que o tráfego é roteado peloVirtualService
.Aplique o
DestinationRule
:kubectl apply -f destination-v1-v2.yaml -n onlineboutique
Dividir o tráfego entre v1 e v2
Use
VirtualService
para definir uma pequena porcentagem do tráfego para direcionar à v2 doproductcatalogservice
.O campo de subconjunto indica a versão e o campo de peso indica a divisão percentual do tráfego. 75% do tráfego vai para a v1 do catálogo de produtos e 25% para a v2.
Aplique o
VirtualService
:kubectl apply -f vs-split-traffic.yaml -n onlineboutique
Se você acessar o EXTERNAL_IP
da entrada do cluster, observe que, periodicamente, o carregamento do front-end está mais lento.
Na próxima seção, conheça a divisão de tráfego no console do Google Cloud .
Observar a divisão de tráfego no console do Google Cloud
Volte ao console do Google Cloud e acesse a página "Serviços do GKE Enterprise". Acessar o GKE Enterprise Services
No canto superior direito, clique em Topologia.
Expanda a carga de trabalho
productcatalogservice
e observe as implantaçõesproductcatalogservice
eproductcatalogservice-v2
.Volte para Visualização de tabela.
Clique em
productcatalogservice
na tabela de serviços.Volte para Tráfego na barra de navegação à esquerda.
O tráfego de entrada é dividido entre v1 e v2 pela porcentagem especificada no arquivo
VirtualService
. Além disso, há duas cargas de trabalho do serviço productcatalog.No lado direito da página, você encontra Solicitações, Taxa de erros e Métricas de latência. Com o Cloud Service Mesh, cada serviço tem essas métricas descritas para fornecer a você métricas de observabilidade.
Lançar ou reverter para uma versão
Depois de observar as métricas durante uma implantação canário, você pode concluir o lançamento da nova versão do serviço ou reverter para a versão original do serviço usando o recurso VirtualService
.
Lançar
Quando estiver satisfeito com o comportamento de um serviço da v2, aumente gradualmente a porcentagem de tráfego direcionado para o serviço da v2. Em algum momento, o tráfego poderá ser direcionado 100% para o novo serviço no recurso VirtualService criado acima, removendo a divisão de tráfego desse recurso.
Para direcionar todo o tráfego para a v2 de productcatalogservice
:
kubectl apply -f vs-v2.yaml -n onlineboutique
Reverter
Se você precisar reverter para o serviço v1, aplique o destination-vs-v1.yaml
anterior. Isso direciona o tráfego apenas para a v1 de productcatalogservice
.
Para direcionar todo o tráfego para a v1 de productcatalogservice
:
kubectl apply -f vs-v1.yaml -n onlineboutique
Limpar
Para evitar cobranças na sua conta do Google Cloud pelos recursos usados no tutorial, exclua o projeto que os contém ou mantenha o projeto e exclua os recursos individuais.
Para evitar cobranças recorrentes na sua conta do Google Cloud pelos recursos usados neste tutorial, é possível excluir o projeto ou os recursos individuais.
Exclua o projeto
No Cloud Shell, exclua o projeto:
gcloud projects delete PROJECT_ID
Excluir os recursos
Se quiser evitar cobranças adicionais, exclua o cluster:
gcloud container clusters delete CLUSTER_NAME \
--project=PROJECT_ID \
--zone=CLUSTER_LOCATION
Se você registrou o cluster na frota usando gcloud container fleet memberships
(em vez de --enable-fleet
ou --fleet-project
durante a criação do cluster),
remova a assinatura desaturada:
gcloud container fleet memberships delete MEMBERSHIP \
--project=PROJECT_ID
Se você quiser manter o cluster configurado para o Cloud Service Mesh, mas remover o exemplo do Online Boutique:
Exclua os namespaces do aplicativo:
kubectl delete -f namespace onlineboutique
Saída esperada:
namespace "onlineboutique" deleted
Exclua as entradas de serviço:
kubectl delete -f https://raw.githubusercontent.com/GoogleCloudPlatform/microservices-demo/main/istio-manifests/frontend.yaml -n onlineboutique kubectl delete -f https://raw.githubusercontent.com/GoogleCloudPlatform/microservices-demo/main/istio-manifests/frontend-gateway.yaml -n onlineboutique
Resposta esperada:
serviceentry.networking.istio.io "allow-egress-googleapis" deleted serviceentry.networking.istio.io "allow-egress-google-metadata" deleted
A seguir
- Para obter um guia geral sobre como configurar políticas
PeerAuthentication
, consulte Como configurar a segurança de transporte.