[英]Flask: code inside a @app.route fails (runs forever) when called a second time
我在Flask路由中执行了一些Python metapy代码,该路由在第一次调用时运行得很好(即,用户在应用程序启动后提交了一个表单),但是在第二次运行时并没有终止(例如,表单在应用程序启动后第二次提交)。
正是:
@app.route('/search', methods=['POST'])
def searchPageResults():
form = SearchForm(request.form)
import metapy
idx = metapy.index.make_inverted_index(os.path.abspath("search/config.toml"))
ranker = metapy.index.OkapiBM25()
query = metapy.index.Document()
query.content("auto")
for result in ranker.score(idx, query):
print(result)
return render_template('SearchPage.html', form=form)
如果我在Flask外部运行该方法,则该方法内部的代码段将运行良好(无论调用多少次)。 仅在用@ app.route(...)装饰的方法内部,它似乎只能运行一次。 具体来说:ranker.score(...)函数是永远运行的函数。 由于代码在烧瓶外部运行良好,因此我认为我不了解在后台发生了Flask特定的事情。
到目前为止,我尝试了什么(但没有帮助):
Flask是否有特定的东西可以解释这种行为?
----更新:附加信息----- config.toml
index = "idx"
corpus = "line.toml"
dataset = "data"
prefix = "."
stop-words = "search/german-stopwords.txt"
start-exceptions = "search/sentence-start-exceptions.txt"
end-exceptions = "search/sentence-end-exceptions.txt"
function-words = "search/function-words.txt"
punctuation = "search/sentence-punctuation.txt"
[[analyzers]]
method = "ngram-word"
ngram = 1
filter = [{type = "icu-tokenizer"}, {type = "lowercase"}]
如前所述,该行为仅在该Flask路由的第二次调用之后发生。 在本地,一切正常(使用完全相同的数据集和config.toml)
更新:MetaPy Flask演示应用程序中的行为相同我在MetaPy演示应用程序中的行为相同: https : //github.com/meta-toolkit/metapy-demos 。 (唯一的区别是由于可用性,我需要采用一些包的requirements.txt中指定的较新版本)。
解决了。 Flask集成Web服务器出现问题。 一旦部署到另一个Web服务器,问题就解决了。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.