Yandex Cloud
Поиск
Связаться с намиПодключиться
  • Документация
  • Блог
  • Все сервисы
  • Статус работы сервисов
    • Популярные
    • Инфраструктура и сеть
    • Платформа данных
    • Контейнеры
    • Инструменты разработчика
    • Бессерверные вычисления
    • Безопасность
    • Мониторинг и управление ресурсами
    • Машинное обучение
    • Бизнес-инструменты
  • Все решения
    • По отраслям
    • По типу задач
    • Экономика платформы
    • Безопасность
    • Техническая поддержка
    • Каталог партнёров
    • Обучение и сертификация
    • Облако для стартапов
    • Облако для крупного бизнеса
    • Центр технологий для общества
    • Облако для интеграторов
    • Поддержка IT-бизнеса
    • Облако для фрилансеров
    • Обучение и сертификация
    • Блог
    • Документация
    • Контент-программа
    • Мероприятия и вебинары
    • Контакты, чаты и сообщества
    • Идеи
    • Истории успеха
    • Тарифы Yandex Cloud
    • Промоакции и free tier
    • Правила тарификации
  • Документация
  • Блог
Проект Яндекса
© 2025 ООО «Яндекс.Облако»
Yandex Managed Service for Apache Airflow™
  • Начало работы
    • Все инструкции
      • Загрузка файла в Yandex Object Storage
      • Подключение к бакету Yandex Object Storage с политикой доступа
      • Чтение файла из Yandex Object Storage
    • Работа с интерфейсами Apache Airflow™
    • Передача логов Apache Airflow™ в Cloud Logging
  • Управление доступом
  • Правила тарификации
  • Справочник Terraform
  • Метрики Yandex Monitoring
  • История изменений
  • Вопросы и ответы

В этой статье:

  • Создайте бакет для загрузки файлов
  • Подготовьте DAG-файл и запустите граф
  • Проверьте результат
  1. Пошаговые инструкции
  2. Работа с Yandex Object Storage
  3. Загрузка файла в Yandex Object Storage

Загрузка файла в Yandex Object Storage

Статья создана
Yandex Cloud
Обновлена 21 марта 2025 г.
  • Создайте бакет для загрузки файлов
  • Подготовьте DAG-файл и запустите граф
  • Проверьте результат

Используйте направленный ациклический граф (DAG) для загрузки файлов в Object Storage.

Создайте бакет для загрузки файловСоздайте бакет для загрузки файлов

  1. Создайте бакет Object Storage с именем username-airflow для загрузки файлов.
  2. Предоставьте разрешение READ и WRITE для сервисного аккаунта airflow-sa на созданный ранее бакет.

Подготовьте DAG-файл и запустите графПодготовьте DAG-файл и запустите граф

  1. Создайте локально файл с именем upload_file_to_s3.py и скопируйте в него скрипт:

    from airflow.decorators import dag, task
    import boto3
    import botocore
    import botocore.config
    import yandexcloud
    
    
    def _upload_file_to_s3(bucket_name: str, object_path: str, content: str):
        sdk = yandexcloud.SDK()
    
        def provide_cloud_auth_header(request, **kwargs):
            request.headers.add_header("X-YaCloud-SubjectToken", sdk._channels._token_requester.get_token())
    
        session = boto3.Session()
        session.events.register('request-created.s3.*', provide_cloud_auth_header)
        client = session.resource(
            "s3",
            endpoint_url="https://storage.yandexcloud.net",
            config=botocore.config.Config(
                signature_version=botocore.UNSIGNED,
                retries=dict(
                    max_attempts=5,
                    mode="standard",
                ),
            ),
        )
        client.Bucket(name=bucket_name).put_object(Key=object_path, Body=content)
    
    
    @dag(schedule=None)
    def upload_file_to_s3():
        @task
        def upload():
            _upload_file_to_s3(
                bucket_name="username-airflow",
                object_path="data/airflow.txt",
                content="Hello from Managed Airflow!"
            )
    
        upload()
    
    
    upload_file_to_s3()
    
    
  2. Загрузите DAG-файл upload_file_to_s3.py в первый созданный бакет. В результате одноименный граф появится в веб-интерфейсе Apache Airflow™ автоматически.

  3. Откройте веб-интерфейс Apache Airflow™.

  4. Убедитесь, что в разделе DAGs появился новый граф upload_file_to_s3.

    Загрузка DAG-файла из бакета может занять несколько минут.

  5. Чтобы запустить граф, в строке с его именем нажмите кнопку image.

Проверьте результатПроверьте результат

Проверьте наличие файла в веб-интерфейсе Object Storage бакета username-airflow.

Была ли статья полезна?

Предыдущая
Получение IAM-токена
Следующая
Подключение к бакету Yandex Object Storage с политикой доступа
Проект Яндекса
© 2025 ООО «Яндекс.Облако»