질문:
Heroku에 GoLang 앱 배포 GoDep 지원을 사용하면 빌드가 성공하지만 엔드포인트에 액세스하면 "응용 프로그램 오류"가 반환됩니다. 앱은 localhost의 포트 9000에서 실행되지만 Grace.Serve는 다른 포트에서 수신 대기하는 것 같습니다.
Heroku 로그 출력:
2019-07-08T05:03:48.131507+00:00 heroku[web.1]: Error R10 (Boot timeout) -> Web process failed to bind to $PORT within 60 seconds of launch
애플리케이션 코드:
err := grace.Serve(":9000", context.ClearHandler(http.DefaultServeMux))
답변:
문제는 애플리케이션이 명시적으로 웹 서버를 포트 9000에 바인딩하고 있으며 이는 Heroku에 할당된 포트와 충돌한다는 것입니다. Heroku는 PORT 환경 변수를 통해 동적 포트를 할당합니다.
이 문제를 해결하려면 애플리케이션이 포트 9000을 하드코딩하는 대신 PORT 환경 변수를 기반으로 포트를 동적으로 할당해야 합니다.
개정 애플리케이션 코드:
port := os.Getenv("PORT") if port == "" { port = "9000" // Default port if not specified } err := grace.Serve(":" + port, context.ClearHandler(http.DefaultServeMux))
위 내용은 내 GoLang Heroku 앱이 성공적인 빌드에도 불구하고 '응용 프로그램 오류'를 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!