Tutorial: Provisionar a criação e monitorar as condições de trabalho com a Versão Prévia dos Gêmeos Digitais do Azure
Importante
Uma nova versão do serviço dos Gêmeos Digitais do Azure foi lançada. À luz dos recursos expandidos do novo serviço, o serviço original dos Gêmeos Digitais do Azure (descrito neste conjunto de documentação) foi desativado.
Para exibir a documentação do novo serviço, visite a documentação ativa dos Gêmeos Digitais do Azure.
Este tutorial demonstra como usar a Versão prévia dos Gêmeos Digitais do Azure para monitorar as condições de temperatura e o nível de conforto desejados em seus espaços. Depois de configurar o prédio de exemplo, provisione o prédio e execute funções personalizadas em seus dados de sensor usando as etapas deste tutorial.
Neste tutorial, você aprenderá como:
- Definir condições a serem monitoradas.
- Criar uma UDF (função definida pelo usuário).
- Simular dados de sensor.
- Obter resultados de uma função definida pelo usuário.
Pré-requisitos
Este tutorial pressupõe que você já tenha concluído a configuração dos Gêmeos Digitais do Azure. Antes de prosseguir, verifique se você tem:
- Uma conta do Azure.
- Uma instância de Gêmeos Digitais em execução.
- Os exemplos de C# dos Gêmeos Digitais baixados e extraídos do seu computador de trabalho.
-
SDK do .NET Core versão 2.1.403 ou posterior no computador de desenvolvimento para executar a amostra. Execute
dotnet --version
para verificar se a versão instalada é a correta. - Use o Visual Studio Code para explorar o código de exemplo.
Dica
Use um nome de instância dos Gêmeos Digitais exclusivo quando estiver provisionando uma nova instância.
Definir condições a serem monitoradas
Você pode definir um conjunto de condições específicas a monitorar nos dados de dispositivo ou sensor, chamadas correspondências. Em seguida, você pode definir funções chamadas funções definidas pelo usuário. As funções definidas pelo usuário executam a lógica personalizada nos dados oriundos de seus dispositivos e espaços quando as condições especificadas pelas correspondências são atendidas. Para obter mais informações, leia Processamento de dados e funções definidas pelo usuário.
No projeto de exemplo occupancy-quickstart, abra o arquivo src\actions\provisionSample.yaml no Visual Studio Code. Observe a seção que começa com o tipo de matchers. Cada entrada nesse tipo cria uma correspondência com o Nome especificado. A correspondência monitorará um sensor do tipo dataTypeValue. Observe como ela se relaciona com o espaço chamado Sala de Foco A1, que tem um nó devices contendo alguns sensores. Para provisionar uma correspondência que vai controlar um desses sensores, seu dataTypeValue deverá corresponder ao dataType do sensor.
Adicione a seguinte correspondência abaixo das correspondências existentes. Verifique se as chaves estão alinhadas e se os espaços não foram substituídos por guias. Essas linhas também estão presentes no arquivo provisionSample.yaml como linhas comentadas. Você pode remover os comentários removendo o caractere #
na frente de cada linha.
- name: Matcher Temperature
dataTypeValue: Temperature
Essa correspondência controlará o sensor SAMPLE_SENSOR_TEMPERATURE
que você adicionou no primeiro tutorial.
Criar uma função definida pelo usuário
Você pode usar as funções definidas pelo usuário para personalizar o processamento de seus dados de sensor. Elas são um código JavaScript personalizado que pode ser executado dentro da instância dos Gêmeos Digitais do Azure quando ocorrem condições específicas descritas pelas correspondências. Você pode criar correspondências e funções definidas pelo usuário para cada sensor que deseja monitorar. Para obter mais informações, leia Processamento de dados e funções definidas pelo usuário.
No arquivo de exemplo provisionSample.yaml, procure uma seção que começa com o tipo userdefinedfunctions. Esta seção provisiona uma função definida pelo usuário com determinado Nome. Essa UDF atua na lista de correspondências em matcherNames. Observe como você pode fornecer seu próprio arquivo JavaScript para a UDF como o script.
Além disso, observe a seção denominada roleassignments. Ela atribui a função de Administrador de Espaço à função definida pelo usuário. Essa função permite que ela acesse os eventos que vêm de um dos espaços provisionados.
Configure a UDF para incluir o correspondente de temperatura adicionando ou descompactando a seguinte linha no
matcherNames
nó do arquivo provisionSample.yaml :- Matcher Temperature
Abra o arquivo src\actions\userDefinedFunctions\availability.js em seu editor. Esse é o arquivo referenciado no elemento script de provisionSample.yaml. A função definida pelo usuário nesse arquivo procura condições quando nenhum movimento é detectado na sala e quando os níveis de dióxido de carbono estão abaixo de 1.000 ppm.
Modifique o arquivo JavaScript para monitorar a temperatura e outras condições. Adicione as linhas de código a seguir para procurar condições quando nenhum movimento é detectado na sala, os níveis de dióxido de carbono estão abaixo de 1.000 ppm e a temperatura está abaixo de 25 graus Celsius.
Observação
Esta seção modifica o arquivo src\actions\userDefinedFunctions\availability.js para que você possa saber com detalhes como escrever uma função definida pelo usuário. No entanto, você pode optar por usar diretamente o arquivo src\actions\userDefinedFunctions\availabilityForTutorial.js em sua configuração. Esse arquivo tem todas as alterações exigidas por este tutorial. Se você usar esse arquivo, não deixe de usar o nome de arquivo correto para a chave script em src\actions\provisionSample.yaml.
a. Na parte superior do arquivo, adicione as seguintes linhas para a temperatura abaixo do comentário
// Add your sensor type here
:var temperatureType = "Temperature"; var temperatureThreshold = 78;
b. Adicione as seguintes linhas depois da instrução que define
var motionSensor
, abaixo do comentário// Add your sensor variable here
:var temperatureSensor = otherSensors.find(function(element) { return element.DataType === temperatureType; });
c. Adicione a seguinte linha depois da instrução que define
var carbonDioxideValue
, abaixo do comentário// Add your sensor latest value here
:var temperatureValue = getFloatValue(temperatureSensor.Value().Value);
d. Remova as seguintes linhas de código abaixo do comentário
// Modify this line to monitor your sensor value
:if(carbonDioxideValue === null || motionValue === null) { sendNotification(telemetry.SensorId, "Sensor", "Error: Carbon dioxide or motion are null, returning"); return; }
Substitua-as pelas seguintes linhas:
if(carbonDioxideValue === null || motionValue === null || temperatureValue === null){ sendNotification(telemetry.SensorId, "Sensor", "Error: Carbon dioxide, motion, or temperature are null, returning"); return; }
e. Remova as seguintes linhas de código abaixo do comentário
// Modify these lines as per your sensor
:var availableFresh = "Room is available and air is fresh"; var noAvailableOrFresh = "Room is not available or air quality is poor";
Substitua-as pelas seguintes linhas:
var alert = "Room with fresh air and comfortable temperature is available."; var noAlert = "Either room is occupied, or working conditions are not right.";
f. Remova o seguinte bloco de código if-else após o comentário
// Modify this code block for your sensor
:// If carbonDioxide less than threshold and no presence in the room => log, notify and set parent space computed value if(carbonDioxideValue < carbonDioxideThreshold && !presence) { log(`${availableFresh}. Carbon Dioxide: ${carbonDioxideValue}. Presence: ${presence}.`); setSpaceValue(parentSpace.Id, spaceAvailFresh, availableFresh); } else { log(`${noAvailableOrFresh}. Carbon Dioxide: ${carbonDioxideValue}. Presence: ${presence}.`); setSpaceValue(parentSpace.Id, spaceAvailFresh, noAvailableOrFresh); // Set up custom notification for poor air quality parentSpace.Notify(JSON.stringify(noAvailableOrFresh)); }
E substitua-o pelo bloco if-else a seguir:
// If sensor values are within range and room is available if(carbonDioxideValue < carbonDioxideThreshold && temperatureValue < temperatureThreshold && !presence) { log(`${alert}. Carbon Dioxide: ${carbonDioxideValue}. Temperature: ${temperatureValue}. Presence: ${presence}.`); // log, notify and set parent space computed value setSpaceValue(parentSpace.Id, spaceAvailFresh, alert); // Set up notification for this alert parentSpace.Notify(JSON.stringify(alert)); } else { log(`${noAlert}. Carbon Dioxide: ${carbonDioxideValue}. Temperature: ${temperatureValue}. Presence: ${presence}.`); // log, notify and set parent space computed value setSpaceValue(parentSpace.Id, spaceAvailFresh, noAlert); }
O UDF modificado irá procurar uma condição em que uma sala se torna disponível e tem o dióxido de carbono e a temperatura dentro dos limites toleráveis. Ele irá gerar uma notificação com a instrução
parentSpace.Notify(JSON.stringify(alert));
quando essa condição for atendida. Ela definirá o valor do espaço monitorado independentemente de a condição ser atendida, com a mensagem correspondente.g. Salve o arquivo.
Abra a janela de comando e navegue até a pasta occupancy-quickstart\src. Execute o seguinte comando para provisionar o grafo de inteligência espacial e a função definida pelo usuário:
dotnet run ProvisionSample
Importante
Para impedir o acesso não autorizado à API de Gerenciamento dos Gêmeos Digitais, o aplicativo occupancy-quickstart exige que você entre com suas credenciais de conta do Azure. Ele salva suas credenciais por um breve período, para que você não precise entrar toda vez que for executá-lo. Quando o programa é executado pela primeira vez e quando as credenciais salvas expiram, ele encaminha você para uma página de entrada e fornece um código específico da sessão para inserir nessa página. Siga os prompts para entrar com sua conta do Azure.
Depois que a conta é autenticada, o aplicativo começa a criação de um grafo especial de exemplo conforme configurado em provisionSample.yaml. Aguarde até a conclusão do provisionamento. Isso levará alguns minutos. Depois disso, observe as mensagens na janela de comando e observe como o grafo espacial é criado. Observe como o aplicativo cria um hub IoT no nó raiz ou em
Venue
.Da saída na janela de comando, copie o valor da
ConnectionString
, na seçãoDevices
, para a área de transferência. Você precisará desse valor para simular a conexão do dispositivo na próxima seção.
Dica
Se você receber uma mensagem de erro semelhante a "A operação de E/S foi anulada devido a uma saída de thread ou solicitação do aplicativo" no meio do provisionamento, tente executar o comando novamente. Isso pode acontecer quando o cliente HTTP atingir o tempo limite devido a um problema de rede.
Simular dados de sensor
Nesta seção, você usará o projeto chamado device-connectivity no exemplo. Você vai simular dados de sensor para detectar movimento, temperatura e dióxido de carbono. Esse projeto gera valores aleatórios para os sensores e os envia ao hub IoT usando a cadeia de conexão do dispositivo.
Em uma janela de comando separada, vá para o exemplo dos Gêmeos Digitais do Azure e, em seguida para a pasta device-connectivity.
Execute esse comando para ter certeza de que as dependências do projeto estão corretas:
dotnet restore
Abra o arquivo appsettings.json no editor e edite os seguintes valores:
a. DeviceConnectionString: atribua o valor de
ConnectionString
na janela de saída da seção anterior. Copie essa cadeia de caracteres na totalidade, entre aspas, para que o simulador possa se conectar corretamente ao hub IoT.b. HardwareId na matriz Sensores : como você está simulando eventos de sensores provisionados para a instância dos Gêmeos Digitais do Azure, a ID de hardware e os nomes dos sensores neste arquivo devem corresponder ao
sensors
nó do arquivo provisionSample.yaml .Adicione uma nova entrada para o sensor de temperatura. O nó Sensores em appsettings.json deve ser semelhante ao seguinte:
"Sensors": [{ "DataType": "Motion", "HardwareId": "SAMPLE_SENSOR_MOTION" },{ "DataType": "CarbonDioxide", "HardwareId": "SAMPLE_SENSOR_CARBONDIOXIDE" },{ "DataType": "Temperature", "HardwareId": "SAMPLE_SENSOR_TEMPERATURE" }]
Execute este comando para iniciar a simulação de eventos de dispositivo para temperatura, movimento e dióxido de carbono:
dotnet run
Observação
Já que o exemplo de simulação não se comunica diretamente com a instância dos Gêmeos Digitais, ele não requer autenticação.
Obter resultados da função definida pelo usuário
A função definida pelo usuário é executada sempre que sua instância recebe dados de sensor e de dispositivo. Essa seção consulta sua instância dos Gêmeos Digitais do Azure para obter os resultados da função definida pelo usuário. Você será notificado quase em tempo real, quando uma sala estiver disponível, se o ar estará fresco e se a temperatura estará correta.
Abra a janela de comando que você usou para provisionar o exemplo, ou uma nova janela de comando, e vá para a pasta occupancy-quickstart\src do exemplo novamente.
Execute o seguinte comando e entre quando solicitado:
dotnet run GetAvailableAndFreshSpaces
A janela de saída mostra como a função definida pelo usuário é executada e intercepta eventos de simulação do dispositivo.
Se a condição monitorada for atendida, a função definida pelo usuário definirá o valor do espaço com a mensagem relevante, como vimos anteriormente. A função GetAvailableAndFreshSpaces
imprime a mensagem no console.
Limpar os recursos
Se você quiser parar de explorar os Gêmeos Digitais do Azure neste momento, fique à vontade para excluir recursos criados neste tutorial:
No menu à esquerda no portal do Azure, escolha Todos os recursos, marque o grupo de recursos dos Gêmeos Digitais e a opção Excluir.
Dica
Se você teve problemas para excluir sua instância de Gêmeos Digitais, lançamos uma atualização de serviço com a correção. Tente novamente excluir a instância.
Se necessário, exclua os aplicativos de exemplo em seu computador de trabalho.
Próximas etapas
Agora que você provisionou os espaços e criou uma estrutura para disparar notificações personalizadas, vá para um dos tutoriais abaixo: