공유 메모리를 이용한 유저모드 폴링 기반 바이너리 호환 가상 머신 간 통신 기법

Binary-Compatible User-Mode Polling-Based Inter-VM Communication Techniques Using Shared Memory

초록

가상 머신의 호스트 및 타 가상 머신 간 데이터 교환에서 호환성을 위해 보편적으로 TCP/IP 프로토콜을 사용하나 성능상의 비효율성이 발생한다. 가상 머신 간 공유 메모리를 이용하여 통신할 경우 더 효율적인 데이터 전송이 가능하지만, 기존 TCP/IP 기반 프로그램을 재프로그램 혹은 재컴파일해야 하는 단점이 있다. 이를 해결하기 위한 가상 머신 간 공유 메모리 기반 바이너리 호환 통신 방법들이 연구되었으나 제거되지 못한 오버헤드가 존재한다. 이 논문은 현재의 가상 머신 간 공유 메모리 기반 바이너리 호환 통신 방법들의 오버헤드를 제거하는 기법을 제안한다. 제안한 구조에서는 기존 네트워크 스택을 TCP/IP 라이브러리의 함수 후킹으로 우회하였으며, 연결 별 전송 큐 및 유저모드 폴링 기법의 도입으로 커널모드 스위칭 오버헤드를 제거하였다. 결과에 따르면, 제시한 기법을 사용할 경우 기존 가상 네트워크 방식 대비 평균 레이턴시는 96.06% 감소, 평균 처리량은 222.24%가 증가하였다.

키워드

가상 네트워크가상 머신 간 공유 메모리바이너리 호환함수 후킹유저모드폴링virtual networkinter-vm shared memorybinary-compatiblefunction hookingusermodepolling
제목
공유 메모리를 이용한 유저모드 폴링 기반 바이너리 호환 가상 머신 간 통신 기법
제목 (타언어)
Binary-Compatible User-Mode Polling-Based Inter-VM Communication Techniques Using Shared Memory
저자
민지홍박주형박준석
DOI
10.5626/JOK.2020.47.11.1015
발행일
2020-11
유형
Y
저널명
정보과학회논문지
47
11
페이지
1015 ~ 1020