Поделиться через


Преобразование данных в Delta Lake с помощью потока данных для сопоставления

ОБЛАСТЬ ПРИМЕНЕНИЯ: Фабрика данных Azure Azure Synapse Analytics

Совет

Попробуйте использовать фабрику данных в Microsoft Fabric, решение для аналитики с одним интерфейсом для предприятий. Microsoft Fabric охватывает все, от перемещения данных до обработки и анализа данных в режиме реального времени, бизнес-аналитики и отчетности. Узнайте, как бесплатно запустить новую пробную версию !

Если вы еще не работали с фабрикой данных Azure, ознакомьтесь со статьей Введение в фабрику данных Azure.

В этом руководстве вы используете холст потока данных для создания потоков данных, которые позволяют анализировать и преобразовывать данные в Azure Data Lake Storage (ADLS) 2-го поколения и хранить их в Delta Lake.

Необходимые компоненты

  • Подписка Azure. Если у вас еще нет подписки Azure, создайте бесплатную учетную запись Azure, прежде чем начинать работу.
  • Учетная запись хранения Azure. Хранилище ADLS используется в качестве хранилища данных источника и приемника. Если у вас нет учетной записи хранения, создайте ее, следуя действиям в этом разделе.

Файл, который мы преобразуем в этом руководстве, MoviesDB.csv, который можно найти здесь. Чтобы извлечь файл из GitHub, скопируйте его содержимое в любой текстовый редактор, а затем сохраните его на локальном компьютере в виде CSV-файла. Сведения о передаче файла в учетную запись хранения см. в статье Отправка BLOB-объектов с помощью портала Azure. Примеры ссылаются на контейнер с именем sample-data.

Создание фабрики данных

На этом этапе вы создадите фабрику данных и откроете пользовательский интерфейс службы "Фабрика данных" для создания конвейера в фабрике данных.

  1. Откройте Microsoft Edge или Google Chrome. Сейчас пользовательский интерфейс Фабрики данных поддерживают только браузеры Microsoft Edge и Google Chrome.

  2. В меню слева последовательно выберите элементы Создать ресурс>Интеграция>Фабрика данных.

  3. На странице Новая фабрика данных в поле Имя введите ADFTutorialDataFactory.

  4. Выберите подписку Azure, в рамках которой вы хотите создать фабрику данных.

  5. Для группы ресурсов выполните одно из следующих действий:

    a. Выберите Использовать существующуюи укажите существующую группу ресурсов в раскрывающемся списке.

    b. Выберите Создать новуюи укажите имя группы ресурсов.

    Сведения о группах ресурсов см. в статье Общие сведения об Azure Resource Manager.

  6. В качестве версии выберите V2.

  7. В поле Расположение выберите расположение фабрики данных. В раскрывающемся списке отображаются только поддерживаемые расположения. Хранилища данных (например, служба хранилища Azure и База данных SQL) и вычислительные ресурсы (например, Azure HDInsight), используемые фабрикой данных, могут располагаться в других регионах.

  8. Нажмите кнопку создания.

  9. После завершения создания вы увидите уведомление в центре уведомлений. Нажмите кнопку Перейти к ресурсу, чтобы открыть страницу фабрики данных.

  10. Выберите Создание и мониторинг, чтобы запустить на отдельной вкладке пользовательский интерфейс фабрики данных.

Создание конвейера с помощью действия потока данных

На этом шаге создается конвейер, содержащий действие потока данных.

  1. На домашней странице выберите Orchestrate (Оркестрация).

    Снимок экрана: домашняя страница ADF

  2. На вкладке Общие для конвейера введите DeltaLake в качестве имени конвейера.

  3. В области Действия разверните меню "гармошка" Move and Transform (Перемещение и преобразование). Перетащите действие Поток данных из области на холст конвейера.

    Снимок экрана: холст конвейера, на который можно перетащить действие Потока данных.

  4. Во всплывающем окне Adding Data Flow (Добавление Потока данных) выберите Create new Data Flow (Создать Поток данных) и присвойте ему имя DeltaLake. По завершении нажмите кнопку "Готово".

    Снимок экрана: присваивание имени создаваемому потоку данных.

  5. На верхней панели холста конвейера продвиньте ползунок Отладка потока данных. Режим отладки позволяет в интерактивном режиме тестировать логику преобразования в динамическом кластере Spark. Подготовка кластеров Потоков данных занимает 5–7 минут, поэтому пользователям рекомендуем сначала включить отладку, если планируется разработка Потока данных. Дополнительные сведения см. в статье Режим отладки.

    Снимок экрана, показывающий, где находится ползунок отладки потока данных.

Встраивание логики преобразования в холст потока данных

Вы создаете два потока данных в этом руководстве. Первый поток данных — это простой источник для приемника для создания нового Delta Lake из CSV-файла фильмов. Наконец, вы создадите схему потока, которая следует за обновлением данных в Delta Lake.

Итоговый поток

Цели руководства

  1. Используйте источник набора данных MoviesCSV из предварительных требований и создайте новое Delta Lake из него.
  2. Создайте логику, чтобы обновить рейтинги для 1988 фильмов до "1".
  3. Удалите все фильмы, начиная с 1950 года.
  4. Вставьте новые фильмы для 2021 года путем копирования фильмов из 1960 года.

Начало работы с пустым холстом потока данных

  1. Выберите преобразование источника в верхней части окна редактора потока данных и нажмите кнопку +Создать рядом со свойством набора данных в окне параметров источника:

    Снимок экрана: добавление нового исходного набора данных в поток данных.

  2. Выберите Azure Data Lake Storage 2-го поколения в появившемся окне нового набора данных и нажмите кнопку "Продолжить".

    Снимок экрана, показывающий, где выбрать Azure Data Lake Storage 2-го поколения в окне

  3. Выберите разделители для типа набора данных и нажмите кнопку "Продолжить ".

    Снимок экрана, показывающий, где выбрать формат набора данных.

  4. Присвойте набору данных "MoviesCSV" и нажмите кнопку "Создать " в разделе "Связанная служба ", чтобы создать связанную службу в файле.

  5. Укажите сведения о учетной записи хранения, созданной ранее в разделе предварительных требований, и перейдите к файлу MoviesCSV, который вы добавили туда.

  6. После добавления связанной службы установите флажок "Первая строка" в качестве заголовка , а затем нажмите кнопку "ОК ", чтобы добавить источник.

  7. Перейдите на вкладку "Проекция " окна параметров потока данных и выберите " Определить типы данных".

  8. Теперь выберите + после источника в окне редактора потока данных и прокрутите вниз, чтобы выбрать приемник в разделе "Назначение ", добавив новый приемник в поток данных.

    Снимок экрана: место добавления назначения приемника для потока данных.

  9. На вкладке "Приемник" для параметров приемника, отображаемых после добавления приемника, выберите Inline для типа приемника, а затем Delta для типа встроенного набора данных. Затем выберите Azure Data Lake Storage 2-го поколения для связанной службы.

    Снимок экрана: сведения о приемнике для встроенного разностного набора данных.

  10. Выберите имя папки в контейнере хранилища, в котором требуется, чтобы служба создавала Delta Lake.

  11. Наконец, вернитесь к конструктору конвейера и выберите "Отладка ", чтобы выполнить конвейер в режиме отладки с помощью действия потока данных на холсте. Это создает новое Delta Lake в Azure Data Lake Storage 2-го поколения.

  12. Теперь в меню "Ресурсы фабрики" слева от экрана выберите + , чтобы добавить новый ресурс, а затем выберите поток данных.

    Снимок экрана: место создания потока данных в фабрике данных.

  13. Как и ранее, снова выберите файл MoviesCSV в качестве источника, а затем снова выберите " Обнаружение типов данных" на вкладке "Проекция ".

  14. На этот раз после создания источника выберите + в окне редактора потока данных и добавьте преобразование "Фильтр" в источник.

    Снимок экрана: добавление условия фильтра в поток данных.

  15. Добавьте фильтр по условию в окне параметров фильтра, которое разрешает только строки фильма, соответствующие 1950, 1960 и 1988.

    Снимок экрана: добавление фильтра в столбце Year для набора данных.

  16. Теперь добавьте преобразование "Производный столбец " для обновления оценок для каждого фильма 1988 года до "1".

    Снимок экрана, показывающий, где ввести выражение для производного столбца.

  17. В преобразовании изменения строк создаются политики Update, insert, delete, and upsert. Добавьте преобразование изменения строк после производного столбца.

  18. Политики изменения строк должны выглядеть следующим образом.

    Изменение строк

  19. Теперь, когда вы задаете правильную политику для каждого типа строки alter, убедитесь, что в преобразовании приемника заданы правильные правила обновления.

    Приемник

  20. Здесь мы используем приемник Delta Lake для Azure Data Lake Storage 2-го поколения озера данных и разрешаем вставлять, обновлять, удалять.

  21. Обратите внимание, что ключевые столбцы представляют собой составной ключ, состоящий из первичного ключевого столбца "Фильм" и столбца года. Это связано с тем, что мы создали ненастоящие фильмы 2021 года, скопировав строки для 1960 года. Это позволяет избежать конфликтов при поиске существующих строк за счет обеспечения уникальности.

Загрузка готового примера

Ниже приведен пример решения для конвейера Delta с потоком данных для обновления и удаления строк в озере.

Дополнительные сведения о языке выражений потока данных.