예제 #1
0
def main(args=None):
    # from dbnd._core.log.config import configure_basic_logging
    # configure_basic_logging(None)

    dbnd_system_bootstrap()

    # LET'S PATCH AIRFLOW FIRST
    from dbnd_airflow.bootstrap import dbnd_airflow_bootstrap

    dbnd_airflow_bootstrap()

    from airflow.bin.cli import CLIFactory
    from airflow.configuration import conf
    from dbnd_airflow.plugins.setup_plugins import (
        setup_scheduled_dags,
        setup_versioned_dags,
    )

    # ORIGINAL CODE from  airflow/bin/airflow
    if conf.get("core", "security") == "kerberos":
        os.environ["KRB5CCNAME"] = conf.get("kerberos", "ccache")
        os.environ["KRB5_KTNAME"] = conf.get("kerberos", "keytab")

    import argcomplete
    from dbnd_airflow.scheduler.zombies import find_and_kill_dagrun_zombies

    CLIFactory.subparsers_dict[find_and_kill_dagrun_zombies.__name__] = {
        "func": find_and_kill_dagrun_zombies,
        "help": "Clean up BackfillJob zombie tasks",
        "args": tuple(),
    }

    parser = CLIFactory.get_parser()
    argcomplete.autocomplete(parser)
    args = parser.parse_args(args=args)
    func_name = args.func.__name__

    # DBND PATCH:
    if dbnd_config.getboolean("airflow",
                              "auto_add_scheduled_dags") and func_name in [
                                  "scheduler",
                                  "webserver",
                              ]:
        setup_scheduled_dags()
    if dbnd_config.getboolean(
            "airflow",
            "auto_add_versioned_dags") and func_name in ["webserver"]:
        setup_versioned_dags()

    args.func(args)

    if func_name in ["resetdb", "initdb"]:
        pool_name = dbnd_config.get("airflow", "dbnd_pool")
        if pool_name == "dbnd_pool":
            create_airflow_pool(pool_name)
예제 #2
0
def main(args=None):
    # from dbnd._core.log.config import configure_basic_logging
    # configure_basic_logging(None)

    from dbnd import dbnd_config
    from dbnd._core.configuration.environ_config import set_quiet_mode
    from dbnd._core.context.bootstrap import dbnd_system_bootstrap

    set_quiet_mode()
    dbnd_system_bootstrap()

    # LET'S PATCH AIRFLOW FIRST
    from dbnd_airflow.bootstrap import airflow_bootstrap

    airflow_bootstrap()

    from airflow.bin.cli import CLIFactory
    from airflow.configuration import conf
    from dbnd_airflow.plugins.setup_plugins import (
        setup_scheduled_dags,
        setup_versioned_dags,
    )

    # ORIGINAL CODE from  airflow/bin/airflow
    if conf.get("core", "security") == "kerberos":
        os.environ["KRB5CCNAME"] = conf.get("kerberos", "ccache")
        os.environ["KRB5_KTNAME"] = conf.get("kerberos", "keytab")

    parser = CLIFactory.get_parser()
    argcomplete.autocomplete(parser)
    args = parser.parse_args(args=args)
    func_name = args.func.__name__

    # DBND PATCH:
    if dbnd_config.getboolean("airflow",
                              "auto_add_scheduled_dags") and func_name in [
                                  "scheduler",
                                  "webserver",
                              ]:
        setup_scheduled_dags()
    if dbnd_config.getboolean(
            "airflow",
            "auto_add_versioned_dags") and func_name in ["webserver"]:
        setup_versioned_dags()

    args.func(args)