Есть ли способ создавать/изменять соединения через API Airflow

Пройдя через Admin → Connections, у нас есть возможность создавать/изменять параметры подключения, но мне интересно, могу ли я сделать то же самое через API, чтобы я мог программно устанавливать соединения

airflow.models.Connection похоже, что он имеет дело только с фактическим подключением к экземпляру, а не с сохранением его в списке. Это похоже на функцию, которая должна была быть реализована, но я не уверен, где я могу найти документы для этой конкретной функции.

Ответы

Ответ 1

Соединение на самом деле является моделью, которую вы можете использовать для запроса и вставки нового соединения

from airflow import settings
from airflow.models import Connection
conn = Connection(
        conn_id=conn_id,
        conn_type=conn_type,
        host=host,
        login=login,
        password=password,
        port=port
) #create a connection object
session = settings.Session() # get the session
session.add(conn)
session.commit() # it will insert the connection object programmatically.

Ответ 2

Вы также можете добавлять, удалять и перечислять соединения из CLI Airflow, если вам нужно сделать это вне кода Python/Airflow, через bash, в Dockerfile и т.д.

airflow connections --add ...

Использование:

airflow connections [-h] [-l] [-a] [-d] [--conn_id CONN_ID]
                    [--conn_uri CONN_URI] [--conn_extra CONN_EXTRA]
                    [--conn_type CONN_TYPE] [--conn_host CONN_HOST]
                    [--conn_login CONN_LOGIN] [--conn_password CONN_PASSWORD]
                    [--conn_schema CONN_SCHEMA] [--conn_port CONN_PORT]

https://airflow.apache.org/cli.html#connections

Это не похоже на то, что CLI в настоящее время поддерживает изменение существующего соединения, но есть проблема Jira для него с активным открытым PR на GitHub.

Ответ 3

код ниже непрерывно продолжает создавать соединения (бесконечно), как это остановить?

from airflow import settings
from airflow.models import Connection
conn = Connection(
        conn_id=conn_id,
        conn_type=conn_type,
        host=host,
        login=login,
        password=password,
        port=port
) #create a connection object
session = settings.Session() # get the session
session.add(conn)
session.commit() # it will insert the connection object programmatically. 

Обратите внимание, я изменил параметр в connection() в моей системе.