Airflow 不会在任何地方记录日志。
创始人
2024-08-01 08:01:07
0

Airflow 默认会将日志记录到其安装目录下的logs文件夹中,但是也可以通过配置更改日志记录的位置。以下是一个示例解决方法:

  1. 打开airflow.cfg配置文件。该文件位于Airflow安装目录下的airflow文件夹中。

  2. 找到并修改以下配置项:

    logging_level = WARNING
    logging_config_class = log_config.LOGGING_CONFIG
    

    logging_level设置为WARNING,以减少日志记录的级别。将logging_config_class设置为log_config.LOGGING_CONFIG,以使用自定义的日志配置。

  3. 创建一个名为log_config.py的新文件,放置在Airflow安装目录下的airflow文件夹中。

  4. log_config.py文件中,添加以下代码:

    import os
    from airflow import configuration as conf
    
    def LOGGING_CONFIG():
        log_dir = conf.get('logging', 'BASE_LOG_FOLDER')
        filename_template = conf.get('logging', 'LOG_FILENAME_TEMPLATE')
        filename = filename_template.format(scheduled_dag_file=__file__)
        log_filepath = os.path.join(log_dir, filename)
        return {
            'version': 1,
            'disable_existing_loggers': False,
            'handlers': {
                'console': {
                    'class': 'logging.StreamHandler',
                    'formatter': 'airflow',
                    'stream': 'ext://sys.stdout'
                },
                'file': {
                    'class': 'logging.FileHandler',
                    'formatter': 'airflow',
                    'filename': log_filepath
                }
            },
            'formatters': {
                'airflow': {
                    'format': '%(asctime)s - %(name)s - %(levelname)s - %(message)s'
                }
            },
            'root': {
                'handlers': ['console', 'file'],
                'level': 'INFO'
            }
        }
    

    这个函数定义了自定义的日志配置,将日志记录到指定的文件中。

  5. 保存log_config.py文件。

  6. 重新启动Airflow服务。

这样,Airflow将不再记录日志到默认位置,而是记录到自定义的日志文件中。请注意,这个解决方法仅适用于Airflow v2.0及以上版本。

相关内容

热门资讯

安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
避免在粘贴双引号时向VS 20... 在粘贴双引号时向VS 2022添加反斜杠的问题通常是由于编辑器的自动转义功能引起的。为了避免这个问题...
Android Recycle... 要在Android RecyclerView中实现滑动卡片效果,可以按照以下步骤进行操作:首先,在项...
omi系统和安卓系统哪个好,揭... OMI系统和安卓系统哪个好?这个问题就像是在问“苹果和橘子哪个更甜”,每个人都有自己的答案。今天,我...
原生ios和安卓系统,原生对比... 亲爱的读者们,你是否曾好奇过,为什么你的iPhone和安卓手机在操作体验上有着天壤之别?今天,就让我...
安装了Anaconda之后找不... 在安装Anaconda后,如果找不到Jupyter Notebook,可以尝试以下解决方法:检查环境...
Android - 无法确定任... 这个错误通常发生在Android项目中,表示编译Debug版本的Java代码时出现了依赖关系问题。下...
Android - NDK 预... 在Android NDK的构建过程中,LOCAL_SRC_FILES只能包含一个项目。如果需要在ND...
Akka生成Actor问题 在Akka框架中,可以使用ActorSystem对象生成Actor。但是,当我们在Actor类中尝试...
Agora-RTC-React... 出现这个错误原因是因为在 React 组件中使用,import AgoraRTC from “ago...