Краткое руководство. Создание задания Stream Analytics с использованием инструментов Azure Stream Analytics для Visual Studio Code
В этом кратком руководстве вы создадите, запустите и отправьте задание Azure Stream Analytics (ASA) с помощью расширения средств ASA для Visual Studio Code на локальном компьютере. Вы узнаете, как создать задание ASA, которое считывает данные потоковой передачи в режиме реального времени из Центр Интернета вещей и фильтрует события с температурой больше 27°. Выходные результаты отправляются в файл в хранилище BLOB-объектов. Входные данные, используемые в этом кратком руководстве, создаются онлайн-симулятором Raspberry Pi.
Примечание.
Средства Visual Studio Code не поддерживают рабочие места в регионах "Восточная Китай", "Северная Китай", "Центральная Германия" и "Северная Германия".
Необходимые компоненты
- Подписка Azure. Если у вас еще нет подписки Azure, создайте бесплатную учетную запись.
- Visual Studio Code.
Установка расширения "Инструменты Azure Stream Analytics"
Откройте Visual Studio Code (VS Code).
В области "Расширения" на панели слева найдите stream analytics и выберите "Установить" в расширении средств Azure Stream Analytics.
После установки выберите значок Azure на панели действий и войдите в Azure.
После входа вы увидите подписки в учетной записи Azure.
Примечание.
Расширение ASA Tools автоматически войдет в систему при каждом открытии VS Code. Если для вашей учетной записи настроена двухфакторная проверка подлинности, мы рекомендуем выполнять ее с использованием телефона, а не PIN-кода. Чтобы выйти из учетной записи Azure, нажмите Ctrl + Shift + P
и введите Azure: Sign Out
.
Запуск IoT-симулятора
Откройте онлайн-симулятор Raspberry Pi для Интернета вещей Azure.
Замените значения заполнителя в 15 строке строкой подключения устройства Центра Интернета вещей, которую вы сохранили при работе с предыдущим разделом.
Выберите Выполнить. В выходных данных должны присутствовать показания датчика и сообщения, отправляемые в Центр Интернета вещей.
Внимание
Нажмите кнопку "Сброс" через несколько минут, чтобы сбросить строка подключения.
Создание хранилища BLOB-объектов
В верхнем левом углу окна портала Azure щелкните Создать ресурс>Хранилище>Учетная запись хранения.
В области создания учетной записи хранения введите имя для учетной записи хранения, расположение и группу ресурсов. Выберите такое же расположение и группу ресурсов, как и для созданного центра Интернета вещей. Затем нажмите кнопку "Рецензирование " и "Создать ", чтобы создать учетную запись хранения.
На странице Учетная запись хранения выберите Контейнеры в меню слева, а затем выберите + Контейнер на панели команд.
На странице Создание контейнера укажите имя контейнера, оставьте для параметра Уровень общедоступного доступа значение Закрытый (отсутствие анонимного доступа) и нажмите ОК.
Создание проекта Stream Analytics
В Visual Studio Code нажмите клавиши CTRL+SHIFT+P и введите ASA: создать проект.
Введите имя проекта, например myASAproj, и выберите папку для этого проекта.
Проект ASA добавляется в рабочую область. Она состоит из трех папок: входных данных, выходных данных и функций. Также он включает скрипт запроса (*.asaql), файл JobConfig.json и файл конфигурации asaproj.json.
Файл asaproj.json содержит входные данные, выходные данные и параметры конфигурации задания для отправки задания Stream Analytics в Azure.
Примечание.
При добавлении входных и выходных данных с помощью палитры команд все соответствующие пути автоматически добавляются в файл asaproj.json. Если вы добавляете входные или выходные данные непосредственно на диск или удаляете их оттуда, используйте для этого файл asaproj.json. Вы можете поместить все входные и выходные данные в одно расположение, а затем создать ссылки на них в разных заданиях, указав пути в каждом файле asaproj.json.
Определение запроса преобразования
Откройте файл myASAproj.asaql и добавьте следующий запрос:
SELECT * INTO Output FROM Input WHERE Temperature > 27
Настройка входных данных для задания
Щелкните правой кнопкой мыши папку Inputs в проекте Stream Analytics. Затем выберите ASA: Добавить входные данные из контекстного меню.
Или нажмите клавиши CTRL+SHIFT+P , чтобы открыть палитру команд и ввести ASA: добавить входные данные.
Выберите в качестве типа входных данных Центр Интернета вещей.
Выберите из раскрывающегося меню подписки Azure и нажмите клавишу ВВОД.
Введите входные данные для имени и нажмите клавишу ВВОД.
В папке "Входные данные" будет создан файл IoTHub1.json .
В JSON-файле убедитесь, что входные данные указаны в имени.
В редакторе JSON для Input.json выберите пункт "Выбрать из подписок", а затем выберите подписку Azure с центром Интернета вещей.
В редакторе JSON выберите Центр Интернета вещей и выберите созданный центр Интернета вещей.
По умолчанию
SharedAccessPolicyName
должно быть задано значениеiothubowner
. В противном случае выберите ссылку "Имя политики общего доступа" и выберите iothubowner из раскрывающегося списка.Значение
SharedAccessPolicyKey
должно быть задано автоматически.Выберите предварительный просмотр данных , чтобы узнать, успешно ли настроены входные данные для задания. Он получит пример Центр Интернета вещей и отобразится в окне предварительного просмотра.
Настройка выходных данных для задания
- Щелкните правой кнопкой мыши выходные данные в обозревателе и выберите ASA: Добавить выходные данные.
- Выберите Data Lake Storage 2-го поколения/хранилище BLOB-объектов для типа приемника в раскрывающемся списке.
- Выбор из подписок Azure
- Введите выходные данные для имени псевдонима и нажмите клавишу ВВОД. Это выходное имя используется для инструкции INTO в запросе.
- В редакторе JSON для Output.json выберите "Выбрать из подписок" и выберите подписку Azure с учетной записью служба хранилища Azure
- Если необходимо изменить учетную запись хранения, которая автоматически заполнена, выберите учетную запись хранения и выберите учетную запись служба хранилища Azure. Имена учетных записей обнаруживаются автоматически, если они создаются в той же подписке.
- Если необходимо изменить имя контейнера, выберите контейнер и выберите созданный контейнер BLOB-объектов.
Компиляция скрипта и отправка в Azure
При компиляции скрипта проверяется синтаксис и создаются шаблоны Azure Resource Manager для автоматического развертывания.
Щелкните правой кнопкой мыши файл скрипта в окне обозревателя, наведите указатель на ASA: Компиляция скрипта, а затем выберите ASA: Шаблон ARM версии 2 (рекомендуется).
После компиляции вы увидите папку Deploy в проекте с двумя шаблонами Azure Resource Manager. Эти два файла используются для автоматического развертывания.
Выберите "Отправить в Azure " в редакторе запросов.
В окне отправки выполните следующие действия:
Выберите свою подписку Azure.
Выберите группу ресурсов Azure.
Выберите регион, в котором нужно создать задание Stream Analytics.
Затем выберите Отправить.
Выберите "Опубликовать в Azure " и завершите работу. Дождитесь открытия новой вкладки Cloud Job View с состоянием задания.
Запуск задания Stream Analytics и просмотр выходных данных
На вкладке "Представление заданий облака" выберите "Пуск ", чтобы запустить задание в облаке.
В окне задания начальной потоковой передачи нажмите кнопку "ОК". Этот процесс может занять несколько минут.
Если задание запущено успешно, состояние задания изменяется на "Выполнение". Вы увидите логическую схему, показывающую, как выполняется задание ASA.
Чтобы просмотреть выходные результаты, можно открыть хранилище BLOB-объектов в расширении Visual Studio Code или в портал Azure.
Скачайте и откройте файл, чтобы просмотреть выходные данные.
{"messageId":11,"deviceId":"Raspberry Pi Web Client","temperature":28.165519323167562,"humidity":76.875393581654379,"EventProcessedUtcTime":"2022-09-01T22:53:58.1015921Z","PartitionId":3,"EventEnqueuedUtcTime":"2022-09-01T22:52:57.6250000Z","IoTHub":{"MessageId":null,"CorrelationId":null,"ConnectionDeviceId":"MyASAIoTDevice","ConnectionDeviceGenerationId":"637976642928634103","EnqueuedTime":"2022-09-01T22:52:57.6290000Z"}} {"messageId":14,"deviceId":"Raspberry Pi Web Client","temperature":29.014941877871451,"humidity":64.93477299527828,"EventProcessedUtcTime":"2022-09-01T22:53:58.2421545Z","PartitionId":3,"EventEnqueuedUtcTime":"2022-09-01T22:53:03.6100000Z","IoTHub":{"MessageId":null,"CorrelationId":null,"ConnectionDeviceId":"MyASAIoTDevice","ConnectionDeviceGenerationId":"637976642928634103","EnqueuedTime":"2022-09-01T22:53:03.6140000Z"}} {"messageId":17,"deviceId":"Raspberry Pi Web Client","temperature":28.032846241745975,"humidity":66.146114343897338,"EventProcessedUtcTime":"2022-09-01T22:53:58.2421545Z","PartitionId":3,"EventEnqueuedUtcTime":"2022-09-01T22:53:19.5960000Z","IoTHub":{"MessageId":null,"CorrelationId":null,"ConnectionDeviceId":"MyASAIoTDevice","ConnectionDeviceGenerationId":"637976642928634103","EnqueuedTime":"2022-09-01T22:53:19.5830000Z"}} {"messageId":18,"deviceId":"Raspberry Pi Web Client","temperature":30.176185593576143,"humidity":72.697359909427419,"EventProcessedUtcTime":"2022-09-01T22:53:58.2421545Z","PartitionId":3,"EventEnqueuedUtcTime":"2022-09-01T22:53:21.6120000Z","IoTHub":{"MessageId":null,"CorrelationId":null,"ConnectionDeviceId":"MyASAIoTDevice","ConnectionDeviceGenerationId":"637976642928634103","EnqueuedTime":"2022-09-01T22:53:21.6140000Z"}} {"messageId":20,"deviceId":"Raspberry Pi Web Client","temperature":27.851894248213021,"humidity":71.610229530268214,"EventProcessedUtcTime":"2022-09-01T22:53:58.2421545Z","PartitionId":3,"EventEnqueuedUtcTime":"2022-09-01T22:53:25.6270000Z","IoTHub":{"MessageId":null,"CorrelationId":null,"ConnectionDeviceId":"MyASAIoTDevice","ConnectionDeviceGenerationId":"637976642928634103","EnqueuedTime":"2022-09-01T22:53:25.6140000Z"}} {"messageId":21,"deviceId":"Raspberry Pi Web Client","temperature":27.718624694772238,"humidity":66.540445035685153,"EventProcessedUtcTime":"2022-09-01T22:53:58.2421545Z","PartitionId":3,"EventEnqueuedUtcTime":"2022-09-01T22:53:48.0820000Z","IoTHub":{"MessageId":null,"CorrelationId":null,"ConnectionDeviceId":"MyASAIoTDevice","ConnectionDeviceGenerationId":"637976642928634103","EnqueuedTime":"2022-09-01T22:53:48.0830000Z"}} {"messageId":22,"deviceId":"Raspberry Pi Web Client","temperature":27.7849054424326,"humidity":74.300662748167085,"EventProcessedUtcTime":"2022-09-01T22:54:09.3393532Z","PartitionId":3,"EventEnqueuedUtcTime":"2022-09-01T22:54:09.2390000Z","IoTHub":{"MessageId":null,"CorrelationId":null,"ConnectionDeviceId":"MyASAIoTDevice","ConnectionDeviceGenerationId":"637976642928634103","EnqueuedTime":"2022-09-01T22:54:09.2400000Z"}} {"messageId":28,"deviceId":"Raspberry Pi Web Client","temperature":30.839892925680324,"humidity":76.237611741451786,"EventProcessedUtcTime":"2022-09-01T22:54:47.8053253Z","PartitionId":3,"EventEnqueuedUtcTime":"2022-09-01T22:54:47.6180000Z","IoTHub":{"MessageId":null,"CorrelationId":null,"ConnectionDeviceId":"MyASAIoTDevice","ConnectionDeviceGenerationId":"637976642928634103","EnqueuedTime":"2022-09-01T22:54:47.6150000Z"}} {"messageId":29,"deviceId":"Raspberry Pi Web Client","temperature":30.561040300759053,"humidity":78.3845172058103,"EventProcessedUtcTime":"2022-09-01T22:54:49.8070489Z","PartitionId":3,"EventEnqueuedUtcTime":"2022-09-01T22:54:49.6030000Z","IoTHub":{"MessageId":null,"CorrelationId":null,"ConnectionDeviceId":"MyASAIoTDevice","ConnectionDeviceGenerationId":"637976642928634103","EnqueuedTime":"2022-09-01T22:54:49.5990000Z"}} {"messageId":31,"deviceId":"Raspberry Pi Web Client","temperature":28.163585438418679,"humidity":60.0511571297096,"EventProcessedUtcTime":"2022-09-01T22:55:25.1528729Z","PartitionId":3,"EventEnqueuedUtcTime":"2022-09-01T22:55:24.9050000Z","IoTHub":{"MessageId":null,"CorrelationId":null,"ConnectionDeviceId":"MyASAIoTDevice","ConnectionDeviceGenerationId":"637976642928634103","EnqueuedTime":"2022-09-01T22:55:24.9120000Z"}} {"messageId":32,"deviceId":"Raspberry Pi Web Client","temperature":31.00503387156985,"humidity":78.68821066044552,"EventProcessedUtcTime":"2022-09-01T22:55:43.2652127Z","PartitionId":3,"EventEnqueuedUtcTime":"2022-09-01T22:55:43.0480000Z","IoTHub":{"MessageId":null,"CorrelationId":null,"ConnectionDeviceId":"MyASAIoTDevice","ConnectionDeviceGenerationId":"637976642928634103","EnqueuedTime":"2022-09-01T22:55:43.0520000Z"}}
Очистка ресурсов
Ставшие ненужными группу ресурсов, задание Stream Analytics и все связанные ресурсы можно удалить. При удалении задания будет прекращена тарификация за единицы потоковой передачи, потребляемые заданием. Если вы планируете использовать это задание в будущем, вы можете остановить и перезапустить его позже. Если вы не собираетесь использовать это задание дальше, удалите все ресурсы, созданные в ходе работы с этим руководством, сделав следующее:
В меню слева на портале Azure выберите Группы ресурсов, а затем щелкните имя созданного ресурса.
На странице группы ресурсов щелкните Удалить. В следующем окне введите имя удаляемого ресурса и щелкните Удалить.
Следующие шаги
Дополнительные сведения о расширении средств ASA для Visual Studio Code см. в следующих статьях: