Partilhar via


Configurar um dispositivo IoT Edge para comunicar através de um servidor proxy

Aplica-se a: ícone sim IoT Edge 1.1

Importante

A data de fim do suporte do IoT Edge 1.1 foi 13 de dezembro de 2022. Consulte o Ciclo de Vida de Produtos da Microsoft para obter informações sobre como é suportado este produto, serviço, tecnologia ou API. Para obter mais informações sobre como atualizar para a versão mais recente do IoT Edge, consulte Atualizar o IoT Edge.

Os dispositivos IoT Edge enviam solicitações HTTPS para se comunicar com o Hub IoT. Se o dispositivo estiver conectado a uma rede que usa um servidor proxy, você precisará configurar o tempo de execução do IoT Edge para se comunicar através do servidor. Os servidores proxy também podem afetar módulos individuais do IoT Edge se fizerem solicitações HTTP ou HTTPS que não são roteadas por meio do hub IoT Edge.

Este artigo descreve as quatro etapas a seguir para configurar e gerenciar um dispositivo IoT Edge atrás de um servidor proxy:

  1. Instalar o tempo de execução do IoT Edge no seu dispositivo

    Os scripts de instalação do IoT Edge extraem pacotes e arquivos da Internet, portanto, seu dispositivo precisa se comunicar por meio do servidor proxy para fazer essas solicitações. Para dispositivos Windows, o script de instalação também fornece uma opção de instalação offline.

    Esta etapa é um processo único para configurar o dispositivo IoT Edge quando você o configura pela primeira vez. As mesmas conexões também são necessárias quando você atualiza o tempo de execução do IoT Edge.

  2. Configurar o IoT Edge e o tempo de execução do contêiner em seu dispositivo

    O IoT Edge é responsável pelas comunicações com o Hub IoT. O tempo de execução do contêiner é responsável pelo gerenciamento do contêiner, portanto, se comunica com os registros de contêiner. Ambos os componentes precisam fazer solicitações da Web através do servidor proxy.

    Esta etapa é um processo único para configurar o dispositivo IoT Edge quando você o configura pela primeira vez.

  3. Configurar as propriedades do agente do IoT Edge no arquivo de configuração em seu dispositivo

    O daemon IoT Edge inicia o módulo edgeAgent inicialmente. Em seguida, o módulo edgeAgent recupera o manifesto de implantação do Hub IoT e inicia todos os outros módulos. Para que o agente do IoT Edge faça a conexão inicial com o Hub IoT, configure as variáveis de ambiente do módulo edgeAgent manualmente no próprio dispositivo. Após a conexão inicial, você pode configurar o módulo edgeAgent remotamente.

    Esta etapa é um processo único para configurar o dispositivo IoT Edge quando você o configura pela primeira vez.

  4. Para todas as implantações futuras de módulos, defina variáveis de ambiente para qualquer módulo que se comunique através do proxy

    Depois que seu dispositivo IoT Edge estiver configurado e conectado ao Hub IoT por meio do servidor proxy, você precisará manter a conexão em todas as implantações futuras de módulos.

    Esta etapa é um processo contínuo feito remotamente para que cada novo módulo ou atualização de implantação mantenha a capacidade do dispositivo de se comunicar através do servidor proxy.

Conheça o URL do seu proxy

Antes de começar qualquer uma das etapas neste artigo, você precisa saber sua URL de proxy.

As URLs de proxy têm o seguinte formato: protocol://proxy_host:proxy_port.

  • O protocolo é HTTP ou HTTPS. O daemon do Docker pode usar qualquer protocolo, dependendo das configurações do Registro do contêiner, mas o daemon do IoT Edge e os contêineres de tempo de execução devem sempre usar HTTP para se conectar ao proxy.

  • O proxy_host é um endereço para o servidor proxy. Se o servidor proxy exigir autenticação, você poderá fornecer suas credenciais como parte do host proxy com o seguinte formato: user:password@proxy_host.

  • A proxy_port é a porta de rede na qual o proxy responde ao tráfego de rede.

Instalar o IoT Edge através de um proxy

Quer o seu dispositivo IoT Edge seja executado em Windows ou Linux, tem de aceder aos pacotes de instalação através do servidor proxy. Dependendo do seu sistema operacional, siga as etapas para instalar o tempo de execução do IoT Edge por meio de um servidor proxy.

Dispositivos Linux

Se você estiver instalando o tempo de execução do IoT Edge em um dispositivo Linux, configure o gerenciador de pacotes para passar pelo servidor proxy para acessar o pacote de instalação. Por exemplo, configure o apt-get para usar um http-proxy. Depois que o gerenciador de pacotes estiver configurado, siga as instruções em Instalar o tempo de execução do Azure IoT Edge como de costume.

Dispositivos Windows usando IoT Edge para Linux no Windows

Se você estiver instalando o tempo de execução do IoT Edge usando o IoT Edge para Linux no Windows, o IoT Edge será instalado por padrão em sua máquina virtual Linux. Não são necessárias etapas adicionais de instalação ou atualização.

Dispositivos Windows usando contêineres do Windows

Se você estiver instalando o tempo de execução do IoT Edge em um dispositivo Windows, precisará passar pelo servidor proxy duas vezes. A primeira conexão baixa o arquivo de script do instalador e a segunda conexão é durante a instalação para baixar os componentes necessários. Você pode configurar informações de proxy nas configurações do Windows ou incluir suas informações de proxy diretamente nos comandos do PowerShell.

As etapas a seguir demonstram um exemplo de uma instalação do Windows usando o -proxy argumento:

  1. O comando Invoke-WebRequest precisa de informações de proxy para acessar o script do instalador. Em seguida, o comando Deploy-IoTEdge precisa das informações de proxy para baixar os arquivos de instalação.

    . {Invoke-WebRequest -proxy <proxy URL> -useb aka.ms/iotedge-win} | Invoke-Expression; Deploy-IoTEdge -proxy <proxy URL>
    
  2. O comando Initialize-IoTEdge não precisa passar pelo servidor proxy, portanto, a segunda etapa requer apenas informações de proxy para Invoke-WebRequest.

    . {Invoke-WebRequest -proxy <proxy URL> -useb aka.ms/iotedge-win} | Invoke-Expression; Initialize-IoTEdge
    

Se você tiver credenciais complicadas para o servidor proxy que não podem ser incluídas na URL, use o -ProxyCredential parâmetro em -InvokeWebRequestParameters. Por exemplo,

$proxyCredential = (Get-Credential).GetNetworkCredential()
. {Invoke-WebRequest -proxy <proxy URL> -ProxyCredential $proxyCredential -useb aka.ms/iotedge-win} | Invoke-Expression; `
Deploy-IoTEdge -InvokeWebRequestParameters @{ '-Proxy' = '<proxy URL>'; '-ProxyCredential' = $proxyCredential }

Para obter mais informações sobre parâmetros de proxy, consulte Invoke-WebRequest. Para obter mais informações sobre os parâmetros de instalação do Windows, consulte Scripts do PowerShell para IoT Edge no Windows.

Configurar o IoT Edge e o Moby

O IoT Edge depende de dois daemons em execução no dispositivo IoT Edge. O daemon Moby faz solicitações da Web para extrair imagens de contêiner de registros de contêiner. O daemon IoT Edge faz solicitações da Web para se comunicar com o Hub IoT.

Os daemons Moby e IoT Edge precisam ser configurados para usar o servidor proxy para funcionalidade contínua do dispositivo. Esta etapa ocorre no dispositivo IoT Edge durante a configuração inicial do dispositivo.

Daemon Moby

Como o Moby é construído no Docker, consulte a documentação do Docker para configurar o daemon Moby com variáveis de ambiente. A maioria dos registros de contêiner (incluindo o DockerHub e o Azure Container Registries) oferece suporte a solicitações HTTPS, portanto, o parâmetro que você deve definir é HTTPS_PROXY. Se você estiver extraindo imagens de um registro que não suporta TLS (Transport Layer Security), defina o parâmetro HTTP_PROXY .

Escolha o artigo que se aplica ao seu sistema operacional do dispositivo IoT Edge:

Daemon do IoT Edge

O daemon IoT Edge é configurado de maneira semelhante ao daemon Moby. Use as etapas a seguir para definir uma variável de ambiente para o serviço, com base no seu sistema operacional.

O daemon do IoT Edge sempre usa HTTPS para enviar solicitações ao Hub IoT.

Linux

Abra um editor no terminal para configurar o daemon do IoT Edge.

sudo systemctl edit iotedge

Insira o seguinte texto, substituindo a URL> do <proxy pelo endereço e porta do servidor proxy. Em seguida, salve e saia.

[Service]
Environment=https_proxy=<proxy URL>

Atualize o gerenciador de serviços para pegar a nova configuração do IoT Edge.

sudo systemctl daemon-reload

Reinicie o IoT Edge para que as alterações entrem em vigor.

sudo systemctl restart iotedge

Verifique se a variável de ambiente foi criada e se a nova configuração foi carregada.

systemctl show --property=Environment iotedge

Windows usando IoT Edge para Linux no Windows

Faça login no seu IoT Edge para Linux na máquina virtual Windows:

Connect-EflowVm

Siga as mesmas etapas da seção Linux acima para configurar o daemon do IoT Edge.

Windows usando contêineres do Windows

Abra uma janela do PowerShell como administrador e execute o seguinte comando para editar o registro com a nova variável de ambiente. Substitua <url> proxy pelo endereço e porta do servidor proxy.

reg add HKLM\SYSTEM\CurrentControlSet\Services\iotedge /v Environment /t REG_MULTI_SZ /d https_proxy=<proxy URL>

Reinicie o IoT Edge para que as alterações entrem em vigor.

Restart-Service iotedge

Configurar o agente IoT Edge

O agente IoT Edge é o primeiro módulo a ser iniciado em qualquer dispositivo IoT Edge. Ele foi iniciado pela primeira vez com base nas informações no arquivo de configuração do IoT Edge. Em seguida, o agente IoT Edge se conecta ao Hub IoT para recuperar manifestos de implantação, que declaram quais outros módulos devem ser implantados no dispositivo.

Esta etapa ocorre uma vez no dispositivo IoT Edge durante a configuração inicial do dispositivo.

  1. Abra o arquivo config.yaml em seu dispositivo IoT Edge. Em sistemas Linux, esse arquivo está localizado em /etc/iotedge/config.yaml. Em sistemas Windows, esse arquivo está localizado em C:\ProgramData\iotedge\config.yaml. O arquivo de configuração está protegido, portanto, você precisa de privilégios administrativos para acessá-lo. Em sistemas Linux, use o sudo comando antes de abrir o arquivo em seu editor de texto preferido. No Windows, abra um editor de texto como o Bloco de Notas como administrador e, em seguida, abra o ficheiro.

  2. No arquivo config.yaml, localize a seção de especificações do módulo do Agente de Borda. A definição do agente do IoT Edge inclui um parâmetro env onde você pode adicionar variáveis de ambiente.

  3. Remova os colchetes que são espaços reservados para o parâmetro env e adicione a nova variável em uma nova linha. Lembre-se de que os recuos no YAML são dois espaços.

    https_proxy: "<proxy URL>"
    
  4. O tempo de execução do IoT Edge usa AMQP por padrão para falar com o Hub IoT. Alguns servidores proxy bloqueiam portas AMQP. Se esse for o caso, você também precisará configurar o edgeAgent para usar AMQP sobre WebSocket. Adicione uma segunda variável de ambiente.

    UpstreamProtocol: "AmqpWs"
    

    Definição de edgeAgent com variáveis de ambiente

  5. Salve as alterações em config.yaml e feche o editor. Reinicie o IoT Edge para que as alterações entrem em vigor.

    • Linux e IoT Edge para Linux no Windows:

      sudo systemctl restart iotedge
      
    • Windows usando contêineres do Windows:

      Restart-Service iotedge
      
  1. Adicione o parâmetro https_proxy à seção de variáveis de ambiente e defina sua URL de proxy como seu valor.

    [agent]
    name = "edgeAgent"
    type = "docker"
    
    [agent.config]
    image = "mcr.microsoft.com/azureiotedge-agent:1.4"
    
    [agent.env]
    # "RuntimeLogLevel" = "debug"
    # "UpstreamProtocol" = "AmqpWs"
    "https_proxy" = "<proxy URL>"
    
  2. O tempo de execução do IoT Edge usa AMQP por padrão para falar com o Hub IoT. Alguns servidores proxy bloqueiam portas AMQP. Se esse for o caso, você também precisará configurar o edgeAgent para usar AMQP sobre WebSocket. Descomente o UpstreamProtocol parâmetro.

    [agent.config]
    image = "mcr.microsoft.com/azureiotedge-agent:1.4"
    
    [agent.env]
    # "RuntimeLogLevel" = "debug"
    "UpstreamProtocol" = "AmqpWs"
    "https_proxy" = "<proxy URL>"
    
  3. Salve as alterações e feche o editor. Aplique as alterações mais recentes.

    sudo iotedge config apply
    
  4. Verifique se as configurações de proxy são propagadas usando docker inspect edgeAgent a Env seção . Caso contrário, o contêiner deve ser recriado.

    sudo docker rm -f edgeAgent
    
  5. O tempo de execução do IoT Edge deve ser recriado edgeAgent em um minuto. Quando edgeAgent o contêiner estiver sendo executado novamente, docker inspect edgeAgent verifique se as configurações de proxy correspondem ao arquivo de configuração.

Configurar manifestos de implantação

Depois que o dispositivo IoT Edge estiver configurado para funcionar com o servidor proxy, você precisará continuar a declarar a variável de ambiente HTTPS_PROXY em manifestos de implantação futuros. Você pode editar manifestos de implantação usando o assistente do portal do Azure ou editando um arquivo JSON de manifesto de implantação.

Sempre configure os dois módulos de tempo de execução, edgeAgent e edgeHub, para se comunicarem através do servidor proxy para que possam manter uma conexão com o Hub IoT. Se você remover as informações de proxy do módulo edgeAgent, a única maneira de restabelecer a conexão é editando o arquivo de configuração no dispositivo, conforme descrito na seção anterior.

Além dos módulos edgeAgent e edgeHub, outros módulos podem precisar da configuração de proxy. Os módulos que precisam acessar recursos do Azure além do Hub IoT, como armazenamento de blob, devem ter a variável HTTPS_PROXY especificada no arquivo de manifesto de implantação.

O procedimento a seguir é aplicável durante toda a vida útil do dispositivo IoT Edge.

Portal do Azure

Quando você usa o assistente Definir módulos para criar implantações para dispositivos IoT Edge, cada módulo tem uma seção Variáveis de Ambiente onde você pode configurar conexões de servidor proxy.

Para configurar o agente do IoT Edge e os módulos do hub do IoT Edge, selecione Configurações de tempo de execução na primeira etapa do assistente.

Definir configurações avançadas do Edge Runtime

Adicione a variável de ambiente https_proxy às definições do agente do IoT Edge e do módulo do hub do IoT Edge. Se você incluiu a variável de ambiente UpstreamProtocol no arquivo de configuração em seu dispositivo IoT Edge, adicione-a também à definição do módulo do agente do IoT Edge.

Definir https_proxy variável de ambiente

Todos os outros módulos que você adiciona a um manifesto de implantação seguem o mesmo padrão.

Arquivos de manifesto de implantação JSON

Se você criar implantações para dispositivos IoT Edge usando os modelos no Visual Studio Code ou criando manualmente arquivos JSON, poderá adicionar as variáveis de ambiente diretamente a cada definição de módulo.

Use o seguinte formato JSON:

"env": {
    "https_proxy": {
        "value": "<proxy URL>"
    }
}

Com as variáveis de ambiente incluídas, sua definição de módulo deve se parecer com o seguinte exemplo de edgeHub:

"edgeHub": {
    "type": "docker",
    "settings": {
        "image": "mcr.microsoft.com/azureiotedge-hub:1.1",
        "createOptions": "{}"
    },
    "env": {
        "https_proxy": {
            "value": "http://proxy.example.com:3128"
        }
    },
    "status": "running",
    "restartPolicy": "always"
}

Se você incluiu a variável de ambiente UpstreamProtocol no arquivo confige.yaml em seu dispositivo IoT Edge, adicione-a também à definição do módulo do agente do IoT Edge.

"env": {
    "https_proxy": {
        "value": "<proxy URL>"
    },
    "UpstreamProtocol": {
        "value": "AmqpWs"
    }
}

Trabalhando com proxies de inspeção de tráfego

Alguns proxies como o Zscaler podem inspecionar tráfego encriptado por TLS. Durante a inspeção de tráfego TLS, o certificado retornado pelo proxy não é o certificado do servidor de destino, mas é o certificado assinado pelo próprio certificado raiz do proxy. Por padrão, o certificado desse proxy não é confiável pelos módulos do IoT Edge (incluindo edgeAgent e edgeHub) e o handshake TLS falha.

Para resolver isso, o certificado raiz do proxy precisa ser confiável pelo sistema operacional e pelos módulos do IoT Edge.

  1. Configure o certificado de proxy no armazenamento de certificados raiz confiável do seu sistema operacional host. Para obter mais informações sobre como instalar um certificado raiz, consulte Instalar a autoridade de certificação raiz no armazenamento de certificados do sistema operacional.

  2. Configure seu dispositivo IoT Edge para se comunicar por meio de um servidor proxy fazendo referência ao certificado no pacote de confiança. Para obter mais informações sobre como configurar o pacote de confiança, consulte Gerenciar CA raiz confiável (pacote de confiança).

Para configurar o suporte a proxy de inspeção de tráfego para contêineres não gerenciados pelo IoT Edge, entre em contato com seu provedor de proxy.

Nomes de domínio totalmente qualificados (FQDNs) de destinos com os quais o IoT Edge se comunica

Se o proxy tiver um firewall que exija que você permita a lista de permissões de todos os FQDNs para conectividade com a Internet, revise a lista em Permitir conexões de dispositivos IoT Edge para determinar quais FQDNs adicionar.

Próximos passos

Saiba mais sobre as funções do tempo de execução do IoT Edge.

Solucionar erros de instalação e configuração com problemas e resoluções comuns para o Azure IoT Edge