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

Hyper-V Virtual Machine Management service Account does not have permission to open attachment

신규 생성한 VHDX 파일을 사용하려는 데 다음과 같은 오류 메시지가 발생합니다.

The application encountered an error while attempting to change the state of '...[vm name]...'.

'...[vm name]...' failed to start.

Synthetic SCSI Controller (Instance ID 6B2CDE5B-97C0-49A0-8676-A1892835C036): Failed to Power on with Error 'General access denied error'.

Hyper-V Virtual Machine Management service Account does not have permission to open attachment 'C:\VMs\...[vm name]...\Virtual Hard Disks\cdrive.vhdx'. Error: 'General access denied error'.

[Expanded Information]
'...[vm name]...' failed to start. (Virtual machine ID DD899062-7D90-4858-8C7D-F4249DA773FF)

'...[vm name]...' Synthetic SCSI Controller (Instance ID 6B2CDE5B-97C0-49A0-8676-A1892835C036): Failed to Power on with Error 'General access denied error' (0x80070005). (Virtual machine ID DD899062-7D90-4858-8C7D-F4249DA773FF)

'...[vm name]...': Hyper-V Virtual Machine Management service Account does not have permission to open attachment 'C:\VMs\...[vm name]...\Virtual Hard Disks\...[vm name]....vhdx'. Error: 'General access denied error' (0x80070005). (Virtual machine ID DD899062-7D90-4858-8C7D-F4249DA773FF)

검색해 보니 다음의 글이 나옵니다.

Hyper-V virtual machine may not start, and you receive a “‘General access denied error’ (0x80070005)” error message 
; https://support.microsoft.com/en-us/kb/2249906

정리하면, 그냥 수작업으로 icacls 도구를 이용해 권한을 부여해도 된다는 것입니다. 형식은 다음과 같습니다.

icacls "...vhdx_file_path..." /grant "NT VIRTUAL MACHINE\[...Virtual machine ID...]":(F)

이 중에서 "Virtual machine ID"는 오류 메시지에 보면 나옵니다. 위에서는 "DD899062-7D90-4858-8C7D-F4249DA773FF"에 해당합니다. 따라서 다음과 같이 명령어를 주면 됩니다.

C:\Windows\system32>icacls "F:\VMs\...[vm name]...\Virtual Hard Disks\...[vm name]....vhdx" /grant "NT VIRTUAL MACHINE\DD899062-7D90-4858-8C7D-F4249DA773FF":(F)
processed file: F:\VMs\...[vm name]...\Virtual Hard Disks\...[vm name]....vhdx
Successfully processed 1 files; Failed processing 0 files

참고로, 이와 관련해서 다음의 글도 생각나는군요. ^^

Hyper-V VM 복사는 robocopy로.
; https://www.sysnet.pe.kr/2/0/1404




권한 변경을 하고 VM을 시작했더니, 그래도 실행이 안 되면서 다음과 같은 오류가 발생합니다.

The application encountered an error while attempting to change the state of '...[vm name]...'.

'...[vm name]...' failed to change state.

The operation cannot be performed while the object is in use.

이해할 수 없군요. 아마도 해당 .vhdx 파일이 다른 프로세스에 의해 사용 중이라는 것인데, 실제로 Process Explorer를 통해 살펴 보니 Pid == 4번인 "SYSTEM" 프로세스가 붙잡고 있었습니다. 음... 어쩌면 이전 단계에서 .vhdx 파일을 생성할 때 작업 처리 도중 내부적인 오류가 발생한 것이 아닌가 생각됩니다. 즉, .vhdx 파일 생성에 실패했지만 그 작업을 수행 중인 스레드가 종료되지 않아 계속 해당 파일을 열고 있는 것일지도... ^^;;;

어쨌든 이런 경우 시스템을 껏다 켜면 되겠지만, Virtual Machine들이 운영 중인 호스트를 재부팅하는 것은 부담이므로 그냥 새롭게 다른 이름으로 vhdx 파일을 하나 새로 생성해 연결하는 것으로 해결했습니다.




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







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

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

비밀번호

댓글 작성자
 




... 106  107  108  109  110  111  112  [113]  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11191정성태5/2/201727189Windows: 139. Dell Venue 8 Pro 태블릿에 USB를 이용한 윈도우 운영체제 설치 방법
11190정성태5/2/201732854Windows: 138. Windows 운영체제의 ISO 설치 파일에 미리 Device driver를 준비하는 방법
11189정성태5/2/201723421Windows: 137. Windows 7 USB/DVD DOWNLOAD TOOL로 98%에서 실패하는 경우
11188정성태4/27/201727014VC++: 118. Win32 HANDLE 자료형의 이모저모 [2]
11187정성태4/26/201727930개발 환경 구성: 314. C# - PowerPoint 확장 Add-in 만드는 방법 [1]파일 다운로드1
11186정성태4/24/201725755VS.NET IDE: 117. Visual Studio 확장(VSIX)을 이용해 사용자 매크로를 추가하는 방법 [1]파일 다운로드1
11185정성태4/22/201723482VS.NET IDE: 116. Visual Studio 확장(VSIX)을 이용해 사용자 메뉴 추가하는 방법 (2) - 동적 메뉴 구성파일 다운로드1
11184정성태4/21/201724927VS.NET IDE: 115. Visual Studio 확장(VSIX)을 이용해 사용자 메뉴 추가하는 방법파일 다운로드1
11183정성태4/19/201724237.NET Framework: 654. UWP 앱에서 FolderPicker 사용 시 유의 사항파일 다운로드1
11182정성태4/19/201727892개발 환경 구성: 313. Nuget Facebook 라이브러리를 이용해 ASP.NET 웹 폼과 로그인 연동하는 방법
11181정성태4/18/201725358개발 환경 구성: 312. Azure Web Role의 AppPool 실행 권한을 Local System으로 바꾸는 방법
11180정성태4/16/201728033Java: 18. Java의 Memory Mapped File 자원 반환이 안 되는 문제
11179정성태4/13/201721219기타: 64. SVG Converter 스토어 앱 개인정보 보호 정책 안내
11178정성태4/10/201723382개발 환경 구성: 311. COM+ 관리자의 DCOM 구성에 나오는 기준
11177정성태4/7/201722734.NET Framework: 653. C# 7 새로운 문법(1) - 더욱 편리해진 Out 변수 사용파일 다운로드1
11176정성태4/5/201720333VC++: 117. Visual Studio - ATL COM 개체를 단위 테스트 하는 방법
11175정성태4/5/201728664.NET Framework: 652. C# 개발자를 위한 C++ COM 객체의 기본 구현 방식 설명파일 다운로드1
11174정성태4/3/201723167VC++: 116. Visual Studio 단위 테스트 - Failed to set up the execution context to run the test
11173정성태4/3/201726421VC++: 115. Visual Studio에서 C++ DLL을 대상으로 단위 테스트할 때 비정상 종료한다면?파일 다운로드1
11172정성태4/3/201725124.NET Framework: 651. C# - 특정 EXE 프로세스를 종료시킨 EXE를 찾아내는 방법파일 다운로드1
11171정성태3/31/201722805VS.NET IDE: 114. Visual Studio 디버깅 경고 창 - You are debugging a Release build of ...
11170정성태3/31/201725461.NET Framework: 650. C# - CachedAnonymousMethodDelegate 유형의 코드 생성
11169정성태3/30/201725069VC++: 114. C++ vtable의 가상 함수 호출 가로채기파일 다운로드1
11168정성태3/29/201726346VC++: 113. C++ 클래스 상속 관계의 vtable 생성 과정
11167정성태3/28/201726725VC++: 112. C++의 가상 함수 테이블 (vtable)은 언제 생성될까요? [2]
11166정성태3/28/201723157오류 유형: 382. System.Data.SqlClient.SqlException - Arithmetic overflow error converting IDENTITY to data type int.
... 106  107  108  109  110  111  112  [113]  114  115  116  117  118  119  120  ...