2021. 2. 28. 00:07ㆍComputer(인강)/운영체제
안녕하세요 bannavi입니다^ㅅ^
오늘은 가상 머신의 이해에 대해 살펴보겠습니다!
바로 살펴보겠습니다.
가볍게 이해하기: Virtual Machine(가상 머신)
우선 가상머신은
인공지능, 클라우드 컴퓨팅에서 자주 사용되는 기술이죠.
- 하나의 하드웨어(CPU, Memory등)에 다수의 운영체제를 설치하고, 개별 컴퓨터처럼 동작하도록 하는 프로그램
Virtual Machine Type1 (native 또는 bare metal)
- 하이퍼 바이저(또는 VMM): 운영 체제와 응용프로그램을 물리적 하드웨어에서 분리하는 프로세스
- 하이퍼바이저 또는 버추얼 머신 모니터(VMM)라고 하는 소프트웨어가 Hardware에서 직접 구동
ex. Xen, KVM
Virtual Machine Type2
- 하이퍼바이저 또는 버추얼 머신 모니터 (VMM)라고 하는 소프트웨어가 Host OS 상위에 설치
- VMWare, Parallels Desktop(Mac)
Type1 방식 Type2 방식보다 더 빠를 수 있음.
Full Virtualization(전가상화) VS Half Virtualization(반가상화)
* 전가상화: 각 가상머신이 하이퍼바이저를 통해서 하드웨어와 통신
- 하이퍼바이저가 마친 하드웨어인 것처럼 동작하므로, 가상머신의 OS는 자신이 가상 머신인 상태인지를 모름
전가상화(전체를 다 가상화 했다)
반가상화
* 반가상화: 각 가상머신에서 직접 하드웨어와 통신
- 각 가상머신에 설치되는 OS는 가상 머신인 경우, 이를 인지하고, 각 명령에 하이퍼바이저 명령을 추가해서 하드웨어와 통신
(반가상화 방식이 전가상화에 비해 조금 더 빠를 수 있겠지만, 명시적으로 가상이라는 명령을 내려주려면 OS를 수정해야되고
그러면 복잡도가 올라가서 성능이 떨어질 수 있다는 단점이 있다.)
-> 최근에는 하드웨어 성능이 더 높아졌기 때문에 전가상화 기술을 선호한다.
VMWare
VMWare: 대중적인 가상머신 프로그램(Type2)
KVM
- AWS(아마존 클라우드 컴퓨팅 서비스)등에서 사용(Type1)
KVM
- Intel-VT등 가상화 기능을 가진 CPU에서는 VMX root/VMX non-root 모드 존재
- 각 모드별로 protection ring 0 ~ 3 지원, 가상화 기능을 사용하지 않을 경우, VMX root 모드 사용
- KVM은 각 가상 시스템에 대응하는 KVM프로세스 실행, KVM 모듈(/dev/kvm)을 통해 vCPU 사용
- KVM 프로세스 기반 게스트 커널(VMX non-root/RING 0 사용), QEMU 장치 에뮬레이터가 로드됨
-게스트 커널 위에서 실해오디는 응용 프로그램은 VMX non-root / RING3 사용
-게스트 커널이 물리적 HW 자원 필요시, VM exit 가 발생, KVM 모듈에서 해당 요청 처리
- 일반 HW 자원은 QEMU 장치 에뮬레이터에서 처리
* QEMU 장치 에뮬레이터는 VMX root / RING3를 통해, 호스트 커널에 요청 후, 해당 데이터는 공유 메모리를 통해 KVM 게스트 커널과 공유
또 다른 가상 머신: Docker(가상머신 vs Docker)
* 가상 머신은 컴퓨터 하드웨어를 가상화(하드웨어 전체 추상화)
- 하이퍼바이저 사용, 추가 OS 필요등 성능 저하 이슈 존재
* Docker는 운영체제 레벨에서 별도로 분리된 실행환경을 제공(커널 추상화)
- 마치 리눅스 처음 설치했을때와 유사한 실행 환경을 만들어주는 리눅스 컨테이너 기술 기반
- 리눅스 컨테이너 기술이므로 macOS나 windows에 설치할 경우는 가상 머신 기반 제공
가상 머신 정리
* Bare-Metal 방식이 가장 성능이 좋음
- 하드웨어 직접 엑세스하기 때문
- AWS(클라우드 컴퓨팅) 환경도 Bare-Metal 기반 가상 머신 기술 활용(KVM)
* Docker는 경량 이미지로 실행환경을 통쨰로 백업, 실행 가능(실무에 많이 사용됨)
- Data Engineering에서 Docker로 시스템 환경 설정 + 프로그램을 한번에 배포
- 예: 프로그램 업데이트 -> Docker 이미지 작성 -> Jenkins로 배치잡 생성 및 실행(AWS EC2 재생성 및 Docker 이미지 설치, 실행)
->Docker가 많이 쓰이는 이유는 가상환경때문이 아니라 실행환경을 통째로 백업할 수 있기 때문이다.
Java Virtual Machine
- 가상 머신과는 다른 목적(응용프로그램 레벨 가상화)
- Java 컴파일러는 CPU dependency를 가지지 않는 bytecode를 생성함
- 이 파일을 Java Virtual Machine에서 실행함
- 각 운영체제를 위한 Java Virtual Machine프로그램 존재
'Computer(인강) > 운영체제' 카테고리의 다른 글
실제 최신 운영체제 이해 및 운영체제 총정리(총정리 강의) (0) | 2021.02.28 |
---|---|
부팅의 이해 (0) | 2021.02.27 |
02. inode 방식과 가상 파일 시스템 (0) | 2021.02.27 |
파일 시스템 배경 (0) | 2021.02.27 |
가상 메모리 동작 이해 총정리 (0) | 2021.02.27 |