airflow.providers.apache.spark.hooks.spark_jdbc

Module Contents

class airflow.providers.apache.spark.hooks.spark_jdbc.SparkJDBCHook(spark_app_name: str = 'airflow-spark-jdbc', spark_conn_id: str = default_conn_name, spark_conf: Optional[Dict[str, Any]] = None, spark_py_files: Optional[str] = None, spark_files: Optional[str] = None, spark_jars: Optional[str] = None, num_executors: Optional[int] = None, executor_cores: Optional[int] = None, executor_memory: Optional[str] = None, driver_memory: Optional[str] = None, verbose: bool = False, principal: Optional[str] = None, keytab: Optional[str] = None, cmd_type: str = 'spark_to_jdbc', jdbc_table: Optional[str] = None, jdbc_conn_id: str = 'jdbc-default', jdbc_driver: Optional[str] = None, metastore_table: Optional[str] = None, jdbc_truncate: bool = False, save_mode: Optional[str] = None, save_format: Optional[str] = None, batch_size: Optional[int] = None, fetch_size: Optional[int] = None, num_partitions: Optional[int] = None, partition_column: Optional[str] = None, lower_bound: Optional[str] = None, upper_bound: Optional[str] = None, create_table_column_types: Optional[str] = None, *args, **kwargs)[source]

Bases: airflow.providers.apache.spark.hooks.spark_submit.SparkSubmitHook

This hook extends the SparkSubmitHook specifically for performing data transfers to/from JDBC-based databases with Apache Spark.

Parameters
  • spark_app_name (str) -- Name of the job (default airflow-spark-jdbc)

  • spark_conn_id (str) -- Connection id as configured in Airflow administration

  • spark_conf (dict) -- Any additional Spark configuration properties

  • spark_py_files (str) -- Additional python files used (.zip, .egg, or .py)

  • spark_files (str) -- Additional files to upload to the container running the job

  • spark_jars (str) -- Additional jars to upload and add to the driver and executor classpath

  • num_executors (int) -- number of executor to run. This should be set so as to manage the number of connections made with the JDBC database

  • executor_cores (int) -- Number of cores per executor

  • executor_memory (str) -- Memory per executor (e.g. 1000M, 2G)

  • driver_memory (str) -- Memory allocated to the driver (e.g. 1000M, 2G)

  • verbose (bool) -- Whether to pass the verbose flag to spark-submit for debugging

  • keytab (str) -- Full path to the file that contains the keytab

  • principal (str) -- The name of the kerberos principal used for keytab

  • cmd_type (str) -- Which way the data should flow. 2 possible values: spark_to_jdbc: data written by spark from metastore to jdbc jdbc_to_spark: data written by spark from jdbc to metastore

  • jdbc_table (str) -- The name of the JDBC table

  • jdbc_conn_id (str) -- Connection id used for connection to JDBC database

  • jdbc_driver (str) -- Name of the JDBC driver to use for the JDBC connection. This driver (usually a jar) should be passed in the 'jars' parameter

  • metastore_table (str) -- The name of the metastore table,

  • jdbc_truncate (bool) -- (spark_to_jdbc only) Whether or not Spark should truncate or drop and recreate the JDBC table. This only takes effect if 'save_mode' is set to Overwrite. Also, if the schema is different, Spark cannot truncate, and will drop and recreate

  • save_mode (str) -- The Spark save-mode to use (e.g. overwrite, append, etc.)

  • save_format (str) -- (jdbc_to_spark-only) The Spark save-format to use (e.g. parquet)

  • batch_size (int) -- (spark_to_jdbc only) The size of the batch to insert per round trip to the JDBC database. Defaults to 1000

  • fetch_size (int) -- (jdbc_to_spark only) The size of the batch to fetch per round trip from the JDBC database. Default depends on the JDBC driver

  • num_partitions (int) -- The maximum number of partitions that can be used by Spark simultaneously, both for spark_to_jdbc and jdbc_to_spark operations. This will also cap the number of JDBC connections that can be opened

  • partition_column (str) -- (jdbc_to_spark-only) A numeric column to be used to partition the metastore table by. If specified, you must also specify: num_partitions, lower_bound, upper_bound

  • lower_bound (int) -- (jdbc_to_spark-only) Lower bound of the range of the numeric partition column to fetch. If specified, you must also specify: num_partitions, partition_column, upper_bound

  • upper_bound (int) -- (jdbc_to_spark-only) Upper bound of the range of the numeric partition column to fetch. If specified, you must also specify: num_partitions, partition_column, lower_bound

  • create_table_column_types -- (spark_to_jdbc-only) The database column data types to use instead of the defaults, when creating the table. Data type information should be specified in the same format as CREATE TABLE columns syntax (e.g: "name CHAR(64), comments VARCHAR(1024)"). The specified types should be valid spark sql data types.

conn_name_attr = spark_conn_id[source]
default_conn_name = spark_default[source]
conn_type = spark_jdbc[source]
hook_name = Spark JDBC[source]
_resolve_jdbc_connection(self)[source]
_build_jdbc_application_arguments(self, jdbc_conn: Dict[str, Any])[source]
submit_jdbc_job(self)[source]

Submit Spark JDBC job

get_conn(self)[source]

Was this entry helpful?