gpt4 book ai didi

python - flask - 运行时错误 : Working outside of application context

转载 作者:行者123 更新时间:2023-12-04 08:35:07 24 4
gpt4 key购买 nike

我收到“运行时错误:在应用程序上下文之外工作。”我的 flask 应用程序出错,我很难理解原因。我试图推送应用程序上下文,但这似乎对我不起作用,我可能只是对如何访问“current_app”有点困惑,以便我可以从其他类和蓝图写入我的记录器。我的代码如下:
运行.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)
初始化.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/python@3.9/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 的路由中,它就可以工作了。

关于python - flask - 运行时错误 : Working outside of application context,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64837678/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com