シンプルなflaskアプリを作成しようとしています:
from flask import Flask
app = Flask(__name__)
if __name__ == '__main__':
app.run()
しかし、デバッグを追加すると:
FLASK_APP = run.py
FLASK_ENV = development
FLASK_DEBUG = 1
次のエラーが表示されました。
ValueError:シグナルはメインスレッドでのみ動作します
ここで完全なスタックトレース
FLASK_APP = run.py
FLASK_ENV = development
FLASK_DEBUG = 1
In folder c:/MyProjectPath/api
c:\MyProjectPath\api\venv\Scripts\python.exe -m flask run
* Serving Flask-SocketIO app "run.py"
* Forcing debug mode on
* Restarting with stat
* Debugger is active!
* Debugger PIN: 283-122-745
Exception in thread Thread-1:
Traceback (most recent call last):
File "c:\appdata\local\programs\python\python37\Lib\threading.py", line 917, in _bootstrap_inner
self.run()
File "c:\appdata\local\programs\python\python37\Lib\threading.py", line 865, in run
self._target(*self._args, **self._kwargs)
File "c:\MyProjectPath\api\venv\lib\site-packages\flask_socketio\cli.py", line 59, in run_server
return run_command()
File "c:\MyProjectPath\api\venv\lib\site-packages\click\core.py", line 764, in __call__
return self.main(*args, **kwargs)
File "c:\MyProjectPath\api\venv\lib\site-packages\click\core.py", line 717, in main
rv = self.invoke(ctx)
File "c:\MyProjectPath\api\venv\lib\site-packages\click\core.py", line 956, in invoke
return ctx.invoke(self.callback, **ctx.params)
File "c:\MyProjectPath\api\venv\lib\site-packages\click\core.py", line 555, in invoke
return callback(*args, **kwargs)
File "c:\MyProjectPath\api\venv\lib\site-packages\click\decorators.py", line 64, in new_func
return ctx.invoke(f, obj, *args, **kwargs)
File "c:\MyProjectPath\api\venv\lib\site-packages\click\core.py", line 555, in invoke
return callback(*args, **kwargs)
File "c:\MyProjectPath\api\venv\lib\site-packages\flask\cli.py", line 771, in run_command
threaded=with_threads, ssl_context=cert)
File "c:\MyProjectPath\api\venv\lib\site-packages\werkzeug\serving.py", line 812, in run_simple
reloader_type)
File "c:\MyProjectPath\api\venv\lib\site-packages\werkzeug\_reloader.py", line 267, in run_with_reloader
signal.signal(signal.SIGTERM, lambda *args: sys.exit(0))
File "c:\appdata\local\programs\python\python37\Lib\signal.py", line 47, in signal
handler = _signal.signal(_enum_to_int(signalnum), _enum_to_int(handler))
ValueError: signal only works in main thread
直面している問題は、flask run
コマンドを置き換えるFlask-SocketIOパッケージのバグに関係しています。このため、Flask-SocketIOは、インポートしなくても常に使用されます。いくつかの解決策があります。
flask run
は使用しないで、プログラムのメインファイルを実行しますflask run --no-reload
Flask-SocketIOバグへの参照: issue 817
Githubの@ AkshayKumar007 answer のおかげで問題を解決しました。それが私にとって最も便利な解決策でした。
皆さん、私も同じ問題に直面していました。要約すると、socket-ioを使用している場合は、flaskを実行しないでください。まず、追加
if __name__ == "__main__": socketio.run(app)
アプリケーションの最後。実行するには
python3 __init__.py
お役に立てば幸いです。