Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 33.1. Enable rapid-fail protection 상황 재현 방법 [링크 복사], [링크+제목 복사],
조회: 20575
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
부모글 보이기/감추기

이미 아시는 분도 계시겠지만.

IIS는 문제 있는 작업자 프로세스가 무한정 recycling이 되는 것을 방지합니다.
바로 그 기능이 "오류 급증 시 보호 기능 사용" 인 것이죠.

5분(기본값) 안에 작업자 프로세스가 한계상황에 직면하여 5번(기본값) recycling이 되었다면 문제가 있는 프로세스라고 판단하는 것입니다.

거의 그런 상황을 내는 응용 프로그램이 만들어질리는 없을 거라 보이지만. ^^

재미있게 한번 재현을 해본다면.

1. Web Application을 제작.
2. 테스트 WebForm1.aspx를 만들고, 코딩은 할 필요 없음.
3. http://localhost/WebApp/WebForm1.aspx라고 IE로 네비게이션.
4. 작업 관리자에서 w3wp.exe를 강제 종료.
5. 위의 3번과 4번 작업을 5분 안에 5번 만 반복합니다.
6. 이제 http://localhost/WebApp/WebForm1.aspx로 네비게이션을 하려고 하면, 응답이 바로 떨어집니다. "Service Unavailable"이라고 대문짝만하게. 이후로, 아무리(무한정 기다려 본적은 없음) 기다려도 해당 AppPool은 IIS로부터 완전히 격리가 되어 활동하지 않게 됩니다. 다시 서비스를 하기 위해서는, IIS를 재시작 시켜야 합니다.

저 같은 경우, 가끔 "작업자 프로세스" 자체에 대한 테스트 때문에 일부러 "작업관리자"를 통해서 w3wp.exe를 죽이는 데요. 그런 경우 가끔 "Service Unavailable" 상황까지 가게 됩니다. ^^; 이럴 땐.... IIS reset의 귀찮음이 싫은 분이시라면, Enable rapid-fail protection 옵션을 끄고 테스트 하시면 됩니다.








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

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

비밀번호

댓글 작성자
 




... [16]  17  18  19  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13543정성태1/30/20249799Windows: 254. Windows - 기본 사용 중인 5357 포트 비활성화는 방법
13542정성태1/30/20248885오류 유형: 893. Visual Studio - Web Application을 실행하지 못하는 IISExpress - 두 번째 이야기
13541정성태1/29/20249649VS.NET IDE: 188. launchSettings.json의 useSSL 옵션
13540정성태1/29/20249561Linux: 69. 리눅스 - "Docker Desktop for Windows" Container 환경에서 IPv6 Loopback Address 바인딩 오류
13539정성태1/26/20249384개발 환경 구성: 703. Visual Studio - launchSettings.json을 이용한 HTTP/HTTPS 포트 바인딩
13538정성태1/25/20249972닷넷: 2211. C# - NonGC(FOH) 영역에 .NET 개체를 생성파일 다운로드1
13537정성태1/24/202410766닷넷: 2210. C# - Native 메모리에 .NET 개체를 생성파일 다운로드1
13536정성태1/23/202410369닷넷: 2209. .NET 8 - NonGC Heap / FOH (Frozen Object Heap) [1]
13535정성태1/22/202410827닷넷: 2208. C# - GCHandle 구조체의 메모리 분석
13534정성태1/21/202410198닷넷: 2207. C# - SQL Server DB를 bacpac으로 Export/Import파일 다운로드1
13533정성태1/18/202410176닷넷: 2206. C# - TCP KeepAlive의 서버 측 구현파일 다운로드1
13532정성태1/17/202410240닷넷: 2205. C# - SuperSimpleTcp 사용 시 주의할 점파일 다운로드1
13531정성태1/16/202410620닷넷: 2204. C# - TCP KeepAlive에 새로 추가된 Retry 옵션파일 다운로드1
13530정성태1/15/20249896닷넷: 2203. C# - Python과의 AES 암호화 연동파일 다운로드1
13529정성태1/15/202410085닷넷: 2202. C# - PublishAot의 glibc에 대한 정적 링킹하는 방법
13528정성태1/14/202410267Linux: 68. busybox 컨테이너에서 실행 가능한 C++, Go 프로그램 빌드
13527정성태1/14/202410369오류 유형: 892. Visual Studio - Failed to launch debug adapter. Additional information may be available in the output window.
13526정성태1/14/202410685닷넷: 2201. C# - Facebook 연동 / 사용자 탈퇴 처리 방법
13525정성태1/13/20249817오류 유형: 891. Visual Studio - Web Application을 실행하지 못하는 IISExpress
13524정성태1/12/20249837오류 유형: 890. 한국투자증권 KIS Developers OpenAPI - GW라우팅 중 오류가 발생했습니다.
13523정성태1/12/20249855오류 유형: 889. Visual Studio - error : A project with that name is already opened in the solution.
13522정성태1/11/202410693닷넷: 2200. C# - HttpClient.PostAsJsonAsync 호출 시 "Transfer-Encoding: chunked" 대신 "Content-Length" 헤더 처리
13521정성태1/11/202410314닷넷: 2199. C# - 한국투자증권 KIS Developers OpenAPI의 WebSocket Ping, Pong 처리
13520정성태1/10/202410018오류 유형: 888. C# - Unable to resolve service for type 'Microsoft.Extensions.ObjectPool.ObjectPool`....' [1]
13519정성태1/10/20249688닷넷: 2198. C# - Reflection을 이용한 ClientWebSocket의 Ping 호출파일 다운로드1
13518정성태1/9/202410464닷넷: 2197. C# - ClientWebSocket의 Ping, Pong 처리
... [16]  17  18  19  20  21  22  23  24  25  26  27  28  29  30  ...