Обучение
Схема обучения
Use advance techniques in canvas apps to perform custom updates and optimization - Training
Use advance techniques in canvas apps to perform custom updates and optimization
Этот браузер больше не поддерживается.
Выполните обновление до Microsoft Edge, чтобы воспользоваться новейшими функциями, обновлениями для системы безопасности и технической поддержкой.
Примечание
Для доступа к этой странице требуется авторизация. Вы можете попробовать войти или изменить каталоги.
Для доступа к этой странице требуется авторизация. Вы можете попробовать изменить каталоги.
В этой статье описывается, как настроить экспорт данных для отправки данных в Azure Data Explorer.
Используйте эту возможность для непрерывного экспорта отфильтрованных и обогащенных данных IoT из приложения IoT Central. Экспорт данных позволяет отправлять изменения практически в реальном времени в другие компоненты облачного решения для получения когнитивных аналитических сведений по принципу "теплого пути", а также для хранения.
Например, доступны следующие возможности:
Совет
При включении экспорта данных вы получаете данные только начиная с этого момента. Чтобы сохранить больше исторических данных, включайте экспорт непрерывных данных заранее. Чтобы вручную экспортировать данные из времени отключения экспорта данных, см. инструкции по использованию REST API IoT Central для запроса устройств.
Примечание
В некоторых случаях для экспорта сообщений может потребоваться до 60 секунд. Это время измеряется, когда IoT Central получает сообщение от базового Центра Интернета вещей до момента доставки сообщения в конечную точку назначения.
Чтобы использовать функции экспорта данных, необходимо иметь разрешение на экспорт данных.
Вы можете использовать кластер Azure Data Explorer или пул Azure Synapse Data Explorer. Дополнительные сведения см. в статье "Что такое разница между Azure Synapse Data Explorer и Azure Data Explorer?".
IoT Central экспортирует данные практически в режиме реального времени в таблицу базы данных в кластере Azure Data Explorer. Данные находятся в тексте сообщения и имеют формат JSON, закодированный как UTF-8. Вы можете добавить преобразование в IoT Central для экспорта данных, соответствующих схеме таблицы.
Чтобы запросить экспортированные данные на портале Azure Data Explorer, перейдите к базе данных и выберите "Запрос".
В следующем видео показано, как экспортировать данные в Azure Data Explorer:
Назначения Azure Data Explorer позволяют настроить подключение к субъекту-службе или управляемому удостоверению.
Управляемые удостоверения более безопасны, так как:
IoT Central в настоящее время использует управляемые удостоверения, назначаемые системой.
При настройке управляемого удостоверения конфигурация включает область и роль:
В следующем видео содержатся дополнительные сведения о назначенных системой управляемых удостоверениях:
Внимание!
Чтобы экспортировать в хранилище BLOB-объектов, не используйте участника учетной записи хранения, как показано в видео. Вместо этого используйте роль участника данных BLOB-объектов хранилища.
В этой статье показано, как создать управляемое удостоверение с помощью Azure CLI. Вы также можете использовать портал Azure для создания управляемого удостоверения.
Если у вас нет существующей базы данных Azure Data Explorer для экспорта, выполните следующие действия. У вас есть два варианта создания базы данных Azure Data Explorer:
Чтобы настроить управляемое удостоверение, которое позволяет приложению IoT Central безопасно экспортировать данные в ресурс Azure:
Создайте управляемое удостоверение для приложения IoT Central для подключения к базе данных. Используйте Azure Cloud Shell для выполнения следующей команды:
az iot central app identity assign --name {your IoT Central app name} \
--resource-group {resource group name} \
--system-assigned
Запишите principalId
и tenantId
выходные данные команды. Эти значения используются на следующем шаге.
Настройте разрешения базы данных, чтобы разрешить подключения из приложения IoT Central. Используйте Azure Cloud Shell для выполнения следующей команды:
az kusto database-principal-assignment create --cluster-name {name of your cluster} \
--database-name {name of your database} \
--resource-group {resource group name} \
--principal-assignment-name {name of your IoT Central application} \
--principal-id {principal id from the previous step} \
--principal-type App --role Admin \
--tenant-id {tenant id from the previous step}
Совет
Если вы используете Azure Synapse, см. раздел az synapse kusto database-principal-assignment
.
Создайте таблицу в базе данных с подходящей схемой для экспортируемых данных. В следующем примере запроса создается таблица с именем smartvitalspatch
. Дополнительные сведения см. в статье "Преобразование данных в приложении IoT Central" для экспорта:
.create table smartvitalspatch (
EnqueuedTime:datetime,
Message:string,
Application:string,
Device:string,
Simulated:boolean,
Template:string,
Module:string,
Component:string,
Capability:string,
Value:dynamic
)
(Необязательно) Чтобы ускорить прием данных в базу данных Azure Data Explorer, выполните приведенные действия.
Перейдите на страницу "Конфигурации" для кластера Azure Data Explorer. Затем включите параметр приема потоковой передачи .
Выполните следующий запрос, чтобы изменить политику таблицы, чтобы включить прием потоковой передачи:
.alter table smartvitalspatch policy streamingingestion enable
Чтобы создать назначение Azure Data Explorer в IoT Central на странице экспорта данных:
Нажмите кнопку + New destination (Создать назначение).
В качестве типа места назначения выберите Azure Data Explorer.
Введите свой кластер Azure Data Explorer или URL-адрес пула, имя базы данных и имя таблицы. Выберите управляемое удостоверение , назначаемое системой, в качестве типа авторизации.
Совет
URL-адрес кластера для автономного обозревателя данных Azure выглядит следующим https://<ClusterName>.<AzureRegion>.kusto.windows.net
образом. URL-адрес кластера для пула Azure Synapse Data Explorer выглядит следующим образом https://<DataExplorerPoolName>.<SynapseWorkspaceName>.kusto.azuresynapse.net
.
Если данные, поступающие в целевую службу, не отображаются, см . статью "Устранение неполадок с экспортом данных из приложения Azure IoT Central".
Теперь, когда у вас есть назначение для экспорта данных, настройте экспорт в приложении IoT Central:
Войдите в приложение IoT Central.
На панели слева выберите элемент Экспорт данных.
Совет
Если вы не видите элемент Экспорт данных на панели слева, у вас нет разрешений на настройку экспорта данных в приложении. Обратитесь к администратору, чтобы настроить экспорт данных.
Выберите + Новый экспорт.
Введите отображаемое имя для нового экспорта и убедитесь, что экспорт данных включен.
Выберите тип данных для экспорта. В следующей таблице перечислены поддерживаемые типы данных.
Тип данных | Description | Формат данных |
---|---|---|
Телеметрия | Экспорт сообщений телеметрии с устройств практически в реальном времени. Каждое экспортированное сообщение содержит полное содержимое исходного сообщения устройства в нормализованном виде. | Формат сообщения телеметрии |
Изменения свойств | Экспорт изменений в свойствах устройства и облака практически в реальном времени. Для свойств устройств, доступных только для чтения, экспортируются изменения в сообщаемых значениях. Для свойств, доступных для чтения и записи, экспортируются и сообщаемые, и требуемые значения. | Формат сообщения об изменении свойства |
Взаимодействие устройств | Экспорт подключенных и отключенных устройств. | Формат сообщения о подключении устройства |
Жизненный цикл устройства | Экспорт событий регистрации, удаления, подготовки, включения, отключения устройств, а также событий displayNameChanged и deviceTemplateChanged. | Формат сообщения об изменениях жизненного цикла устройства |
Жизненный цикл шаблона устройства | Экспорт опубликованных изменений шаблонов устройств, включая создание, обновление и удаление. | Формат сообщения об изменениях жизненного цикла шаблона устройства |
Журналы аудита | Журналы обновлений, инициированных пользователем, для сущностей в приложении. Дополнительные сведения см. в статье "Использование журналов аудита для отслеживания действий в приложении IoT Central" | Формат сообщения журнала аудита |
При необходимости добавьте фильтры, чтобы уменьшить объем экспортируемых данных. Есть несколько типов фильтров, доступных для каждого типа экспорта данных:
Тип данных | Доступные фильтры |
---|---|
Телеметрия |
|
Изменения свойств |
|
Взаимодействие устройств |
|
Жизненный цикл устройства |
|
Жизненный цикл шаблона устройства |
|
Журналы аудита | Н/П |
При необходимости обогатите экспортированные сообщения с дополнительными метаданными пары "ключ-значение". Следующие обогащения доступны для экспорта данных телеметрии, изменений свойств, подключений устройства и жизненного цикла устройства:
Настройте назначение экспорта:
Выберите +Назначение , чтобы добавить место назначения, которое вы уже создали или нажмите кнопку "Создать новую".
Чтобы преобразовать данные перед экспортом, нажмите кнопку +Преобразовать. Дополнительные сведения см. в статье "Преобразование данных в приложении IoT Central" для экспорта.
Выберите +Назначение , чтобы добавить до пяти назначений в один экспорт.
Завершив настройку экспорта, нажмите кнопку Сохранить. Через несколько минут ваши данные будут отображаться в выбранном назначении.
На странице экспорта данных в IoT Central можно проверить состояние экспорта. Вы также можете использовать Azure Monitor , чтобы узнать, сколько данных вы экспортируете и какие-либо ошибки экспорта. Вы можете получить доступ к метрикам экспорта и работоспособности устройств в диаграммах в портал Azure с помощью REST API, запросов в PowerShell или Azure CLI. Сейчас в Azure Monitor можно отслеживать следующие метрики экспорта данных:
Дополнительные сведения см. в статье Мониторинг работоспособности приложения.
В следующих разделах описываются форматы экспортированных данных:
Каждое экспортированное сообщение содержит нормализованную форму полного сообщения, отправленного устройством в тексте сообщения. Сообщение представлено в формате JSON и кодируется как UTF-8. В каждом сообщении содержатся следующие сведения:
applicationId
: идентификатор приложения IoT Central.messageSource
: источник сообщения — telemetry
.deviceId
: идентификатор устройства, с которого было отправлено сообщение телеметрии.schema
: имя и версия схемы полезных данных.templateId
: идентификатор шаблона устройства, назначенного устройству.enqueuedTime
: время, в течение которого IoT Central получил это сообщение.enrichments
: все обогащения, настроенные для экспорта.module
: модуль IoT Edge, который отправил это сообщение. Это поле отображается только в том случае, если сообщение поступило из модуля IoT Edge.component
: компонент, который отправил это сообщение. Это поле отображается только в том случае, если возможности, отправленные в сообщении, были смоделированы как компонент в шаблоне устройства.messageProperties
: другие свойства, отправляемые устройством с сообщением. Эти свойства иногда называют свойствами приложения.
Дополнительные сведения см. в документах Центра Интернета вещей.Сообщения телеметрии имеют свойства для метаданных, а также полезные данные телеметрии. В предыдущем фрагменте показаны примеры системных сообщений, таких как deviceId
и enqueuedTime
. Дополнительные сведения о свойствах системного сообщения см. в статье "Свойства системы" сообщений Центр Интернета вещей устройства в облако.
Свойства можно добавить в сообщения телеметрии, если необходимо добавить пользовательские метаданные в сообщения телеметрии. Например, необходимо добавить отметку времени при создании сообщения устройством.
В следующем фрагменте кода показано, как добавить свойство iothub-creation-time-utc
в сообщение при его создании на устройстве:
Важно!
Такая метка времени должна быть в формате UTC без сведений о часовом поясе. Например, 2021-04-21T11:30:16Z
использовать можно, а 2021-04-21T11:30:16-07:00
— нет.
async function sendTelemetry(deviceClient, index) {
console.log('Sending telemetry message %d...', index);
const msg = new Message(
JSON.stringify(
deviceTemperatureSensor.updateSensor().getCurrentTemperatureObject()
)
);
msg.properties.add("iothub-creation-time-utc", new Date().toISOString());
msg.contentType = 'application/json';
msg.contentEncoding = 'utf-8';
await deviceClient.sendEvent(msg);
}
Каждое сообщение или запись представляет одно изменение в свойствах устройства или облака. В экспортированном сообщении содержатся следующие сведения:
applicationId
: идентификатор приложения IoT Central.messageSource
: источник сообщения — properties
.messageType
: cloudPropertyChange
, devicePropertyDesiredChange
или devicePropertyReportedChange
.deviceId
: идентификатор устройства, с которого было отправлено сообщение телеметрии.schema
: имя и версия схемы полезных данных.enqueuedTime
: время, в течение которого IoT Central обнаружила это изменение.templateId
: идентификатор шаблона устройства, назначенного устройству.properties
: массив измененных свойств, включая имена измененных свойств и значений. Сведения о компоненте и модуле включаются в том случае, если свойство моделируется внутри компонента или модуля IoT Edge.enrichments
: все обогащения, настроенные для экспорта.Каждое сообщение или запись представляет событие подключения с одного устройства. В экспортированном сообщении содержатся следующие сведения:
applicationId
: идентификатор приложения IoT Central.messageSource
: источник сообщения — deviceConnectivity
.messageType
: connected
или disconnected
.deviceId
: идентификатор измененного устройства.schema
: имя и версия схемы полезных данных.templateId
: идентификатор шаблона устройства, назначенного устройству.enqueuedTime
: время, когда это изменение произошло в IoT Central.enrichments
: все обогащения, настроенные для экспорта.Каждое сообщение или запись представляет одно изменение для одного устройства. В экспортированном сообщении содержатся следующие сведения:
applicationId
: идентификатор приложения IoT Central.messageSource
: источник сообщения — deviceLifecycle
.messageType
: тип произошедшего изменения. Одно из значений: registered
, deleted
, provisioned
, enabled
, disabled
, displayNameChanged
или deviceTemplateChanged
.deviceId
: идентификатор измененного устройства.schema
: имя и версия схемы полезных данных.templateId
: идентификатор шаблона устройства, назначенного устройству.enqueuedTime
: время, когда это изменение произошло в IoT Central.enrichments
: все обогащения, настроенные для экспорта.Каждое сообщение или запись представляет одно изменение в одном опубликованном шаблоне устройства. В экспортированном сообщении содержатся следующие сведения:
applicationId
: идентификатор приложения IoT Central.messageSource
: источник сообщения — deviceTemplateLifecycle
.messageType
: created
, updated
или deleted
.schema
: имя и версия схемы полезных данных.templateId
: идентификатор шаблона устройства, назначенного устройству.enqueuedTime
: время, когда это изменение произошло в IoT Central.enrichments
: все обогащения, настроенные для экспорта.Каждое сообщение журнала аудита представляет собой изменение, инициированное пользователем, на сущность, доступную для аудита, в приложении IoT Central. В экспортированном сообщении содержатся следующие сведения:
actor
: сведения о пользователе, который изменил сущность.applicationId
: идентификатор приложения IoT Central.messageSource
: источник сообщения — audit
.messageType
: тип произошедшего изменения. Одно из: updated
, created
, deleted
.updated
: имеется только в том updated
случаеmessageType
. Дополнительные сведения об обновлении.resource
: сведения об измененной сущности.schema
: имя и версия схемы полезных данных.deviceId
: идентификатор измененного устройства.enqueuedTime
: время, когда это изменение произошло в IoT Central.enrichments
: все обогащения, настроенные для экспорта.Теперь, когда вы знаете, как экспортировать в Azure Data Explorer, рекомендуемый следующий шаг — узнать, как экспортировать в веб-перехватчик.
Обучение
Схема обучения
Use advance techniques in canvas apps to perform custom updates and optimization - Training
Use advance techniques in canvas apps to perform custom updates and optimization