app.run() 메서드를 사용하여 Flask 애플리케이션을 실행할 때 서버가 다시 시작됨을 나타내는 인쇄 문이 나타나는 상황이 발생할 수 있습니다. 두 번 나타납니다. 이 동작은 Werkzeug 리로더로 인해 발생할 수 있습니다.
Flask 개발 서버를 구동하는 기본 라이브러리인 Werkzeug는 하위 프로세스 메커니즘을 사용하여 코드 변경 및 자동 재시작을 용이하게 합니다. app.run()을 실행하면 리로더가 코드를 지속적으로 모니터링하는 하위 프로세스를 생성합니다.
이를 설명하기 위해 Werkzeug의 restart_with_reloader() 함수를 분석해 보겠습니다. 이 함수는 subprocess.call()을 호출하여 스크립트를 다시 실행하고 하위 프로세스를 생성합니다. 결과적으로 print 문을 두 번 관찰하게 됩니다.
이 중복을 제거하려면 리로더를 비활성화하는 것이 좋습니다. app.run()에서 use_reloader를 False로 설정하여 이를 달성할 수 있습니다:
app.run(port=4004, debug=config.DEBUG, host='0.0.0.0', use_reloader=False)
또는 플라스크 실행 명령을 사용할 때 리로더를 비활성화할 수 있습니다:
FLASK_DEBUG=1 flask run --no-reload
다른 옵션 werkzeug.serving.is_running_from_reloader() 함수를 활용하여 리로더의 하위 프로세스입니다.
그러나 모듈 전역이 필요한 경우 @app.before_first_request 데코레이터를 선택하세요. 이 데코레이터를 사용하면 다시 로드할 때마다 첫 번째 요청이 수신될 때 한 번 호출될 함수를 지정할 수 있습니다.
@app.before_first_request def before_first_request(): print(f"########### Restarted, first request @ {datetime.utcnow()} ############")
요청 처리를 위해 분기 또는 하위 프로세스를 사용하는 전체 WSGI 서버에서 실행할 때 주의하세요. , 새로 생성된 각 하위 프로세스에 대해 before_first_request 핸들러가 호출될 수 있습니다.
위 내용은 내 Flask 개발 서버가 시작 메시지를 두 번 인쇄하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!