Flask API不会突然收到请求

时间:2015-12-13 08:38:42

标签: python azure flask sqlalchemy flask-restful

我正在尝试在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请求。如果有一些数据库错误,那么我收到了500错误消息,但请求甚至没有首先进入API。

3)如果我在本地调用API,那么问题仍然存在。

4)如果我为端口5000执行netstat(运行我的烧瓶API),我得到以下内容:

enter image description here

出于某种原因,我认为它没有关闭套接字连接。我得到了很多&#34; CLOSE_WAIT&#34;。这是导致问题的原因吗?如何在我的代码中修复此问题?

1 个答案:

答案 0 :(得分:0)

通常,当你获得很多CLOSE_WAIT状态时,这意味着有未连接的套接字连接。似乎您在Flask / Werkzeug - sockets stuck in CLOSE_WAIT找到了答案,它利用Tornado http://flask.pocoo.org/docs/0.10/deploying/wsgi-standalone/#tornado构建了一个非阻塞的Web服务器。