python – Flask API没有突然收到请求
发布时间:2020-12-20 13:08:51 所属栏目:Python 来源:网络整理
导读:我正在尝试在Flask中创建REST API.事情是它运行了好几天,然后突然间它完全收到请求.忘记不回应请求;它只是在第一时间没有收到任何请求.这是我的脚本: from flask import Flask,jsonifyfrom flask_restful import Resource,Apifrom flask_restful import req
我正在尝试在Flask中创建REST API.事情是它运行了好几天,然后突然间它完全收到请求.忘记不回应请求;它只是在第一时间没有收到任何请求.这是我的脚本:
from flask import Flask,jsonify from flask_restful import Resource,Api from flask_restful import reqparse from sqlalchemy import create_engine from flask.ext.httpauth import HTTPBasicAuth from flask.ext.cors import CORS conn_string = "mssql+pyodbc://x" e = create_engine(conn_string) auth = HTTPBasicAuth() @auth.get_password def get_password(username): if username == 'x': return 'x' return None app = Flask(__name__) cors = CORS(app) api = Api(app) class Report(Resource): decorators = [auth.login_required] def get(self): parser = reqparse.RequestParser() parser.add_argument('start',type = str) parser.add_argument('end',type = str) args = parser.parse_args() conn = e.connect() stat = """ select a,b from report where c < ? and d > ? """ query = conn.execute(stat,[args['start'],args['end']]) json_dict = [] for i in query.cursor.fetchall(): res = {'aa': i[0],'bb':i[1]} json_dict.append(res) conn.close() return jsonify(results=json_dict) api.add_resource(Report,'/report') if __name__ == '__main__': app.run(host='0.0.0.0') 我试图调试这个问题,以下是我的观察: 1)Flask API在端口5000上运行,当我在端口5000上移动VM时,我能够连接,这意味着该进程实际上正在VM上运行. 2)在检查我的日志时,API甚至都没有收到GET请求.如果有一些db错误,那么我会收到500错误消息,但请求甚至没有首先进入API. 3)如果我在本地调用API,那么问题仍然存在. 4)如果我为端口5000(运行我的烧瓶API)执行netstat,我得到以下内容: 出于某种原因,我认为它没有关闭套接字连接.我得到了很多“CLOSE_WAIT”.这是导致问题的原因吗?如何在我的代码中修复此问题? 解决方法
通常,当您获得大量CLOSE_WAIT状态时,表示存在未关闭的套接字连接.而且似乎你已经在
Flask / Werkzeug – sockets stuck in CLOSE_WAIT找到了答案,它利用Tornado
http://flask.pocoo.org/docs/0.10/deploying/wsgi-standalone/#tornado来构建一个无阻塞的Web服务器.
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |