성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] Working with Rust Libraries from C#...
[정성태] Detecting blocking calls using asyn...
[정성태] 아쉽게도, 커뮤니티는 아니고 개인 블로그입니다. ^^
[정성태] 질문이 잘 이해가 안 됩니다. 우선, 해당 소스코드에서 ILis...
[양승조
] var대신 dinamic으로 선언해서 해결은 했습니다. 맞는 해...
[양승조
] 또 막혔습니다. ㅠㅠ var list = props[i].Ge...
[양승조
] 아. 감사합니다. 어제는 안됐던것 같은데....정신을 차려야겠네...
[정성태] "props[i].GetValue(props[i])" 코드에서 ...
[정성태] 저렇게 조각 코드 말고, 실제로 재현이 되는 예제 프로젝트를 압...
[정성태] Modules 창(Ctrl+Shift+U)을 띄워서, 해당 Op...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <h1 style='font-family: Malgun Gothic, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>ASP.NET - EcbGetUnicodeServerVariables 코드에서 System.AccessViolationException 예외 발생</h1> <p> <br /> 하드 디스크가 날아가서 테스트 환경을 다시 구성하는데다,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > RAID 1 구성 시 하드 디스크 장애 발생 해결에 대한 경험담 ; <a target='tab' href='http://www.sysnet.pe.kr/2/0/1266'>http://www.sysnet.pe.kr/2/0/1266</a> </pre> <br /> 공교롭게도 동시에 IA64 지원이 추가되면서 코드가 memcpy로 변경되는 차이가 발생했습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > 아이태니엄(IA64: Itanium)에서 겪은 C++ 포인터 연산 문제 ; <a target='tab' href='http://www.sysnet.pe.kr/2/0/1265'>http://www.sysnet.pe.kr/2/0/1265</a> </pre> <br /> 그런데, 새롭게 구성한 Windows 2003 x86 ASP.NET에서 예전에는 없었던 다음과 같은 오류가 발생했습니다. (이벤트 로그에 남은 내용입니다.)<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > An unhandled exception occurred and the process was terminated. Application ID: /LM/W3SVC/1056073434/Root Process ID: 2548 <span style='color: blue; font-weight: bold'>Exception: System.AccessViolationException Message: Attempted to read or write protected memory. This is often an indication that other memory is corrupt. </span> StackTrace: at <span style='color: blue; font-weight: bold'>System.Web.UnsafeNativeMethods.EcbGetUnicodeServerVariables</span>(IntPtr pECB, IntPtr buffer, Int32 bufferSizeInChars, Int32[] serverVarLengths, Int32 serverVarCount, Int32 startIndex, Int32& requiredSize) at System.Web.Hosting.ISAPIWorkerRequestInProcForIIS6.GetAdditionalServerVariables() at System.Web.Hosting.ISAPIWorkerRequestInProc.GetAdditionalServerVar(Int32 index) at System.Web.Hosting.ISAPIWorkerRequestInProc.GetServerVariable(String name) at System.Web.Hosting.ISAPIWorkerRequest.GetRemoteAddress() at System.Web.HttpRequest.get_UserHostAddress() at System.ServiceModel.Channels.RemoteEndpointMessageProperty.Initialize(Boolean getHostedPort) at System.ServiceModel.Channels.RemoteEndpointMessageProperty.get_Address() ...[생략]... at System.ServiceModel.Channels.IOThreadScheduler.CriticalHelper.ScheduledOverlapped.IOCallback(UInt32 errorCode, UInt32 numBytes, NativeOverlapped* nativeOverlapped) at System.ServiceModel.Diagnostics.Utility.IOCompletionThunk.UnhandledExceptionFrame(UInt32 error, UInt32 bytesRead, NativeOverlapped* nativeOverlapped) at System.Threading._IOCompletionCallback.PerformIOCompletionCallback(UInt32 errorCode, UInt32 numBytes, NativeOverlapped* pOVERLAP) For more information, see Help and Support Center at http://go.microsoft.com/fwlink/events.asp. </pre> <br /> AV 예외가 발생한 이후 w3wp.exe는 여지없이 비정상 종료가 되었음을 알 수 있고,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > EventType clr20r3, P1 w3wp.exe, P2 6.0.3790.3959, P3 45d6968e, P4 system.web, P5 2.0.0.0, P6 4c9a2192, P7 228d, P8 39, P9 <span style='color: blue; font-weight: bold'>system.accessviolationexception</span>, P10 NIL. For more information(<a target='tab' href='http://www.sysnet.pe.kr/2/0/595'>1</a>, <a target='tab' href='http://www.sysnet.pe.kr/2/0/1096'>2</a>), see Help and Support Center at http://go.microsoft.com/fwlink/events.asp. </pre> <br /> AppPool에 지정된 "Rapid-fail protection" 정책에 의해 (기본값) 5분 내에 5번의 w3wp.exe 비정상 종료 현상이 발생하면 IIS는 해당 서비스를 "Service Unavailable"로 판단하고 더 이상의 recycle을 하지 않습니다.<br /> <br /> 예전에는 이런 경우가 한 번도 없었다가, IA64 코드 변경 이후 나타난 것 같아서 매우 찜찜했는데요. 다행히 ^^; 제니퍼 제품을 설치하지 않은 상태에서도 이런 상황이 재현이 되어서 자신감(!)을 가지고 다른 환경적인 차이를 고민해 봤습니다.<br /> <br /> 일단, .NET 3.5 및 SP1까지 업데이트 한 후에 발생한 상황이라서 별다른 기대를 하지 않고 '윈도우 업데이트'를 살펴보았는데, 다음과 같은 패치가 아직 설치되지 않고 있었습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Microsoft .NET Framework 3.5 Service Pack 1 and .NET Framework 3.5 Family Update for .NET versions 2.0 through 3.5 (KB951847) x86 ; <a target='tab' href='http://www.update.microsoft.com/windowsupdate/v6/default.aspx?ln=en-us'>http://www.update.microsoft.com/windowsupdate/v6/default.aspx?ln=en-us</a> </pre> <br /> 설치 하고 나니 문제 해결! <br /> <br /> 휴~~~ 다행입니다. ^^ 비록 가끔은 안 좋은 윈도우 업데이트(<a target='tab' href='http://www.sysnet.pe.kr/2/0/1024'>1</a>, <a target='tab' href='http://www.sysnet.pe.kr/2/0/1128'>2</a>)가 있긴 하지만, 어쨌든 업데이트가 괜히 제공되는 것이 아님을 다시 한번 알게 되는 사건이었습니다.<br /> </p><br /> <br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
1863
(왼쪽의 숫자를 입력해야 합니다.)