python – Flask API没有突然收到请求
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python – Flask API没有突然收到请求,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1870字,纯文字阅读大概需要3分钟。
内容图文
我正在尝试在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服务器.
内容总结
以上是互联网集市为您收集整理的python – Flask API没有突然收到请求全部内容,希望文章能够帮你解决python – Flask API没有突然收到请求所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。