Microsoft MVP성태의 닷넷 이야기
오류 유형: 295. HTTP Error 503. The service is unavailable. [링크 복사], [링크+제목 복사],
조회: 20185
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

HTTP Error 503. The service is unavailable.

500번대 에러가 벌써 이렇게 쌓였군요. ^^

IIS 500 Internal Server Error - Skydrive에 공유된 경우
; https://www.sysnet.pe.kr/2/0/1612

[COM+] CreateObject 와 HTTP 500 - Internal server error
; https://www.sysnet.pe.kr/2/0/242

ASP.NET 웹 사이트를 IIS 7 이상의 환경에서 호스팅할 때 500 오류 발생
; https://www.sysnet.pe.kr/2/0/1563

웹 사이트의 모든 정적 컨텐츠 요청에 대해 "Internal Server Error" 응답
; https://www.sysnet.pe.kr/2/0/1538

IIS - 500.19 오류
; https://www.sysnet.pe.kr/2/0/976

오늘은 503 에러에 대해 사례 2개를 추가하려고 합니다. "http://localhost/"로 방문했더니 다음과 같은 오류 화면을 보았는데요.

Service Unavailable

HTTP Error 503. The service is unavailable.

이 때의 이벤트 로그를 보면 다음과 같은 항목이 있습니다.

Log Name:      System
Source:        Microsoft-Windows-WAS
Date:          2015-07-01 오전 12:55:09
Event ID:      5201
Task Category: None
Level:         Warning
Keywords:      Classic
User:          N/A
Computer:      thetest
Description:
A process serving application pool 'DefaultAppPool' reported a failure during application preloading or service loading. The process id was '21644'.  Please ensure that all application preload or service settings in the application pool are configured properly.  The data field contains the error number.

메시지에 따라, 이 원인은 "serviceAutoStartEnabled, serviceAutoStartProvider" 옵션을 구성했으나,

IIS 7.5 부터 지원되는 웹 사이트 자동 시작 모드
; https://www.sysnet.pe.kr/2/0/1367

serviceAutoStartProvider 옵션에 지정된 닷넷 어셈블리를 로드하지 못한 경우에 발생한 것입니다. 따라서 해당 어셈블리를 설치하든가 그 옵션을 "%WINDIR%\system32\inetsrv\config\applicationHost.config" 파일로부터 <sites> 노드 내에 pre-load를 적용했던 웹 사이트를 찾아내 serviceAutoStartEnabled, serviceAutoStartProvider를 삭제해야 합니다.

...[생략]...
    <sites>
        ...[생략]...
        <site name="AutoSite" id="5">
                <application path="/" applicationPool="AutoSite" 
                    serviceAutoStartEnabled="true" 
                    serviceAutoStartProvider="PreWarmupApp"
                    >
                    <virtualDirectory path="/" physicalPath="D:\WebApplication1\WebApplication1" />
                </application>
                <bindings>
                    <binding protocol="http" bindingInformation="*:80:" />
                </bindings>
        </site>
        ...[생략]...
    </sites>
...[생략]...




또 하나의 경우가 있는데요. 이번에는 이벤트 로그에 다음과 같은 항목이 남아 있었습니다.

Log Name:      System
Source:        Microsoft-Windows-WAS
Date:          2015-07-01 오전 12:58:38
Event ID:      5022
Task Category: None
Level:         Warning
Keywords:      Classic
User:          N/A
Computer:      testtest
Description:
The Windows Process Activation Service failed to create a worker process for the application pool 'test'. The data field contains the error number.

메시지로부터 원인을 유추할 수는 없었는데요. 조사 결과, 해당 "test" AppPool의 계정이 "ApplicationPoolIdentity"로 설정되어 있는데, 정작 "test" AppPool에서 돌아갈 웹 애플리케이션의 '루트 디렉터리' 경로에는 권한이 없는 경우에 이런 현상이 발생했습니다.

테스트를 위해 간단하게 해당 AppPool의 계정을 "LocalSystem"으로 설정해 보면 바로 확인할 수 있습니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/25/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2015-07-03 06시00분
권한이 없는 경우, 때로는 다음의 오류도 발생하는 경우가 있음.

System.InvalidOperationException: Failed to map the path '...'.

정성태

... 46  47  48  49  [50]  51  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12385정성태10/28/20208815오류 유형: 673. openssl - req: No value provided for Subject Attribute CN, skipped
12384정성태10/27/202010065오류 유형: 672. AllowPartiallyTrustedCallers 특성이 적용된 어셈블리의 struct 멤버 메서드를 재정의하면 System.Security.VerificationException 예외 발생
12383정성태10/27/202011008.NET Framework: 956. C# 9.0 - (7) 패턴 일치 개선 사항(Pattern matching enhancements) [3]파일 다운로드1
12382정성태10/26/20208622오류 유형: 671. dotnet build - The local source '...' doesn't exist
12381정성태10/26/202010303VC++: 137. C++ stl map의 사용자 정의 타입을 key로 사용하는 방법 [1]파일 다운로드1
12380정성태10/26/20207771오류 유형: 670. Visual Studio - Squash_FailureCommitsReset
12379정성태10/21/202010749.NET Framework: 955. .NET 메서드의 Signature 바이트 코드 분석 [1]파일 다운로드2
12378정성태10/15/202010214.NET Framework: 954. C# - x86/x64 환경에 따라 달라지는 P/Invoke 함수의 export 이름파일 다운로드1
12377정성태10/15/202011538디버깅 기술: 172. windbg - 파일 열기 시점에 bp를 걸어 파일명 알아내는 방법(Managed/Unmanaged)
12376정성태10/15/20208271오류 유형: 669. windbg - sos의 name2ee 명령어 실행 시 "Failed to request module list." 오류
12375정성태10/15/20209590Windows: 177. 윈도우 탐색기에서 띄우는 cmd.exe 창의 디렉터리 구분 문자가 'Yen(&#0165;)' 기호로 나오는 경우 [1]
12374정성태10/14/202014195.NET Framework: 953. C# 9.0 - (6) 함수 포인터(Function pointers) [1]파일 다운로드2
12373정성태10/14/20209471.NET Framework: 952. OpCodes.Box와 관련해 IL 형식으로 직접 코딩 시 유의할 점
12372정성태10/13/202011361.NET Framework: 951. C# 9.0 - (5) 로컬 함수에 특성 지정 가능(Attributes on local functions)파일 다운로드1
12371정성태10/13/202010086개발 환경 구성: 519. Visual Studio의 Ctrl+Shift+U (Edit.MakeUppercase) 단축키가 동작하지 않는 경우
12370정성태10/13/202010951Linux: 33. Linux - nmcli를 이용한 고정 IP 설정
12369정성태10/12/202013758Windows: 176. Raymond Chen이 한글날에 밝히는 윈도우의 한글 자모 분리 현상 [3]
12368정성태10/12/20209820오류 유형: 668. VSIX 확장 빌드 - The "GetDeploymentPathFromVsixManifest" task failed unexpectedly.
12367정성태10/12/202022579오류 유형: 667. Ubuntu - Temporary failure resolving 'kr.archive.ubuntu.com' [2]
12366정성태10/12/202011621.NET Framework: 950. C# 9.0 - (4) 원시 크기 정수(Native ints) [1]파일 다운로드1
12365정성태10/12/202010549.NET Framework: 949. C# 9.0 - (3) 람다 메서드의 매개 변수 무시(Lambda discard parameters)파일 다운로드1
12364정성태10/11/202011757.NET Framework: 948. C# 9.0 - (2) localsinit 플래그 내보내기 무시(Suppress emitting localsinit flag)파일 다운로드1
12363정성태10/11/202012648.NET Framework: 947. C# 9.0 - (1) 대상으로 형식화된 new 식(Target-typed new expressions) [2]파일 다운로드1
12362정성태10/11/20209454VS.NET IDE: 151. Visual Studio 2019에 .NET 5 rc/preview 적용하는 방법
12361정성태10/11/202011053.NET Framework: 946. C# 9.0을 위한 개발 환경 구성
12360정성태10/8/20208274오류 유형: 666. The type or namespace name '...' does not exist in the namespace 'Microsoft.VisualStudio.TestTools' (are you missing an assembly reference?)
... 46  47  48  49  [50]  51  52  53  54  55  56  57  58  59  60  ...