Implantar sua instância de Gerenciamento de API do Azure em uma rede virtual – modo interno
APLICA-SE A: Desenvolvedor | Premium
O Gerenciamento de API do Azure pode ser implantado (injetado) dentro de uma VNet (rede virtual) do Azure para acessar serviços de back-end na rede. Para conhecer as opções de conectividade VNet, os requisitos e as considerações, consulte:
- Usando uma rede virtual com o Gerenciamento de API do Azure
- Requisitos de recursos de rede para injeção do Gerenciamento de API em uma rede virtual
Este artigo explica como configurar a conectividade VNet para sua instância de Gerenciamento de API no modo interno. Nesse modo, você só poderá acessar os pontos de extremidade de Gerenciamento de API a seguir em uma VNet cujo acesso você controla.
- O gateway de API
- O portal do desenvolvedor
- Gerenciamento direto
- Git
Observação
- Nenhum dos pontos de extremidade de Gerenciamento de API é registrado no DNS público. Os pontos de extremidade permanecerão inacessíveis até que você configure o DNS para a VNet.
- Para usar o gateway auto-hospedado nesse modo, habilite também a conectividade privada com o ponto de extremidade de configuração do gateway auto-hospedado.
Use o Gerenciamento de API no modo interno para:
- Torne as APIs hospedadas no seu datacenter privado seguras e acessíveis por terceiros externamente usando as conexões VPN do Azure ou o Azure ExpressRoute.
- Habilite cenários de nuvem híbrida expondo as APIs baseadas em nuvem e as APIs locais por meio de um gateway comum.
- Gerencie suas APIs hospedadas em várias localizações geográficas usando um único ponto de extremidade de gateway.
Para configurações específicas do modo externo, em que os pontos de extremidade de Gerenciamento de API são acessíveis da Internet pública e os serviços de back-end estão localizados na rede, consulte Implantar sua instância de Gerenciamento de API do Azure em uma rede virtual – modo externo.
Observação
Recomendamos que você use o módulo Az PowerShell do Azure para interagir com o Azure. Para começar, consulte Instalar o Azure PowerShell. Para saber como migrar para o módulo Az PowerShell, confira Migrar o Azure PowerShell do AzureRM para o Az.
Pré-requisitos
Revise os requisitos de recursos de rede para injeção do Gerenciamento de API em uma rede virtual antes de começar.
Alguns pré-requisitos são diferentes, dependendo da versão (stv2
ou stv1
) da stv2
hospedando a instância do Gerenciamento de API.
Dica
Quando você usa o portal para criar ou atualizar a conexão de rede de uma instância existente do Gerenciamento de API, a instância é hospedada na plataforma de computação stv2
.
- Uma instância de Gerenciamento de API. Para obter mais informações, consulte Criar uma instância do Gerenciamento de API do Azure.
Uma rede virtual e a sub-rede na mesma região e assinatura da instância do Gerenciamento de API.
- A sub-rede usada para se conectar à instância de gerenciamento de API pode conter outros tipos de recursos do Azure.
- A sub-rede não deve ter nenhuma delegação habilitada. A configuração Delegar sub-rede a um serviço para a sub-rede deve ser definida como Nenhuma.
Um grupo de segurança de rede anexado à sub-rede acima. Um NSG (grupo de segurança de rede) é necessário para permitir explicitamente a conectividade de entrada, pois o balanceador de carga usado internamente pelo Gerenciamento de API é seguro por padrão e rejeita todo o tráfego de entrada. Para uma configuração específica, consulte Configurar regras NSG, abaixo neste artigo.
Para determinados cenários, habilite pontos de extremidade de serviço na sub-rede para serviços dependentes, como o Armazenamento do Microsoft Azure ou o SQL do Azure. Para obter mais informações, consulte Forçar o tráfego de túnel para o firewall local usando o ExpressRoute ou o dispositivo virtual de rede posteriormente neste artigo.
(Opcional) Um endereço IPv4 público de SKU Padrão.
Importante
- A partir de maio de 2024, um recurso de endereço IP público não é mais necessário ao implantar (injetar) uma instância de Gerenciamento de API em uma VNet no modo interno ou migrar a configuração de VNet interna para uma nova sub-rede. No modo de VNet externa, especificar um endereço IP público é opcional; se você não fornecer um, um endereço IP público gerenciado pelo Azure será configurado automaticamente e usado para tráfego de API de runtime. Forneça apenas o endereço IP público se você quiser possuir e controlar o endereço IP público usado para comunicação de entrada ou de saída para a Internet.
Se fornecido, o endereço IP deve estar na mesma região e assinatura que a instância de Gerenciamento de API e a rede virtual.
Ao criar um recurso de endereço IP público, lembre-se de atribuir um rótulo de nome DNS a ele. Em geral, você deve usar o mesmo nome DNS que sua instância de Gerenciamento de API. Se você alterá-la, reimplante sua instância para que o novo rótulo DNS seja aplicado.
Para obter o melhor desempenho de rede, é recomendável usar a Preferência padrão de roteamento: Rede da Microsoft.
Ao criar um endereço IP público em uma região onde você planeja habilitar a redundância de zona para sua instância de Gerenciamento de API, defina a configuração com redundância de zona.
O valor do endereço IP é atribuído como o endereço IPv4 público virtual da instância de gerenciamento de API nessa região.
Para implementações de Gerenciamento de API em várias regiões, configure os recursos da rede virtual separadamente para cada local.
Habilitar conexão de VNET
Habilitar a conectividade VNet usando o portal do Azure (plataforma stv2
)
Vá para o portal do Azure para encontrar sua instância de gerenciamento de API. Procure e selecione serviços de gerenciamento de API.
Escolha sua instância de gerenciamento de API.
Selecione Rede>Rede virtual.
Escolha o tipo de acesso Interno.
Na lista de localizações (regiões) em que o serviço de Gerenciamento de API é provisionado:
- Escolha um Local.
- Selecionar Rede virtual e Sub-rede.
- A lista de VNets é preenchida com as VNets do Resource Manager disponíveis em suas assinaturas do Azure e definidas na região que você está configurando.
Escolha Aplicar. A página Rede virtual da instância de Gerenciamento de API é atualizada com suas novas opções de VNet e sub-rede.
Continue definindo as configurações de VNet para os locais restantes da instância de Gerenciamento de API.
Na barra de navegação superior, selecione Salvar.
A atualização da instância do Gerenciamento de API pode levar de 15 a 45 minutos. A camada do desenvolvedor tem tempo de inatividade durante o processo. Os SKUs Básico e superior não têm tempo de inatividade durante o processo.
Depois que a implantação for bem-sucedida, você deverá ver o endereço IP virtual privado e o endereço IP virtual público do serviço de Gerenciamento de API na folha Visão geral. Para obter mais informações sobre os endereços IP, confira Roteamento neste artigo.
Observação
Como a URL do gateway não está registrada no DNS público, o console de teste disponível no portal do Azure não funcionará para um serviço implantado na VNet Interna. Em vez disso, use o console de teste fornecido no Portal do desenvolvedor.
Habilitar a conectividade usando um modelo do Resource Manager (platform stv2
)
Modelo do Azure Resource Manager (versão da API 2021-08-01)
Habilitar a conectividade usando cmdlets do Azure PowerShell (plataforma stv1
)
Criar ou atualizar uma instância do Gerenciamento de API em uma VNET.
Configurar regras de NSG
Configure regras de rede personalizadas na sub-rede de gerenciamento de API para filtrar o tráfego de e para a instância de gerenciamento de API. Recomendamos as regras de NSG mínimas a seguir para garantir a operação adequada e o acesso à sua instância. Examine seu ambiente cuidadosamente para determinar mais regras que podem ser necessárias.
Importante
Dependendo do uso do cache e de outros recursos, talvez seja necessário configurar regras de NSG adicionais além das regras mínimas na tabela a seguir. Para obter configurações detalhadas, consultereferência de configuração de rede virtual.
- Para a maioria dos cenários, use asmarcas de serviço indicadas em vez de endereços IP de serviço para especificar fontes de rede e destinos.
- Defina a prioridade dessas regras como maior do que as regras padrão.
Direção | Marca de serviço de origem | Intervalos de portas de origem | Marca de serviço de destino | Intervalos de portas de destino | Protocolo | Ação | Finalidade | Tipo de VNet |
---|---|---|---|---|---|---|---|---|
Entrada | Internet | * | VirtualNetwork | [80], 443 | TCP | Allow | Comunicação do cliente com o Gerenciamento de API | Apenas externo |
Entrada | ApiManagement | * | VirtualNetwork | 3443 | TCP | Allow | Ponto de extremidade de gerenciamento para o Portal do Azure e o Powershell | Interno e externo |
Entrada | AzureLoadBalancer | * | Rede Virtual | 6390 | TCP | Allow | Balanceador de carga de infraestrutura do Azure | Interno e externo |
Entrada | AzureTrafficManager | * | VirtualNetwork | 443 | TCP | Allow | Roteamento do Gerenciador de Tráfego do Azure para implantação em várias regiões | Apenas externo |
Saída | VirtualNetwork | * | Armazenamento | 443 | TCP | Allow | Dependência do Armazenamento do Microsoft Azure para a funcionalidade principal do serviço | Interno e externo |
Saída | VirtualNetwork | * | SQL | 1433 | TCP | Allow | Acesso aos pontos de extremidade do SQL do Azure para a funcionalidade principal do serviço | Interno e externo |
Saída | VirtualNetwork | * | AzureKeyVault | 443 | TCP | Allow | Acesso ao Azure Key Vault para funcionalidade principal do serviço | Interno e externo |
Saída | VirtualNetwork | * | Azure Monitor | 1886, 443 | TCP | Allow | Publicar logs e métricas de diagnóstico, integridade de recursos e Application Insights | Interno e externo |
Configuração de DNS
No modo de VNet interna, você precisa gerenciar seu DNS para habilitar o acesso de entrada aos pontos de extremidade de Gerenciamento de API.
Recomendações:
- Configurar uma zona privada DNS do Azure.
- Vincular a zona privada DNS do Azure à VNet na qual você implantou o serviço de Gerenciamento de API.
Saiba como configurar uma zona privada no DNS do Azure.
Observação
O serviço de Gerenciamento de API não escuta as solicitações nos endereços IP. Ele só responde às solicitações para o nome de host configurado em seus pontos de extremidade. Esses pontos de extremidade incluem:
- Gateway de API
- O Portal do Azure
- O portal do desenvolvedor
- Ponto de extremidade de gerenciamento direto
- Git
Acesso em nomes de host padrão
Ao criar um serviço de Gerenciamento de API (contosointernalvnet
, por exemplo), os seguintes pontos de extremidade são configurados por padrão:
Ponto de extremidade | Configuração de ponto de extremidade |
---|---|
Gateway de API | contosointernalvnet.azure-api.net |
Portal do desenvolvedor | contosointernalvnet.portal.azure-api.net |
O novo portal do desenvolvedor | contosointernalvnet.developer.azure-api.net |
Ponto de extremidade de gerenciamento direto | contosointernalvnet.management.azure-api.net |
Git | contosointernalvnet.scm.azure-api.net |
Acessar em nomes de domínio personalizados
Se você não quiser acessar o serviço de Gerenciamento de API com os nomes de host padrão, configure nomes de domínio personalizados para todos os seus pontos de extremidade, conforme mostrado na imagem a seguir:
Configurar registros de DNS
Crie registros no servidor DNS para acessar os pontos de extremidade acessíveis de dentro de sua VNet. Mapeie os registros do ponto de extremidade para o endereço IP virtual privado do seu serviço.
Para fins de teste, você pode atualizar o arquivo de hosts em uma máquina virtual em uma sub-rede conectada à VNet na qual o Gerenciamento de API está implantado. Considerando que o endereço IP virtual privado do serviço seja 10.1.0.5, você pode mapear o arquivo de hosts conforme mostrado a seguir. O arquivo de mapeamento de hosts está em %SystemDrive%\drivers\etc\hosts
(Windows) ou /etc/hosts
(Linux, macOS).
Endereço IP virtual interno | Configuração de ponto de extremidade |
---|---|
10.1.0.5 | contosointernalvnet.azure-api.net |
10.1.0.5 | contosointernalvnet.portal.azure-api.net |
10.1.0.5 | contosointernalvnet.developer.azure-api.net |
10.1.0.5 | contosointernalvnet.management.azure-api.net |
10.1.0.5 | contosointernalvnet.scm.azure-api.net |
Então você pode acessar todos os pontos de extremidade de Gerenciamento de API da máquina virtual criada.
Roteiro
Os endereços IP virtuais a seguir são configurados para uma instância do Gerenciamento de API em uma rede virtual interna.
Endereço IP virtual | Descrição |
---|---|
Endereço IP virtual privado | Um endereço IP com balanceamento de carga no intervalo de sub-rede (DIP) da instância do Gerenciamento de API, no qual você possa acessar o gateway de API, o portal do desenvolvedor, o gerenciamento e os pontos de extremidade do Git. Registre esse endereço com os servidores DNS usados pela VNet. |
Endereço IP virtual público | Usado somente para o tráfego do painel de controle para o ponto de extremidade de gerenciamento na porta 3443. Pode ser bloqueado para a marca de serviço ApiManagement. |
Os endereços IP públicos e privados com balanceamento de carga podem ser encontrados na folha Visão geral do portal do Azure.
Para obter mais informações e considerações, consulte endereços IP do gerenciamento de API do Azure.
Endereços VIP e DIP
Os endereços DIP (IP Dinâmico) serão atribuídos a cada máquina virtual subjacente no serviço e usados para acessar os pontos de extremidade e recursos na VNet e em VNets emparelhadas. O endereço VIP (IP virtual público) do serviço de Gerenciamento de API será usado para acessar os recursos voltados para o público.
Se as listas de restrição de IP protegem recursos na VNet ou VNets emparelhadas, recomendamos especificar todo o intervalo para a sub-rede onde o serviço de Gerenciamento de API for implantado para conceder ou restringir acesso ao serviço.
Saiba mais sobre o tamanho de sub-rede recomendado.
Exemplo
Se você implantar uma unidade de capacidade do Gerenciamento de API na camada Premium em uma VNet interna, três endereços IP serão usados: um para o VIP privado e um para cada um dos DIPs de duas VMs. Se você escalar horizontalmente para quatro unidades, mais IPs serão consumidos para DIPs adicionais na sub-rede.
Se o ponto de extremidade de destino tiver apenas um conjunto fixo de DIPs na lista de permitidos, ocorrerão falhas de conexão se você adicionar novas unidades no futuro. Por esse motivo e como a sub-rede está inteiramente no seu controle, recomendamos adicionar toda a sub-rede no back-end à lista de permitidos.
Forçar o tráfego de túnel para o firewall local usando o ExpressRoute ou o dispositivo virtual de rede
Um túnel forçado permite redirecionar ou "forçar" todo o tráfego direcionado à Internet de sua sub-rede de volta para o local para inspeção e auditoria. Normalmente, você configura e define sua própria rota padrão (0.0.0.0/0
), forçando todo o tráfego da sub-rede do Gerenciamento de API a fluir por meio de um firewall local ou para um dispositivo virtual de rede. Esse fluxo de tráfego interrompe a conectividade com o Gerenciamento de API, uma vez que o tráfego de saída é bloqueado no local ou convertido por NAT para um conjunto irreconhecível de endereços que não funcionam mais com diversos pontos de extremidade do Azure. Você pode solucionar esse problema através dos seguintes métodos:
Habilite os pontos de extremidade de serviço na sub-rede em que o serviço de Gerenciamento de API está implantado para:
- SQL do Azure (necessário somente na região primária se o serviço de Gerenciamento de API estiver implantado em várias regiões)
- Armazenamento do Azure
- Hubs de eventos do Azure
- Azure Key Vault (necessário quando o Gerenciamento de API é implantado na plataforma
stv2
)
Ao habilitar pontos de extremidade diretamente da sub-rede pelo Gerenciamento de API para esses serviços, é possível usar a rede de backbone do Microsoft Azure, fornecendo roteamento ideal para o tráfego do serviço. No caso de pontos de extremidade de serviço com um Gerenciamento de API por túnel forçado, o tráfego para os serviços anteriores do Azure não é forçado por túnel. No entanto, o outro tráfego de dependência do serviço de Gerenciamento de API permanece em túnel forçado. Verifique se o firewall ou a solução de virtualização não bloqueia esse tráfego ou se o serviço de Gerenciamento de API pode não funcionar corretamente.
Observação
É altamente recomendável habilitar pontos de extremidade de serviço diretamente da sub-rede do Gerenciamento de API para serviços dependentes, como o SQL do Azure e o Armazenamento do Azure que dão suporte a eles. No entanto, algumas organizações podem ter requisitos para forçar o túnel de todo o tráfego da sub-rede do Gerenciamento de API. Nesse caso, configure o seu firewall ou dispositivo virtual para permitir esse tráfego. Você precisará permitir o intervalo de endereços IP completo de cada serviço dependente e manter essa configuração atualizada quando a infraestrutura do Azure for alterada. Seu serviço Gerenciamento de API também pode ter latência ou tempos limite inesperados devido ao túnel de força desse tráfego de rede.
Todo o tráfego do painel de controle da Internet para o ponto de extremidade de gerenciamento de seu serviço de Gerenciamento de API é roteado por um conjunto específico de IPs de entrada, hospedados pela marca de serviço ApiManagement. Quando o tráfego for feito por túnel forçado, as respostas não serão mapeadas simetricamente de volta a esses IPs de origem de entrada e a conectividade com o ponto de extremidade de gerenciamento será perdida. Para superar essa limitação, configure uma UDR (rota definida pelo usuário) para a marca de serviço ApiManagement com o tipo de próximo salto definido como "Internet" para direcionar o tráfego de volta para o Azure.
Observação
Permitir que o tráfego de gerenciamento do Gerenciamento de API ignore um firewall local ou uma solução de virtualização de rede não é considerado um risco de segurança significativo. A configuração recomendada para sua sub-rede de Gerenciamento de API permite o tráfego de gerenciamento de entrada na porta 3443 somente do conjunto de endereços IP do Azure abrangidos pela marca de serviço ApiManagement. A configuração de UDR recomendada é apenas para o caminho de retorno desse tráfego do Azure.
No (Modo VNet externo) o tráfego do plano de dados para clientes que tentam acessar o gateway de Gerenciamento de API e o portal do desenvolvedor da Internet também será descartado por padrão devido ao roteamento assimétrico introduzido pelo túnel forçado. Para cada cliente que requer acesso, configure uma UDR explícita com o tipo de próximo salto "Internet" para ignorar o firewall ou o dispositivo de rede virtual.
Para outras dependências do serviço de Gerenciamento de API em túnel forçado, resolva o nome do host e comunique-se com o ponto de extremidade. Estão incluídos:
- Monitoramento de integridade e métricas
- Diagnósticos do portal do Azure
- Retransmissão de SMTP
- CAPTCHA do portal do desenvolvedor
- Servidor de KMS do Azure
Para obter mais informações, consulte Referência de configuração de rede virtual.
Problemas comuns de configuração de rede
Esta seção foi movida. Confira configuração de rede virtual.
Solução de problemas
Implantação inicial malsucedida do serviço de Gerenciamento de API em uma sub-rede
- Implante uma máquina virtual na mesma sub-rede.
- Conecte na máquina virtual e valide a conectividade com um dos seguintes recursos em sua assinatura do Azure:
- Azure Storage Blob
- Banco de Dados SQL do Azure
- Tabela de armazenamento do Azure
- Azure Key Vault (para uma instância de gerenciamento de API hospedada na
stv2
plataforma)
Importante
Depois de validar a conectividade, remova todos os recursos da sub-rede antes de implantar o Gerenciamento de API nela (necessário quando o API Management está hospedado na plataforma stv1
).
Verificar status de rede
Depois de implantar o Gerenciamento de API na sub-rede, use o portal para verificar a conectividade de sua instância com dependências, como o Armazenamento do Azure.
No portal, no menu à esquerda, em Implantação e infraestrutura, selecione Rede>Status de rede.
Filtrar | Descrição |
---|---|
Obrigatório | Selecione para revisar a conectividade de serviços do Azure necessária para o Gerenciamento de API. A falha indica que a instância não é capaz de realizar operações centrais para gerenciar APIs. |
Opcional | Selecione para revisar a conectividade de serviços opcionais. A falha apenas indica que a funcionalidade específica não funcionará (por exemplo, SMTP). A falha pode levar à degradação no uso e no monitoramento da instância de Gerenciamento de API e no fornecimento do SLA comprometido. |
Para ajudar a solucionar problemas de conectividade, selecione:
Métricas: para examinar as métricas de status de conectividade de rede
Diagnosticar: para executar um verificador de rede virtual durante um período de tempo especificado
Para resolver problemas de conectividade, reveja as configurações de rede e corrija as configurações de rede necessárias.
Atualizações incrementais
Ao fazer alterações em sua rede, consulte a API NetworkStatus para verificar se o serviço de Gerenciamento de API não perdeu o acesso a recursos críticos. O status de conectividade deve ser atualizado a cada 15 minutos.
Para aplicar uma alteração de configuração de rede à instância de gerenciamento de API usando o portal:
- No menu à esquerda de sua instância, em Implementação e infraestrutura, selecione Rede>Rede virtual.
- Selecione Aplicar configuração de rede.
Links de navegação de recurso
Uma instância de APIM hospedada na stv1
plataforma de computação, quando implantada em uma sub-rede da VNet do Resource Manager, reserva a sub-rede criando um link de navegação de recurso. Se a sub-rede já contiver um recurso de outro provedor, a implantação falhará. Da mesma forma, ao excluir um serviço de Gerenciamento de API ou movê-lo para uma sub-rede diferente, o link de navegação do recurso é removido.
Desafios encontrados na reatribuição da instância do APIM para a sub-rede anterior
- Bloqueio da VNet — Ao mover uma instância do Gerenciamento de API de volta para sua sub-rede original, a reatribuição imediata pode não ser possível devido ao bloqueio da VNet, que leva até uma hora para ser removido. Se a sub-rede original tiver outros serviços
stv1
de Gerenciamento de API baseados em plataforma (baseados em serviço de nuvem), será necessário excluí-los e aguardar para implantar um serviçostv2
baseado em plataforma na mesma sub-rede. - Bloqueio de grupo de recursos - Outro cenário a ser considerado é a presença de um bloqueio de escopo no nível do grupo de recursos ou superior, dificultando o processo de Exclusão do Link de Navegação de Recursos. Para resolver isso, remova o bloqueio de escopo e espere de quatro a seis horas para que o serviço APIM desvincule-se da sub-rede original antes da remoção do bloqueio, habilitando a implantação na sub-rede desejada.
Solucionar problemas de conexão com o Microsoft Graph de dentro de uma VNet
A conectividade de rede com o Microsoft Graph é necessária para os recursos que incluem a entrada do usuário no portal do desenvolvedor usando o provedor de identidade do Microsoft Entra.
Para solucionar problemas de conectividade com o Microsoft Graph de dentro de uma VNet:
Certifique-se de que o NSG e outras regras de rede estão configuradas para conectividade de saída da sua instância de Gerenciamento de API para o Microsoft Graph (usando a marca de serviço AzureActiveDirectory).
Verifique se a resolução de DNS e o acesso à rede para
graph.microsoft.com
de dentro da VNet. Por exemplo, provisione uma nova VM dentro da VNet, conecte-se a ela e tenteGET https://graph.microsoft.com/v1.0/$metadata
de um navegador ou usando cURL, PowerShell ou outras ferramentas.
Próximas etapas
Saiba mais sobre: