클라우드 서비스 구축의 최고 난이도! 가상화 기술을 이해한다.
가상화 기술은 서버에 있는 유휴 상태의 하드웨어 자원을 사용해 물리적인 PC 없이도 PC 환경을 사용할 수 있게 하는 기술이다. 10년 전부터 개발되어왔으나 잠시 잊혀졌던 가상화 기술은 클라우드 서비스가 보편화하면서 다시 주목할 필요가 생겼다. 이 책에서는 가상화 기술 중 가장 널리 쓰이는 Xen 하이퍼바이저를 통해 가상화 기술의 세 가지 핵심 부분의 하나인 메모리 가상화의 원리를 자세히 소개한다. 또한 가상화 기술을 구현하는 리눅스 커널 소스 코드와 Xen 소스 코드를 자세히 분석해 실제 가상 머신의 동작을 이해하는 데 도움을 준다.
『Xen으로 배우는 가상화 기술의 이해』 시리즈 2탄!
Xen 하이퍼바이저는 크게 CPU, 메모리, I/O(입출력) 가상화 환경을 지원한다. 이 책은 CPU 가상화를 잇는 '가상화 기술의 이해' 시리즈 2탄으로 메모리 가상화에 관한 부분을 중점적으로 다룬다. Xen 하이퍼바이저를 통한 가상화 기술의 모든 것을 파악하려면 이미 출간된 CPU 가상화와 곧 출간할 예정인 I/O 가상화를 함께 살펴보면 좋을 것이다.
Series 1. Xen으로 배우는 가상화 기술의 이해 - CPU 가상화
대상 독자
메모리 주소 변환을 통한 메모리 가상화 관리의 핵심을 이해한다!
메모리 관리는 안정적인 컴퓨터 동작에 있어서 필수 요소다. CPU 성능이 아무리 좋아도 CPU 속도에 맞춰 안정적으로 데이터를 보내고 받는 기억 공간을 관리하지 못하면 결국 성능 저하로 이어지기 때문이다. 이는 물리 머신보다 더 한정된 자원을 효율적으로 관리해야 하는 가상화에서도 마찬가지다. 먼저 가상 메모리의 개념과 가상 메모리의 주소 체계를 관리하는 섀도 페이지 테이블, 직접 페이지 테이블, 중첩 페이지 테이블 등을 상세히 소개한다. 다음에는 하이퍼바이저와 운영체제, 애플리케이션 사이의 안정적인 성능을 유지하는 데 필요한 메모리 보호 방법인 세그먼테이션과 페이징 보호를 소개한다. 또한 CPU에서 메모리 주소 체계를 관리하는 데 사용하는 하드웨어 지원 페이징도 살펴본다.
1장. 가상 머신 모니터는 무엇인가?
1.1 왜 가상화인가?
1.2 하이퍼바이저 종류
2장. 메모리 가상화
2.1 가상 메모리
2.2 가상화 환경의 메모리 주소 체계
2.3 섀도 페이지 테이블
2.4 직접 페이지 테이블 접근
2.5 중첩 페이지 테이블
3장. 메모리 보호
3.1 세그먼테이션
3.2 페이징 보호
3.3 32비트에서의 Xen 메모리 보호
3.4 x86-64에서의 메모리 보호
4장. 주소 변환 체계
4.1 페이지 프레임 번호
4.2 P2M 매핑
5장. 직접 페이징
5.1 페이지 테이블 수정
5.2 페이지 테이블 고정
5.3 쓰기 가능한 페이지 테이블
6장. 섀도 페이지 테이블
6.1 요구 페이징
6.2 TLB 에뮬레이션
6.3 TLB 에뮬레이션의 문제점
6.4 Xen의 섀도 페이지 테이블 구현
6.5 HVM 환경의 페이지 폴트 처리 과정
6.6 페이지 폴트 예외 처리
6.7 섀도 페이지 테이블의 페이지 폴트 핸들러 분석
6.8 다양한 섀도 페이지 테이블 최적화 방법
7장. 하드웨어 지원 페이징
7.1 페이지 테이블 구조
7.2 NPT 구축
7.3 NPT 주소 변환 오버헤드
7.4 hap_enable( ) 함수
7.5 ASID
Xen으로 배우는 가상화 기술의 이해 - I/O 가상화
문대혁 , 이상철 , 박은병 , 김태훈
Xen으로 배우는 가상화 기술의 이해 - CPU 가상화
박은병 , 이상철 , 문대혁 , 김태훈
리얼타임 eBook 안내
PDF 형식으로 제공되며, 다운로드한 eBook은 PDF 포맷을 지원하는 디바이스 또는 프로그램에서 제한없이 열람할 수 있습니다. 또한 eBook 내의 텍스트 검색 및 인쇄도 가능합니다.