Microsoft MVP성태의 닷넷 이야기
오류 유형: 147. System.Runtime.InteropServices.COMException (0x80005000) [링크 복사], [링크+제목 복사],
조회: 18016
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

System.Runtime.InteropServices.COMException (0x80005000)

IIS Recycle을 하는 코드를 만들어 두었는데,

string appPoolPath = "IIS://" + Environment.MachineName + "/W3SVC/AppPools/DefaultAppPool";
DirectoryEntry appPoolEntry = new DirectoryEntry(appPoolPath);

appPoolEntry.Invoke("Recycle");

특정 PC에서는 다음과 같은 오류가 발생했습니다.

System.Runtime.InteropServices.COMException (0x80005000): 不明なエラ? (0x80005000)
   場所 System.DirectoryServices.DirectoryEntry.Bind(Boolean throwIfFail)
   場所 System.DirectoryServices.DirectoryEntry.Bind()
   場所 System.DirectoryServices.DirectoryEntry.get_NativeObject()
   場所 System.DirectoryServices.DirectoryEntry.Invoke(String methodName, Object[] args)
   ...[생략]...
   場所 System.Windows.Forms.NativeWindow.Callback(IntPtr hWnd, Int32 msg, IntPtr wparam, IntPtr lparam)

원인을 알 수 없어 웹 검색을 해보았는데, 참 다양한 많은 사연들이 있었지만 제 경우에 해당하는 것은 없었습니다.

그런데, 문득 문제를 일으킨 PC가 "Windows 7"이라는 것과 예전에 작업했던 내용이 떠오르면서 단서를 얻을 수가 있었습니다.

IIS Metabase와 ServerManager 개체 활용
; https://www.sysnet.pe.kr/2/0/973

그렇습니다. 해당 컴퓨터에서는 "IIS 6 Metabase Compatibility" 구성 요소가 설치되어 있지 않았기 때문에 Recycle 명령을 실행 시에 그와 같은 오류가 발생한 것입니다. ^^

그래서, 운영체제 버전이 6 이상인 경우에는 다음과 같은 코드를 수행하도록 확장하는 것으로~~~ 이슈 종료!

// Microsoft.Web.Administration.dll
ServerManager svr = new ServerManager();

ApplicationPool appPool = svr.ApplicationPools[appPoolId];
if (appPool != null)
{
    appPool.Recycle();
}




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 8/12/2021]

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

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  [9]  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13422정성태10/5/20233502닷넷: 2148. C# - async 유무에 따른 awaitable 메서드의 병렬 및 예외 처리
13421정성태10/4/20233618닷넷: 2147. C# - 비동기 메서드의 async 예약어 유무에 따른 차이
13420정성태9/26/20236096스크립트: 57. 파이썬 - UnboundLocalError: cannot access local variable '...' where it is not associated with a value
13419정성태9/25/20233355스크립트: 56. 파이썬 - RuntimeError: dictionary changed size during iteration
13418정성태9/25/20234175닷넷: 2146. C# - ConcurrentDictionary 자료 구조의 동기화 방식
13417정성태9/19/20233696닷넷: 2145. C# - 제네릭의 형식 매개변수에 속한 (매개변수를 가진) 생성자를 호출하는 방법
13416정성태9/19/20233385오류 유형: 877. redis-py - MISCONF Redis is configured to save RDB snapshots, ...
13415정성태9/18/20233881닷넷: 2144. C# 12 - 컬렉션 식(Collection Expressions)
13414정성태9/16/20233735디버깅 기술: 193. Windbg - ThreadStatic 필드 값을 조사하는 방법
13413정성태9/14/20233916닷넷: 2143. C# - 시스템 Time Zone 변경 시 이벤트 알림을 받는 방법
13412정성태9/14/20237245닷넷: 2142. C# 12 - 인라인 배열(Inline Arrays) [1]
13411정성태9/12/20233708Windows: 252. 권한 상승 전/후 따로 관리되는 공유 네트워크 드라이브 정보
13410정성태9/11/20235299닷넷: 2141. C# 12 - Interceptor (컴파일 시에 메서드 호출 재작성) [1]
13409정성태9/8/20234077닷넷: 2140. C# - Win32 API를 이용한 모니터 전원 끄기
13408정성태9/5/20234067Windows: 251. 임의로 만든 EXE 파일을 포함한 ZIP 파일의 압축을 해제할 때 Windows Defender에 의해 삭제되는 경우
13407정성태9/4/20233767닷넷: 2139. C# - ParallelEnumerable을 이용한 IEnumerable에 대한 병렬 처리
13406정성태9/4/20233782VS.NET IDE: 186. Visual Studio Community 버전의 라이선스
13405정성태9/3/20234164닷넷: 2138. C# - async 메서드 호출 원칙
13404정성태8/29/20233711오류 유형: 876. Windows - 키보드의 등호(=, Equals sign) 키가 눌리지 않는 경우
13403정성태8/21/20233555오류 유형: 875. The following signatures couldn't be verified because the public key is not available: NO_PUBKEY EB3E94ADBE1229CF
13402정성태8/20/20233638닷넷: 2137. ILSpy의 nuget 라이브러리 버전 - ICSharpCode.Decompiler
13401정성태8/19/20233891닷넷: 2136. .NET 5+ 환경에서 P/Invoke의 성능을 높이기 위한 SuppressGCTransition 특성 [1]
13400정성태8/10/20233758오류 유형: 874. 파이썬 - pymssql을 윈도우 환경에서 설치 불가
13399정성태8/9/20233590닷넷: 2135. C# - 지역 변수로 이해하는 메서드 매개변수의 값/참조 전달
13398정성태8/3/20234490스크립트: 55. 파이썬 - pyodbc를 이용한 SQL Server 연결 사용법
13397정성태7/23/20233991닷넷: 2134. C# - 문자열 연결 시 string.Create를 이용한 GC 할당 최소화
1  2  3  4  5  6  7  8  [9]  10  11  12  13  14  15  ...