當前位置: 首頁>>代碼示例>>Python>>正文


Python BaseHook.get_connection方法代碼示例

本文整理匯總了Python中airflow.hooks.base_hook.BaseHook.get_connection方法的典型用法代碼示例。如果您正苦於以下問題:Python BaseHook.get_connection方法的具體用法?Python BaseHook.get_connection怎麽用?Python BaseHook.get_connection使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在airflow.hooks.base_hook.BaseHook的用法示例。


在下文中一共展示了BaseHook.get_connection方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: execute

# 需要導入模塊: from airflow.hooks.base_hook import BaseHook [as 別名]
# 或者: from airflow.hooks.base_hook.BaseHook import get_connection [as 別名]
    def execute(self, context):
        # Specifying a service account file allows the user to using non default
        # authentication for creating a Kubernetes Pod. This is done by setting the
        # environment variable `GOOGLE_APPLICATION_CREDENTIALS` that gcloud looks at.
        key_file = None

        # If gcp_conn_id is not specified gcloud will use the default
        # service account credentials.
        if self.gcp_conn_id:
            from airflow.hooks.base_hook import BaseHook
            # extras is a deserialized json object
            extras = BaseHook.get_connection(self.gcp_conn_id).extra_dejson
            # key_file only gets set if a json file is created from a JSON string in
            # the web ui, else none
            key_file = self._set_env_from_extras(extras=extras)

        # Write config to a temp file and set the environment variable to point to it.
        # This is to avoid race conditions of reading/writing a single file
        with tempfile.NamedTemporaryFile() as conf_file:
            os.environ[KUBE_CONFIG_ENV_VAR] = conf_file.name
            # Attempt to get/update credentials
            # We call gcloud directly instead of using google-cloud-python api
            # because there is no way to write kubernetes config to a file, which is
            # required by KubernetesPodOperator.
            # The gcloud command looks at the env variable `KUBECONFIG` for where to save
            # the kubernetes config file.
            subprocess.check_call(
                ["gcloud", "container", "clusters", "get-credentials",
                 self.cluster_name,
                 "--zone", self.location,
                 "--project", self.project_id])

            # Since the key file is of type mkstemp() closing the file will delete it from
            # the file system so it cannot be accessed after we don't need it anymore
            if key_file:
                key_file.close()

            # Tell `KubernetesPodOperator` where the config file is located
            self.config_file = os.environ[KUBE_CONFIG_ENV_VAR]
            return super().execute(context)
開發者ID:apache,項目名稱:incubator-airflow,代碼行數:42,代碼來源:gcp_container_operator.py

示例2: execute

# 需要導入模塊: from airflow.hooks.base_hook import BaseHook [as 別名]
# 或者: from airflow.hooks.base_hook.BaseHook import get_connection [as 別名]
    def execute(self, context):
        # If gcp_conn_id is not specified gcloud will use the default
        # service account credentials.
        if self.gcp_conn_id:
            from airflow.hooks.base_hook import BaseHook
            # extras is a deserialized json object
            extras = BaseHook.get_connection(self.gcp_conn_id).extra_dejson
            self._set_env_from_extras(extras=extras)

        # Write config to a temp file and set the environment variable to point to it.
        # This is to avoid race conditions of reading/writing a single file
        with tempfile.NamedTemporaryFile() as conf_file:
            os.environ[KUBE_CONFIG_ENV_VAR] = conf_file.name
            # Attempt to get/update credentials
            # We call gcloud directly instead of using google-cloud-python api
            # because there is no way to write kubernetes config to a file, which is
            # required by KubernetesPodOperator.
            # The gcloud command looks at the env variable `KUBECONFIG` for where to save
            # the kubernetes config file.
            subprocess.check_call(
                ["gcloud", "container", "clusters", "get-credentials",
                 self.cluster_name,
                 "--zone", self.location,
                 "--project", self.project_id])

            # Tell `KubernetesPodOperator` where the config file is located
            self.config_file = os.environ[KUBE_CONFIG_ENV_VAR]
            super(GKEPodOperator, self).execute(context)
開發者ID:mozilla,項目名稱:telemetry-airflow,代碼行數:30,代碼來源:gcp_container_operator.py

示例3: poke

# 需要導入模塊: from airflow.hooks.base_hook import BaseHook [as 別名]
# 或者: from airflow.hooks.base_hook.BaseHook import get_connection [as 別名]
    def poke(self, context):
        hook = BaseHook.get_connection(self.conn_id).get_hook()

        self.log.info('Poking: %s', self.sql)
        records = hook.get_records(self.sql)
        if not records:
            return False
        return str(records[0][0]) not in ('0', '')
開發者ID:MiguelPeralvo,項目名稱:incubator-airflow,代碼行數:10,代碼來源:sql_sensor.py

示例4: _get_project_id

# 需要導入模塊: from airflow.hooks.base_hook import BaseHook [as 別名]
# 或者: from airflow.hooks.base_hook.BaseHook import get_connection [as 別名]
def _get_project_id():
  """Get project ID from default GCP connection."""

  extras = BaseHook.get_connection('google_cloud_default').extra_dejson
  key = 'extra__google_cloud_platform__project'
  if key in extras:
    project_id = extras[key]
  else:
    raise ('Must configure project_id in google_cloud_default '
           'connection from Airflow Console')
  return project_id
開發者ID:GoogleCloudPlatform,項目名稱:training-data-analyst,代碼行數:13,代碼來源:training.py

示例5: poke

# 需要導入模塊: from airflow.hooks.base_hook import BaseHook [as 別名]
# 或者: from airflow.hooks.base_hook.BaseHook import get_connection [as 別名]
    def poke(self, context):
        hook = BaseHook.get_connection(self.conn_id).get_hook()

        logging.info('Poking: ' + self.sql)
        records = hook.get_records(self.sql)
        if not records:
            return False
        else:
            if str(records[0][0]) in ('0', '',):
                return False
            else:
                return True
            print(records[0][0])
開發者ID:Zen-Slug,項目名稱:incubator-airflow,代碼行數:15,代碼來源:sensors.py

示例6: poke

# 需要導入模塊: from airflow.hooks.base_hook import BaseHook [as 別名]
# 或者: from airflow.hooks.base_hook.BaseHook import get_connection [as 別名]
    def poke(self, context):
        conn = BaseHook.get_connection(self.conn_id)

        allowed_conn_type = {'google_cloud_platform', 'jdbc', 'mssql',
                             'mysql', 'oracle', 'postgres',
                             'presto', 'sqlite', 'vertica'}
        if conn.conn_type not in allowed_conn_type:
            raise AirflowException("The connection type is not supported by SqlSensor. " +
                                   "Supported connection types: {}".format(list(allowed_conn_type)))
        hook = conn.get_hook()

        self.log.info('Poking: %s (with parameters %s)', self.sql, self.parameters)
        records = hook.get_records(self.sql, self.parameters)
        if not records:
            return False
        return str(records[0][0]) not in ('0', '')
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:18,代碼來源:sql_sensor.py

示例7: poke

# 需要導入模塊: from airflow.hooks.base_hook import BaseHook [as 別名]
# 或者: from airflow.hooks.base_hook.BaseHook import get_connection [as 別名]
    def poke(self, context):
        conn = BaseHook.get_connection(self.qubole_conn_id)
        Qubole.configure(api_token=conn.password, api_url=conn.host)

        this.log.info('Poking: %s', self.data)

        status = False
        try:
            status = self.sensor_class.check(self.data)
        except Exception as e:
            logging.exception(e)
            status = False

        this.log.info('Status of this Poke: %s', status)

        return status
開發者ID:caseybrown89,項目名稱:airflow,代碼行數:18,代碼來源:qubole_sensor.py

示例8: get_extra_links

# 需要導入模塊: from airflow.hooks.base_hook import BaseHook [as 別名]
# 或者: from airflow.hooks.base_hook.BaseHook import get_connection [as 別名]
    def get_extra_links(self, operator, dttm):
        """
        Get link to qubole command result page.

        :param operator: operator
        :param dttm: datetime
        :return: url link
        """
        conn = BaseHook.get_connection(operator.kwargs['qubole_conn_id'])
        if conn and conn.host:
            host = re.sub(r'api$', 'v2/analyze?command_id=', conn.host)
        else:
            host = 'https://api.qubole.com/v2/analyze?command_id='

        ti = TaskInstance(task=operator, execution_date=dttm)
        qds_command_id = ti.xcom_pull(task_ids=operator.task_id, key='qbol_cmd_id')
        url = host + str(qds_command_id) if qds_command_id else ''
        return url
開發者ID:apache,項目名稱:incubator-airflow,代碼行數:20,代碼來源:qubole_hook.py

示例9: __init__

# 需要導入模塊: from airflow.hooks.base_hook import BaseHook [as 別名]
# 或者: from airflow.hooks.base_hook.BaseHook import get_connection [as 別名]
 def __init__(self,
              sql,
              autocommit=False,
              parameters=None,
              gcp_conn_id='google_cloud_default',
              gcp_cloudsql_conn_id='google_cloud_sql_default',
              *args, **kwargs):
     super(CloudSqlQueryOperator, self).__init__(*args, **kwargs)
     self.sql = sql
     self.gcp_conn_id = gcp_conn_id
     self.gcp_cloudsql_conn_id = gcp_cloudsql_conn_id
     self.autocommit = autocommit
     self.parameters = parameters
     self.gcp_connection = BaseHook.get_connection(self.gcp_conn_id)
     self.cloudsql_db_hook = CloudSqlDatabaseHook(
         gcp_cloudsql_conn_id=gcp_cloudsql_conn_id,
         default_gcp_project_id=self.gcp_connection.extra_dejson.get(
             'extra__google_cloud_platform__project'))
     self.cloud_sql_proxy_runner = None
     self.database_hook = None
開發者ID:Fokko,項目名稱:incubator-airflow,代碼行數:22,代碼來源:gcp_sql_operator.py


注:本文中的airflow.hooks.base_hook.BaseHook.get_connection方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。