Heroku에 Golang 앱 배포: 빌드는 성공했지만 애플리케이션 오류
Go 종속성 지원을 사용하여 Heroku에 Golang 애플리케이션을 배포할 때 엔드포인트에 액세스하려고 할 때 "애플리케이션 오류"가 발생할 수 있습니다. 이 문제는 웹 서버가 Heroku의 적절한 포트에 제대로 바인딩되지 않았을 때 발생합니다.
애플리케이션 로그 메시지에 다음 오류가 표시됩니다.
Error R10 (Boot timeout) -> Web process failed to bind to $PORT within 60 seconds of launch
원인:
이 문제는 다음에서 지정한 포트에 바인딩하는 대신 하드코딩된 포트(9000)에서 서버를 시작하려고 시도하여 발생합니다. Heroku의 $PORT 환경 변수.
해결책:
이 문제를 해결하려면 $PORT 환경 변수를 사용하여 올바른 포트에서 서버를 시작하십시오. 기존 코드를 바꾸세요:
err := grace.Serve(":9000", context.ClearHandler(http.DefaultServeMux))
다음으로:
port := os.Getenv("PORT") if port == "" { port = "9000" // Default port if not specified } err := grace.Serve(":" + port, context.ClearHandler(http.DefaultServeMux))
이 변경으로 인해 서버가 Heroku가 지정한 포트에 올바르게 바인딩되어 "애플리케이션 오류" 문제가 해결됩니다.
위 내용은 Heroku의 내 Golang 앱에 성공적인 빌드 후 '응용 프로그램 오류'가 표시되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!