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

Windows - WHPX(Windows Hypervisor Platform)를 이용한 Android Emulator 가속

MAUI 프로젝트를 Emulator 설정으로 Visual Studio 환경에서 (F5 디버깅처럼) 실행하면 잘 모르고 지나갈 수도 있는데요, 대신 "Tools" / "Android" / "Android Device Manager..." 메뉴를 통해 에뮬레이터를 직접 시작하는 경우 다음과 같은 경고창이 뜰 수도 있습니다.

This emulator does not have hardware acceleration enabled, and its performance will be impacted.
We recommend to either:

- Turn on "Hyper-V" feature to switch to the Native Hypervisor and accelerate your emulator.

- Configure hardware acceleration following the instructions to Enable Hardware Acceleration

- Try using a physical Android device for development.

- You can try and start the emulator anyway running unaccelerated, however this is NOT recommended.

문서를 봤더니,

How to enable hardware acceleration with Android emulators (Hyper-V & AEHD)
; https://learn.microsoft.com/en-us/dotnet/maui/android/emulator/hardware-acceleration

그동안 많은 변화가 있었군요. ^^; 우선 선택의 폭이 넓어져서 2가지 방법 중 하나를 선택하면 됩니다.

  1. The Windows Hypervisor Platform (WHPX). Hyper-V is a virtualization feature of Windows that makes it possible to run virtualized computer systems on a physical host computer.
  2. The Android Emulator hypervisor driver (AEHD).

과거에 유명했던 Intel HAXM은 33.x 이후의 에뮬레이터부터 권장하지 않고, 결국 위의 2번째 옵션에 해당하는 AEHD로 바뀌었다고 합니다. 일단은, AEHD가 범용성이 좋은 듯한데 그래도 윈도우 환경에서는 WHPX를 추천한다고 합니다.




해당 문서에 따르면, Windows 10 RS5 업데이트 이후부터는 Hyper-V를 설치한 경우 내부적으로 WHPX를 자동으로 활성화시키므로 굳이 "Windows Hypervisor Platform"을 켤 필요는 없다고 합니다.

whpx_enable_1.png

하지만 제 경우에 Hyper-V를 설치한 머신인데도 "This emulator does not have hardware acceleration enabled, and its performance will be impacted." 메시지가 뜬 건데요, 어쨌든 명시적으로 저 옵션을 켜고 재부팅한 이후부터는 더 이상 경고 메시지가 뜨지 않습니다. (아마도 WHPX가 나오기 이전부터 설치한 Hyper-V인 경우에는 자동 적용이 안 되는 듯합니다.)

참고로, AEHD는 Hyper-V를 지원하지 못하는 시스템에서도 사용할 수 있다고 하며, 심지어 Hyper-V를 지원한다고 해도 꺼야만 설치가 됩니다. 아마도 개발자라면 Hyper-V를 대부분 설치했을 것이므로 딱히 중요한 사항은 아니기에 자세한 사항은 문서를 참조하시면 되겠습니다.

암튼, 안드로이드 개발 환경만큼은 이젠 물리 기기가 없어도 될 정도로 쾌적해진 것 같습니다. ^^




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







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

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)
13901정성태3/9/20251057Windows: 280. Hyper-V의 3가지 Thread Scheduler (Classic, Core, Root)
13900정성태3/8/20251162스크립트: 72. 파이썬 - SQLAlchemy + oracledb 연동
13899정성태3/7/20251152스크립트: 71. 파이썬 - asyncio의 ContextVar 전달
13898정성태3/5/20251174오류 유형: 948. Visual Studio - Proxy Authentication Required: dotnetfeed.blob.core.windows.net
13897정성태3/5/20251152닷넷: 2326. C# - PowerShell과 연동하는 방법 (두 번째 이야기)파일 다운로드1
13896정성태3/5/20251169Windows: 279. Hyper-V Manager - VM 목록의 CPU Usage 항목이 항상 0%로 나오는 문제
13895정성태3/4/20251299Linux: 117. eBPF / bpf2go - Map에 추가된 요소의 개수를 확인하는 방법
13894정성태2/28/20251405Linux: 116. eBPF / bpf2go - BTF Style Maps 정의 구문과 데이터 정렬 문제
13893정성태2/27/20251417Linux: 115. eBPF (bpf2go) - ARRAY / HASH map 기본 사용법
13892정성태2/24/20251488닷넷: 2325. C# - PowerShell과 연동하는 방법파일 다운로드1
13891정성태2/23/20251457닷넷: 2324. C# - 프로세스의 성능 카운터용 인스턴스 이름을 구하는 방법파일 다운로드1
13890정성태2/21/20251458닷넷: 2323. C# - 프로세스 메모리 중 Private Working Set 크기를 구하는 방법(Win32 API)파일 다운로드1
13889정성태2/20/20251631닷넷: 2322. C# - 프로세스 메모리 중 Private Working Set 크기를 구하는 방법(성능 카운터, WMI) [1]파일 다운로드1
13888정성태2/17/20251433닷넷: 2321. Blazor에서 발생할 수 있는 async void 메서드의 부작용
13887정성태2/17/20251402닷넷: 2320. Blazor의 razor 페이지에서 code-behind 파일로 코드를 분리하는 방법
13886정성태2/15/20251685VS.NET IDE: 196. Visual Studio - Code-behind처럼 cs 파일을 그룹핑하는 방법
13885정성태2/14/20251704닷넷: 2319. ASP.NET Core Web API / Razor 페이지에서 발생할 수 있는 async void 메서드의 부작용
13884정성태2/13/20251910닷넷: 2318. C# - (async Task가 아닌) async void 사용 시의 부작용파일 다운로드1
13883정성태2/12/20251885닷넷: 2317. C# - Memory Mapped I/O를 이용한 PCI Configuration Space 정보 열람파일 다운로드1
13882정성태2/10/20252004스크립트: 70. 파이썬 - oracledb 패키지 연동 시 Thin / Thick 모드
13881정성태2/7/20252107닷넷: 2316. C# - Port I/O를 이용한 PCI Configuration Space 정보 열람파일 다운로드1
13880정성태2/5/20251936오류 유형: 947. sshd - Failed to start OpenSSH server daemon.
13879정성태2/5/20252207오류 유형: 946. Ubuntu - N: Updating from such a repository can't be done securely, and is therefore disabled by default.
13878정성태2/3/20252096오류 유형: 945. Windows - 최대 절전 모드 시 DRIVER_POWER_STATE_FAILURE 발생 (pacer.sys)
13877정성태1/25/20252277닷넷: 2315. C# - PCI 장치 열거 (레지스트리, SetupAPI)파일 다운로드1
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...