Flask-RuntimeError:在应用程序上下文之外工作

它的安德鲁

我收到“ RuntimeError:在应用程序上下文之外工作”。我的烧瓶应用程序中出现错误,并且正在努力了解原因。我曾尝试推送应用程序上下文,但是这似乎对我似乎不起作用,我可能只是对如何访问“ current_app”感到有些困惑,因此我可以从其他类和蓝图写入记录器。我的代码如下:

run.py:

#! /usr/bin/python3.6
from caffeine import create_app
import os

app = create_app()

SECRET_KEY = b'\x84\xde=\xc4\x1c%r\xf9Bt\xd3\xce\xc4o\xae\xf7'
app.secret_key = SECRET_KEY

if __name__ == '__main__':
    app.run(debug=False, host="0.0.0.0", port=8000)

init.py:

import os
import logging
from flask import session
from datetime import timedelta
from pathlib import Path
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_login import LoginManager
from caffeine.config import Config

# Create db instance
db = SQLAlchemy()

# create login manager instance
login_manager = LoginManager()

def create_app():
    """
    Iinstantiates and initialize the Flask application
    """
    app = Flask(__name__)
    app.config.from_object(Config)
    db.init_app(app)
    login_manager.init_app(app)
    login_manager.login_view = 'bp_auth.login'
    login_manager.refresh_view = 'bp_auth.login'
    login_manager.login_message_category = 'info'

    # import Blueprint objects for routes
    from caffeine.routes.bp_aiq_bundle import main
    from caffeine.routes.bp_auth import auth
    from caffeine.routes.bp_bundle import bundle
    from caffeine.routes.bp_aiq import aiq
    from caffeine.errors.handlers import errors
    app.register_blueprint(main)
    app.register_blueprint(auth)
    app.register_blueprint(bundle)
    app.register_blueprint(aiq)
    app.register_blueprint(errors)

    @app.before_request
    def before_request():
        session.permanent = True
        app.permanent_session_lifetime = timedelta(minutes=1440)

    # instantiate logger
    gunicorn_logger = logging.getLogger('gunicorn.error')
    app.logger.handlers = gunicorn_logger.handlers
    app.logger.setLevel(gunicorn_logger.level)

    return app

bp_bundle.py(蓝图):

import inspect
import pickle

from flask import current_app
from flask import render_template, Blueprint, session, url_for, request, redirect
from flask_login import login_required

from caffeine.main.forms import BundlePicker
from caffeine.models.models import BundleData, Clusterdata, AIQData
from caffeine.main.cluster import Cluster
from caffeine.utils.utils import get_session
from caffeine.utils.db_utils import populate_cluster_table
import caffeine.main.error as error
from caffeine.main.events import SliceRole


bundle = Blueprint('bp_bundle', __name__)

current_app.logger.error('hi')

堆栈跟踪:

Traceback (most recent call last):
  File "/Users/aclinton/Documents/environments/caff_env/lib/python3.9/site-packages/gunicorn/arbiter.py", line 583, in spawn_worker
    worker.init_process()
  File "/Users/aclinton/Documents/environments/caff_env/lib/python3.9/site-packages/gunicorn/workers/base.py", line 119, in init_process
    self.load_wsgi()
  File "/Users/aclinton/Documents/environments/caff_env/lib/python3.9/site-packages/gunicorn/workers/base.py", line 144, in load_wsgi
    self.wsgi = self.app.wsgi()
  File "/Users/aclinton/Documents/environments/caff_env/lib/python3.9/site-packages/gunicorn/app/base.py", line 67, in wsgi
    self.callable = self.load()
  File "/Users/aclinton/Documents/environments/caff_env/lib/python3.9/site-packages/gunicorn/app/wsgiapp.py", line 49, in load
    return self.load_wsgiapp()
  File "/Users/aclinton/Documents/environments/caff_env/lib/python3.9/site-packages/gunicorn/app/wsgiapp.py", line 39, in load_wsgiapp
    return util.import_app(self.app_uri)
  File "/Users/aclinton/Documents/environments/caff_env/lib/python3.9/site-packages/gunicorn/util.py", line 358, in import_app
    mod = importlib.import_module(module)
  File "/usr/local/Cellar/[email protected]/3.9.0_1/Frameworks/Python.framework/Versions/3.9/lib/python3.9/importlib/__init__.py", line 127, in import_module
    return _bootstrap._gcd_import(name[level:], package, level)
  File "<frozen importlib._bootstrap>", line 1030, in _gcd_import
  File "<frozen importlib._bootstrap>", line 1007, in _find_and_load
  File "<frozen importlib._bootstrap>", line 986, in _find_and_load_unlocked
  File "<frozen importlib._bootstrap>", line 680, in _load_unlocked
  File "<frozen importlib._bootstrap_external>", line 790, in exec_module
  File "<frozen importlib._bootstrap>", line 228, in _call_with_frames_removed
  File "/Users/aclinton/Documents/projects/caffeine/run.py", line 5, in <module>
    app = create_app()
  File "/Users/aclinton/Documents/projects/caffeine/caffeine/__init__.py", line 32, in create_app
    from caffeine.routes.bp_bundle import bundle
  File "/Users/aclinton/Documents/projects/caffeine/caffeine/routes/bp_bundle.py", line 19, in <module>
    current_app.logger.error('hi')
  File "/Users/aclinton/Documents/environments/caff_env/lib/python3.9/site-packages/werkzeug/local.py", line 347, in __getattr__
    return getattr(self._get_current_object(), name)
  File "/Users/aclinton/Documents/environments/caff_env/lib/python3.9/site-packages/werkzeug/local.py", line 306, in _get_current_object
    return self.__local()
  File "/Users/aclinton/Documents/environments/caff_env/lib/python3.9/site-packages/flask/globals.py", line 52, in _find_app
    raise RuntimeError(_app_ctx_err_msg)
RuntimeError: Working outside of application context.
希夫

在此处导入模块时from caffeine.routes.bp_bundle import bundle,将执行最外层的全局语句。现在,该应用程序尚未运行,该模块正在尝试使用current_app将其放在Flask路线中,它将起作用。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

RuntimeError:在 Python 中使用 Celery 和 Flask 在应用程序上下文之外工作

在应用程序上下文之外工作-Flask

异步使用Flask-Mail会导致“ RuntimeError:在应用程序上下文之外工作”

使用Python Flask应用程序“ RuntimeError:在应用程序上下文之外工作”(使用调度程序发送gmail)

尝试将所有表放入Flask中,RuntimeError:找不到应用程序。在视图函数内部工作或推送应用程序上下文

RQ 作业的 Flask 上下文(运行时错误:在应用程序之外工作)

Flask,Python和Socket.io:多线程应用程序给了我“ RuntimeError:在请求上下文之外工作”

RuntimeError:在应用程序上下文之外工作

Flask Babel RuntimeError:在请求上下文之外工作

从Flask应用程序中的外部应用程序上下文访问应用程序对象

在Flask的应用程序上下文中保持py2neo连接

在Flask框架中将应用程序上下文传递给celery

配置模块的“ RuntimeError:在应用程序上下文之外工作”

Flask启动新线程-RuntimeError:在请求上下文之外工作

将 python flask 应用程序上下文传递给 rq 作业的正确方法

Flask.url_for()错误:尝试在未推送应用程序上下文的情况下生成URL

RuntimeError:尝试从另一个Python脚本向Flask应用发送POST请求时在请求上下文之外工作

RuntimeError:在应用程序上下文之外工作。与app.app_context()无法解决问题

使用py.test进行单元测试时,“ RuntimeError:在应用程序上下文之外工作”

单元测试将生成“ RuntimeError:在应用程序上下文之外工作”。与模拟4.0.0

Python + Flask 在请求上下文之外工作

使用Flask将机器学习模型部署为REST API。错误:RuntimeError:在请求上下文之外工作

烧瓶WTForm:“在应用程序上下文之外工作”

Pytest RuntimeError:找不到应用程序。在视图函数内部工作或推送应用程序上下文

sqlalchemy的Flask应用上下文

使用应用程序工厂模式时,如何从嵌入式Dash应用程序中访问Flask应用程序的上下文?

Flask-APScheduler作业中的查询模型会引发应用上下文RuntimeError

在应用程序上下文之外工作;FlaskClient对象没有属性“ app_context”

使用Python远程API在Google App Engine中“在应用程序上下文之外工作”