Microsoft MVP성태의 닷넷 이야기
Windows: 64. Hyper-V - Windows XP의 Live Migration 오류 [링크 복사], [링크+제목 복사],
조회: 23450
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Hyper-V - Windows XP의 Live Migration 오류


지난번 글에서 Hyper-V의 Live Migration 글을 소개해 드렸지요. ^^

윈도우 서버 2012 - Hyper-V의 새로운 기능 Live Migration
; https://www.sysnet.pe.kr/2/0/1356

위의 설명에 따라 대체로 잘 되고 있었는데, 유독 Windows XP의 live migration 설정 창의 마지막 단계에서 오류가 발생하였습니다.

There was an error during move operation.

Virtual machine migration operation failed at migration destination.

Virtual machine migration operation for '...' failed at migration destination '...'. (Virtual machine ID ...[guid]...)

별다른 힌트가 없어서 이벤트 로그를 확인해 보았는데 다음과 같은 경고들이 보였습니다.

Log Name: Microsoft-Windows-Hyper-V-Integration-Admin
Source: Microsoft-Windows-Hyper-V-Integration-KvpExchange
Date: 2012-09-27 오후 8:45:13
Event ID: 4010
Task Category: None
Level: Warning
Keywords:
User: NT VIRTUAL MACHINE\9888AF43-5F96-46E8-9297-DE325DFE555E
Computer: oldpc.test.com
Description:
Hyper-V Data Exchange connected to virtual machine 'idb-demo', but the version does not match the version expected by Hyper-V (Virtual machine ID 9888AF43-5F96-46E8-9297-DE325DFE555E). Framework version: Negotiated (3.0) - Expected (3.0); Message version: Negotiated (3.0) - Expected (4.0). This is an unsupported configuration. This means that technical support will not be provided until this problem is resolved. To fix this problem, upgrade the integration services. To upgrade, connect to the virtual machine and select Insert Integration Services Setup Disk from the Action menu.

Log Name: Microsoft-Windows-Hyper-V-Worker-Admin
Source: Microsoft-Windows-Hyper-V-Worker
Date: 2012-09-27 오후 8:44:56
Event ID: 23014
Task Category: None
Level: Warning
Keywords:
User: NT VIRTUAL MACHINE\9888AF43-5F96-46E8-9297-DE325DFE555E
Computer: oldpc.test.com
Description:
Device 'Microsoft Synthetic Display Controller' in 'idb-demo' is loaded but has a different version from the server. Server version 3.2 Client version 3.0 (Virtual machine ID 9888AF43-5F96-46E8-9297-DE325DFE555E). The device will work, but this is an unsupported configuration. This means that technical support will not be provided until this problem is resolved. To fix this problem, upgrade the integration services. To upgrade, connect to the virtual machine and select Insert Integration Services Setup Disk from the Action menu.


일단, 이 경고들은 Windows Server 2008 R2에서 호스팅되던 idb-demo라는 Windows XP 가상 머신이 2012 버전의 Integration Services가 적용되지 않아서 발생한 것들이고, IS를 업그레이드 해봤지만 여전히 live migration에는 오류가 발생했습니다.




다행히 여러 가지 테스트 끝에 원인을 알아냈습니다. idb-demo를 호스팅하던 원래 PC에서는 하드 디스크가 C/D/E로 있었고, idb-demo 가상 머신 데이터는 D 드라이브에 있는 상태에서, 옮겨가려는 대상 Hyper-V 머신에는 C/E 드라이브만 있었고 D 드라이브가 없었기 때문에 발생한 오류였습니다.

지난번 글에서 '하드 디스크 구성'을 맞춰주는 것이 좋다고 설명드렸지만, 사실 강제사항은 아니었습니다. 왜냐하면 "Move..." 메뉴를 통한 Live migration의 설정 작업이 완료되는 시점에 드라이브가 다른 경우 다시 설정할 수 있는 옵션이 제공되기 때문입니다.

문제는, 그런 '선택'이 Windows XP의 live migration에서는 제공되지 않고 오류 메시지를 발생시키는 것으로 끝난다는 점입니다.

원인을 알았으니, 이제 해결을 해야 하는데요. "Move..." 메뉴의 마법사의 '자동 교정'에 의존하지 않고 직접 사용자가 폴더를 지정하는 식으로 마이그레이션을 진행하면 간단하게 해결됩니다.

즉, "Move"를 위한 설정 창에서 "Choose Advanced Options"의 값을 기존에는 "Move the virtual machine's data automatically"로 지정했던 것을 아래와 같이 그 이외의 옵션으로 바꿔주어야 합니다. (이 글의 실습에서는 "Move the virtual machine's items to different locations"으로 선택했습니다.)

hyper-v_winxp_live_mig_1.png

이렇게 선택하면, VM에 속한 모든 항목에 대해서 각각 이동 여부를 선택할 수 있는 질문을 받게 되고,

hyper-v_winxp_live_mig_2.png

이후, 다시 개별 항목마다 대상 Hyper-V 컴퓨터의 어떤 폴더로 이동할지 선택할 수 있는 창이 제공됩니다. 위의 그림에서는 4개의 항목(.vhd, Current configuration, Snapshots, Smart Paging)이 선택되었으므로 아래와 같이 경로를 입력받는 창이 4번 제공됩니다.

hyper-v_winxp_live_mig_3.png

물론, 개별적으로 폴더 선택을 할 수 있지만 모두 같은 폴더를 선택해도 무방합니다.

이렇게 선택하고 Windows XP에 대해서 live migration을 진행하면 아무런 오류 없이 정상적으로 VM 이전이 되는 것을 확인할 수 있습니다.




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







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

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)
11274정성태8/22/201719378.NET Framework: 674. Thread 타입의 Suspend/Resume/Join 사용 관련 예외 처리
11273정성태8/22/201721633오류 유형: 415. 윈도우 업데이트 에러 Error 0x80070643
11272정성태8/21/201724794VS.NET IDE: 120. 비주얼 스튜디오 2017 버전 15.3.1 - C# 7.1 공개 [2]
11271정성태8/19/201719242VS.NET IDE: 119. Visual Studio 2017에서 .NET Core 2.0 프로젝트 환경 구성하는 방법
11270정성태8/17/201730716.NET Framework: 673. C#에서 enum을 boxing 없이 int로 변환하기 [2]
11269정성태8/17/201721487디버깅 기술: 93. windbg - 풀 덤프에서 .NET 스레드의 상태를 알아내는 방법
11268정성태8/14/201721060디버깅 기술: 92. windbg - C# Monitor Lock을 획득하고 있는 스레드 찾는 방법
11267정성태8/10/201725117.NET Framework: 672. 모노 개발 환경
11266정성태8/10/201724932.NET Framework: 671. C# 6.0 이상의 소스 코드를 Visual Studio 설치 없이 명령행에서 컴파일하는 방법
11265정성태8/10/201753172기타: 66. 도서: 시작하세요! C# 7.1 프로그래밍: 기본 문법부터 실전 예제까지 [11]
11264정성태8/9/201724092오류 유형: 414. UWP app을 signtool.exe로 서명 시 0x8007000b 오류 발생
11263정성태8/9/201719576오류 유형: 413. The C# project "..." is targeting ".NETFramework, Version=v4.0", which is not installed on this machine. [3]
11262정성태8/5/201718249오류 유형: 412. windbg - SOS does not support the current target architecture. [3]
11261정성태8/4/201720834디버깅 기술: 91. windbg - 풀 덤프 파일로부터 강력한 이름의 어셈블리 추출 후 사용하는 방법
11260정성태8/3/201718938.NET Framework: 670. C# - 실행 파일로부터 공개키를 추출하는 방법
11259정성태8/2/201718175.NET Framework: 669. 지연 서명된 어셈블리를 sn.exe -Vr 등록 없이 사용하는 방법
11258정성태8/1/201718996.NET Framework: 668. 지연 서명된 DLL과 서명된 DLL의 차이점파일 다운로드1
11257정성태7/31/201719166.NET Framework: 667. bypassTrustedAppStrongNames 옵션 설명파일 다운로드1
11256정성태7/25/201720657디버깅 기술: 90. windbg의 lm 명령으로 보이지 않는 .NET 4.0 ClassLibrary를 명시적으로 로드하는 방법 [1]
11255정성태7/18/201723211디버깅 기술: 89. Win32 Debug CRT Heap Internals의 0xBAADF00D 표시 재현 [1]파일 다운로드3
11254정성태7/17/201719582개발 환경 구성: 322. "Visual Studio Emulator for Android" 에뮬레이터를 "Android Studio"와 함께 쓰는 방법
11253정성태7/17/201719933Math: 21. "Coding the Matrix" 문제 2.5.1 풀이 [1]파일 다운로드1
11252정성태7/13/201718454오류 유형: 411. RTVS 또는 PTVS 실행 시 Could not load type 'Microsoft.VisualStudio.InteractiveWindow.Shell.IVsInteractiveWindowFactory2'
11251정성태7/13/201717141디버깅 기술: 88. windbg 분석 - webengine4.dll의 MgdExplicitFlush에서 발생한 System.AccessViolationException의 crash 문제 (2)
11250정성태7/13/201720701디버깅 기술: 87. windbg 분석 - webengine4.dll의 MgdExplicitFlush에서 발생한 System.AccessViolationException의 crash 문제 [1]
11249정성태7/12/201718532오류 유형: 410. LoadLibrary("[...].dll") failed - The specified procedure could not be found.
... [106]  107  108  109  110  111  112  113  114  115  116  117  118  119  120  ...