簡體   English   中英

Flask API沒有突然收到請求

[英]Flask API not receiving requests all of a sudden

我正在嘗試在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找到了答案- CLOSE_WAIT中的套接字 ,利用Tornado http://flask.pocoo.org/docs/0.10/deploying/wsgi-standalone/#tornado來構建非阻塞網絡服務器。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM