>백엔드 개발 >파이썬 튜토리얼 >내 Flask 개발 서버가 시작 메시지를 두 번 인쇄하는 이유는 무엇입니까?

내 Flask 개발 서버가 시작 메시지를 두 번 인쇄하는 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-20 01:04:08301검색

Why Does My Flask Development Server Print Startup Messages Twice?

두 번 실행되는 Flask 개발 서버

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.