Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Msvm_ImageManagementService WMI 객체를 사용할 때 오류 상황 정리

VHD/VHDX 제어 관련해서 인터넷 검색을 해보면 Msvm_ImageManagementService WMI 객체를 사용하는 예제가 많이 나옵니다. 실제로 다음과 같이 코딩을 하게 되는데요.

ManagementScope scope = new ManagementScope(@"root\virtualization", null);

using (ManagementObject imageService = Utility.GetServiceObject(scope, "Msvm_ImageManagementService"))
{
    // ... VHD/VHDX 제어
}

이를 실행해 보면 환경에 따라 다음과 같은 예외가 발생할 수 있습니다.

System.Management.ManagementException: Not found
   at System.Management.ManagementException.ThrowWithExtendedInfo(ManagementStatus errorCode)
   at System.Management.ManagementObject.Initialize(Boolean getObject)
   at System.Management.ManagementBaseObject.get_ClassName()
   at System.Management.ManagementClass.GetInstances(EnumerationOptions options)
   at System.Management.ManagementClass.GetInstances()
...[생략]...

이유는 다음의 글에 나온 데로,

Error 'Get-WmiObject : Invalid class “Msvm_ImageManagementService”'
; http://stackoverflow.com/questions/19201375/error-get-wmiobject-invalid-class-msvm-imagemanagementservice

Windows 8.1부터 네임스페이스가 변경되었기 때문입니다.

The v2 WMI namespace in Hyper-V on Windows 8
; https://docs.microsoft.com/en-us/archive/blogs/virtual_pc_guy/the-v2-wmi-namespace-in-hyper-v-on-windows-8

따라서, 다음과 같이 Scope을 변경해야 합니다.

ManagementScope scope = new ManagementScope(@"root\virtualization\v2", null);

using (ManagementObject imageService = Utility.GetServiceObject(scope, "Msvm_ImageManagementService"))
{
    // ... VHD/VHDX 제어
}




그런데, 이렇게 변경했는데도 예외가 발생할 수 있습니다.

System.Management.ManagementException: This method is not implemented in any class
   at System.Management.ManagementException.ThrowWithExtendedInfo(ManagementStatus errorCode)
   at System.Management.ManagementObject.GetMethodParameters(String methodName, ManagementBaseObject& inParameters, IWbemClassObjectFreeThreaded& inParametersClass, IWbemClassObjectFreeThreaded& outParametersClass)
   at System.Management.ManagementObject.GetMethodParameters(String methodName)
...[생략]...

이유는, v2로 네임스페이스만 변경된 것 뿐만 아니라 메서드의 구현까지 모두 변경되었기 때문입니다. 따라서, v2에 대한 문서를 보고 구현을 해야 합니다.

Msvm_ImageManagementService class
; https://docs.microsoft.com/en-us/windows/win32/hyperv_v2/msvm-imagemanagementservice

CreateVirtualHardDisk method of the Msvm_ImageManagementService class
; https://docs.microsoft.com/en-us/windows/win32/hyperv_v2/createvirtualharddisk-msvm-imagemanagementservice

이제부터 잘 동작할 것입니다. ^^




그런데, 몇몇 컴퓨터에서 그래도 다음과 같은 예외가 발생할 수 있습니다.

System.Management.ManagementException: Invalid namespace
   at System.Management.ManagementException.ThrowWithExtendedInfo(ManagementStatus errorCode)
   at System.Management.ManagementScope.InitializeGuts(Object o)
   at System.Management.ManagementScope.Initialize()
   at System.Management.ManagementScope.Connect()
...[생략]...

환경은 Hyper-V가 설치되지 않은 Windows 10이었기 때문입니다. "root\virtualization\v2" 계열의 WMI 객체들에 대한 MSDN 문서를 보면 "Minimum supported client"로 "Windows?8 [desktop apps only]"라고만 되어 있지만 기본적으로 Hyper-V가 설치되어 있어야만 하는 것입니다.




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







[최초 등록일: ]
[최종 수정일: 7/13/2021]

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

비밀번호

댓글 작성자
 



2017-05-04 01시29분
Windows-classic-samples / Samples / Hyper-V / Storage / cs
; https://github.com/Microsoft/Windows-classic-samples/tree/master/Samples/Hyper-V/Storage/cs
정성태

... 136  137  138  139  140  141  142  143  144  145  146  147  [148]  149  150  ...
NoWriterDateCnt.TitleFile(s)
1387정성태12/12/201229668VC++: 64. x64 Visual C++에서 TEB 주소 구하는 방법
1386정성태12/12/201230999디버깅 기술: 53. windbg - 덤프 파일로부터 네이티브 DLL을 추출하는 방법 [1]
1385정성태12/12/201226418디버깅 기술: 52. Windbg - The version of SOS does not match the version of CLR you are debugging.
1384정성태12/12/201231108개발 환경 구성: 178. System32 폴더의 64비트 DLL을 32비트 Depends.exe에서 보는 방법
1383정성태12/10/201227097개발 환경 구성: 177. 기업용 메신저를 위한 Office Communicator Server 2007 설치 [1]
1382정성태12/8/201229749개발 환경 구성: 176. WebPagetest 서버 - 설치 및 테스트
1381정성태12/5/201228533.NET Framework: 347. C# - 프로세스(EXE) 수준의 Singleton 개체 생성 [2]파일 다운로드1
1380정성태11/28/201238492.NET Framework: 346. 닷넷 개발자에게 Node.js의 의미 [17]
1379정성태11/26/201231855.NET Framework: 345. C# 부호(+, -)에 대한 비트 변환 [1]
1378정성태11/22/201232904Java: 14. 안드로이드 - Hello World 실습 [7]
1377정성태11/19/201226534.NET Framework: 344. 닷넷 프로파일러 - ICorProfilerInfo::GetILFunctionBody 함수 버그
1376정성태11/15/201231638디버깅 기술: 51. 닷넷 응용 프로그램에서 특정 예외가 발생했을 때 풀 덤프 받는 방법 [6]
1375정성태11/15/201227356디버깅 기술: 50. windbg의 mscordacwks DLL 로드 문제 - 두 번째 이야기
1374정성태11/13/201225402개발 환경 구성: 175. Visual Studio의 "Extension Manager"에서 설치된 구성 요소들의 제거 버튼이 비활성화되었다면!
1373정성태11/13/201225943.NET Framework: 343. VB.NET 어셈블리의 .NET Reflector 소스 코드를 분석할 때 알아두면 좋은 사항
1372정성태11/1/2012120662Windows: 67. 64비트 윈도우에서 Internet Explorer 10이 항상 64비트로만 실행된다면? [57]
1371정성태10/31/201228646.NET Framework: 342. Python의 zip과 with 문 context를 C#과 비교하면. [3]파일 다운로드1
1370정성태10/31/201223640VS.NET IDE: 75. Visual Studio - "Active Solution Platform" 변경을 툴바에서 하는 방법
1369정성태10/31/201236888개발 환경 구성: 174. 윈도우에서 Mono 개발 환경 구성 [4]
1368정성태10/31/201228444개발 환경 구성: 173. Windows Phone SDK 8.0 설치
1367정성태10/30/201235969개발 환경 구성: 172. IIS 7.5부터 지원되는 웹 사이트 자동 시작 모드 [1]
1366정성태10/24/201227459개발 환경 구성: 171. GTK+를 윈도우 환경에 수작업 설치
1365정성태10/24/201226218개발 환경 구성: 170. 우분투 데스크톱 Active Directory 가입하기 [2]
1364정성태10/19/201222803Windows: 66. Hyper-V 2012에서 별도의 네트워크 카드를 이용한 Live Migration
1363정성태10/16/201230345개발 환경 구성: 169. Objective-C의 대안 - Xamarin의 Mono를 이용한 C# iOS 개발 환경 [2]
1362정성태10/16/201230611개발 환경 구성: 168. 우분투 서버 Active Directory 가입하기
... 136  137  138  139  140  141  142  143  144  145  146  147  [148]  149  150  ...