nginx+uwsgi+flaskを用いてpythonのウェブアプリケーションを構築しています。
それの仕様上、サーバー内部にて自分自身にリクエストを送ることがあるのですが、その前後で極めて処理が遅延する自体となっており、もしかしたら単一のリクエストしか処理できていない、マルチスレッドで処理できていないかと思い、以下のコードで試してみました。
[main.py]
python
1import * 2 3app = Flask(__name__) 4CORS(app) 5 6@app.route('/Test', methods=['GET']) 7def tests(): 8 print("test") 9 return "test" 10 11@app.route('/Test2loop', methods=['GET']) 12def testloop(): 13 i = 1 14 while True: 15 i =+ 1 16 if i == 100000: 17 i = 0 18 return "" 19 20if __name__ == "__main__": 21 app.run() 22
このコードを、以下のuwsgiの設定で実行したときには、curlにて/Test2loopにリクエストを四回送るとそれ移行は/Testにアクセスしても何も返さなくなりました。
[uwsgi.ini]
uwsgi
1[uwsgi] 2wsgi-file = /app/main.py 3callable = app 4master = true 5processes = 4 6threads = 1 7socket = :3031 8chmod-socket = 777 9vacuum = true 10die-on-term = true 11py-autoreload = 1 12thunder-lock = true
念の為processes=100 threads=200
に変更して試してみたところ、
少なくとも20回ほど/Test2loopにリクエストを送っても/Testに正常にアクセスできました。
そのため、この場合processes,threadsに記載した回数しか並列化されないようですが、これは一般的な動作なのですか?
また、リクエスト毎にスレッドを生成するような処理は可能なのですか?
あなたの回答
tips
プレビュー