KR20170000568A - 인메모리 기반 가상 데스크탑 서비스를 위한 장치 및 방법 - Google Patents

인메모리 기반 가상 데스크탑 서비스를 위한 장치 및 방법 Download PDF

Info

Publication number
KR20170000568A
KR20170000568A KR1020150089625A KR20150089625A KR20170000568A KR 20170000568 A KR20170000568 A KR 20170000568A KR 1020150089625 A KR1020150089625 A KR 1020150089625A KR 20150089625 A KR20150089625 A KR 20150089625A KR 20170000568 A KR20170000568 A KR 20170000568A
Authority
KR
South Korea
Prior art keywords
virtual desktop
virtual
server
user
profile
Prior art date
Application number
KR1020150089625A
Other languages
English (en)
Other versions
KR101929048B1 (ko
Inventor
오수철
김대원
김선욱
문종배
오명훈
오병택
조정현
김성운
김학영
최지혁
Original Assignee
한국전자통신연구원
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 한국전자통신연구원 filed Critical 한국전자통신연구원
Priority to KR1020150089625A priority Critical patent/KR101929048B1/ko
Priority to US15/092,769 priority patent/US10379891B2/en
Publication of KR20170000568A publication Critical patent/KR20170000568A/ko
Application granted granted Critical
Publication of KR101929048B1 publication Critical patent/KR101929048B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45537Provision of facilities of other operating environments, e.g. WINE
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44505Configuring for program initiating, e.g. using registry, configuration files
    • G06F9/4451User profiles; Roaming
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces
    • G06F9/452Remote windowing, e.g. X-Window System, desktop virtualisation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45504Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45583Memory management, e.g. access or allocation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45595Network integration; Enabling network access in virtual machine instances

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Stored Programmes (AREA)

Abstract

본 발명은 인메모리 기반 가상데스크탑 서비스를 위한 장치 및 방법에 관한 것으로, 가상 데스크탑 서비스(Virtual Desktop Service)을 사용하는 사용자 단말과 가상 데스크탑 서비스를 제공하는 복수의 서버들 간에 사용되는 전달 프로토콜의 코디네이션 작업을 수행하는 커넥션 브로커; 상기 가상 데스크탑 서비스를 위한 운영체제를 포함하는 소프트웨어 리소스를 제공하는 리소스 풀; 및 하드웨어 리소스를 지원하고 상기 하드웨어 리소스에 상기 소프트웨어 리소스에 저장된 소프트웨어를 동적으로 할당하는 가상머신 인프라스트럭처;를 포함한다.

Description

인메모리 기반 가상 데스크탑 서비스를 위한 장치 및 방법{APPARATUS AND METHOD FOR VIRTUAL DESKTOP SERVICE BASED ON IN-MEMORY}
본 발명은 인메모리 기반 가상데스크탑 서비스를 위한 장치 및 방법에 관한 것이다.
요즈음, 데이터 저장 하드디스크와 애플리케이션 등을 인터넷 공간에 제공하는 서비스로서의 가상 데스크탑 서비스(Virtual Desktop Service)에 대한 연구 및
표준화 활동이 많이 이루어지고 있다.
한국공개특허 제2010-0123847호, 2009-0111576호 및 2009-0111576호 등은 가상 데스크탑 서비스 기술에 대하여 상세히 개시하고 있다. 하지만, 이러한 가상 데스크탑 서비스에 대한 아키텍처(Architecture)가 아직 표준화되지 않고 있는 상황이며, 이로 인해 사용자에게 가상 데스크탑 서비스를 효율적으로 제공하지 못하는 한계점이 있는 실정이다.
가상 데스크탑 서비스(VIRTUAL DESKTOP SERVICE)는 데이터를 저장하는 하드디스크와 응용 프로그램 등을 인터넷 공간에서 제공하는 서비스로서, 가상 데스크탑 서버에서 실행중인 가상 머신을 클라이언트 시스템에 접속하여 사용하는 서비스다.
종래의 가상 데스크탑을 제공함에 있어서, MS(Microsoft)에서 RDP(Remote Desktop Protocol)를 이용하여 RDC(Remote Desktop Connection)라는 터미널 서비스를 제공하는 방식, 리눅스에서는 RFB(Remote Framebuffer) 프로토콜을 이용하여 VNC(Virtual Network Computing)라는 터미널 서비스를 제공하는 방식, Teradici에
서 PCoIP(PC-over-IP)라는 프로토콜로 터미널 서비스 솔루션을 제공하는 방식들이
존재하였다.
이러한 종래의 방식을 이용하여 가상 데스크탑 서비스를 수행하기 위하여서는 사용자마다 가상 데스크탑 기능을 제공하여야 하며 이를 제공하기 위하여 각 사용자에게 해당되는 디바이스(CPU, Memory, HDD, USB 등)를 사용자에게 할당하고 사 용자용 OS 이미지를 할당하여야 한다.
이런 기능을 제공하기 위하여 공개 툴로서는 virt-tool, virt-manager 등이 존재하며, 시트릭스 사의 xendesktop이나 VMware Fusion 혹은 workstation등의 프
로그램을 이용하여 사용자용 가상머신을 만들고 생성 할 수 있으나, 이러한 종래의 방식들은 사용자는 클라이언트 시스템의 운영체제를 통하여 전용 소프트웨어를 직접 실행해야만 하는 단점이 있어 실시간 가상서비스를 제공하기 위하여 적합하지 않다.
또한, 종래의 가상 데스크탑 기술에서는 MS에서 RDP(Remote Desktop Protocol)를 이용하여 RDC(Remote Desktop Connection)라는 터미널 서비스를 제공하고, 리눅스에서는 RFB(Remote Framebuffer) 프로토콜을 이용하여 VNC(Virtual Network Computing)라는 터미널 서비스를 제공하고 있다. 또한, Teradici는 PCoIP(PC-over-IP)라는 프로토콜로 터미널 서비스 솔루션을 제공한다.
이와 같은 방식을 이용하여 가상 데스크탑 서비스를 수행하기 위해서는 사용자 마다 가상 데스크탑 기능을 제공하여야 하며 이를 제공하기 위하여 각 사용자에게 해당되는 디바이스(CPU, Memory, HDD, USB 등)를 사용자에게 할당하고 사용자용 OS 이미지를 할당하여야 한다.
이런 기능을 제공하기 위하여 공개 툴로서는 virt-tool, virt-manager등이 있고 시트릭스 사의 xendesktop이나 VMware Fusion 혹은 workstation등의 프로그램을 이용하여 사용자용 가상 데스크탑 또는 가상 머신을 만들고 생성 할 수 있으나 이는 수동 방식으로 제공되는 툴이기 때문에 실시간 가상서비스를 제공하기 위하여 적합하지 않다. 그리고, 서로 다른 이기종 서버 환경에서 구동 환경을 제공하기 위한 방법이 적합하지 않다.
또한, 가상 디스크에 가상 데스크탑을 위한 운영체제 및 응용 프로그램이 설치되어 있는 것을 가상 데스크탑 이미지라고 한다. 가상 데스크탑이 부팅 및 운영되기 위해서는 항상 가상 데스크탑 이미지를 접근한다.
단일 가상 데스크탑 서버에는 수십대의 가상 데스크탑이 운영되고 있으며, 가상 데스크탑 부팅과 같이 모든 가상 데스크탑이 일시에 가상 데스크탑 이미지를 접근할 경우, 가상 데스크탑 이미지가 저장되어 있는 가상 디스크에 로드가 집중됨으로써, 전체 시스템의 성능이 저하되는 문제가 발생한다. 특히, 가상 디스크는 가상 데스크탑 서버의 다른 자원들(CPU, 메모리)에 비해서 속도가 현저히 느림으로, 성능 저하 현상은 더 크게 발생한다.
이러한 배경에서, 본 발명은 가상 데스크탑 서비스를 효율적으로 제공할 수 있는 아키텍처(Architecture)를 제공하는 데 주된 목적이 있다.
본 발명에서는 해결하고자 하는 기술적 목적은 사용자 요청 시 실시간으로 VM을 생성하고 이를 기반으로 실시간 가상 데스크톱 서비스를 제공할 수 있는 서버 가상 머신 제공 방법 및 시스템과 이를 지원하는 장치를 제공하는데 있다
본 발명은 서로 다른 이기종의 서버 환경에서 가상 데스크탑 서비스를 제공할 경우에 사용자가 수동으로 프로파일을 수정하거나 오랜 시간 마이그레이션을 통해 제공하는 방법 대신에 보다 효과적으로 가상 데스크탑 서비스를 제공할 수 있는 프로파일 관리 기술을 제공하는 것이다.
본 발명은 상기한 종래의 문제점을 해결하기 위해 제안된 것으로, 디스크에 집중되는 부하를 제거하기 위해서 가상 데스크탑 이미지를 메인 메모리에 저장하고, 이를 사용하여 운영하는 인메모리 가상 데스크탑 시스템을 제공함에 그 목적이 있다.
상기와 같은 목적을 달성하기 위해 본 발명은 가상 데스크탑 서비스(Virtual Desktop Service)을 사용하는 사용자 단말과 가상 데스크탑 서비스를 제공하는 복수의 서버들 간에 사용되는 전달 프로토콜의 코디네이션 작업을 수행하는 커넥션 브로커; 상기 가상 데스크탑 서비스를 위한 운영체제를 포함하는 소프트웨어 리소스를 제공하는 리소스 풀; 및 하드웨어 리소스를 지원하고 상기 하드웨어 리소스에 상기 소프트웨어 리소스에 저장된 소프트웨어를 동적으로 할당하는 가상머신 인프라스트럭처;를 포함한다.
상기와 같은 목적을 달성하기 위해 본 발명은 커넥션 브로커가 가상 데스크탑 서비스(Virtual Desktop Service)를 위한 사용자 단말의 하드웨어에 적합한 가상 머신을 찾는 단계; 상기 커넥션 브로커가 상기 적합한 가상 머신이 없는 경우 가상머신 인프라스트럭처에 해당 가상머신 생성을 요청하고, 상기 적합한 가상 머신이 있는 경우 상기 커넥션 브로커가 해당 가상 머신에 사용자 프로파일을 적용하고 가상 데스트탑을 생성하는 단계; 및 상기 커넥션 브로커가 상기 생성된 가상 데스크탑을 상기 사용자 단말에 전송하기 위한 연결 정보를 가상 데스크탑의 전송 프로토콜을 사용하여 상기 가상 데스크탑을 상기 사용자 단말에 전송하는 단계;를 포함한다.
이상에서 설명한 바와 같이 본 발명에 의하면, 가상 데스크탑 서비스를 효율적으로 제공할 수 있는 아키텍처(Architecture)를 제공하는 효과가 있다.
본 발명에 따르면, 가상화 데스크탑 매니저 및 클라이언트 장치를 가지는 DaaS 시스템이 적용되어, 데스크탑 가상화를 이용한 멀티 피씨(PC) 시스템을 이용하여 효율적인 관리가 가능하며, 시스템 적용이 용이하고 기존 가상화 시스템에도 적용가능 할 수 있다.
도 1은 본 발명의 실시예에 따른 가상 데스크탑 서비스를 위한 서비스 아키텍처를 나타낸 도면이다.
도 2는 본 발명의 실시예에 따른 가상 데스크탑 서비스를 위한 서비스 아키텍처에 대한 개념적인 다이어그램이다.
도 3은 본 발명의 실시예에 따른 가상 데스크탑 서비스를 위한 방법에 대한 흐름도이다.
도 4는 본 발명의 실시예에 따른 가상 데스크탑 서비스를 위한 기능상 계층화된 아키텍처를 나타낸 도면이다.
도 5는 본 발명의 실시예에 따른 가상 데스크탑 서비스를 위한 기능상 계층화된 아키텍처에 대한 개념적인 다이어그램이다.
도 6은 본 발명의 일실시예에 따른 데스크탑 가상화 시스템의 구성을 나타내는 도면이다.
도 7는 본 발명의 일실시예에 따른 가상화 데스크탑 매니저 장치를 나타내는 도면이다.
도 8은 본 발명의 일실시예에 따른 가상화 데스크탑 클라이언트 장치를 나타낸 도면이다.
도 9는 본 발명의 일실시예에 따른 가상화 데스크탑 매니저 장치를 통한 관리 방법을 나타낸 흐름도이다.
도 10은 본 발명의 일실시예에 따른 가상화 데스크탑 클라이언트 장치를 통한 관리방법을 나타낸 흐름도이다.
도 11은 본 발명의 실시예에 따른 가상 데스크톱 서비스 구조를 개략적으로 나타낸 도면이다.
도 12는 본 발명의 실시예에 따른 고가용성(HA : High Ability) 서버 가상 머신 제공을 위한 서버 가상 머신 제공 시스템의 전체 구성 중 서버 구성들을 나타낸
도면이다.
도 13은 본 발명의 실시예에 따른 가상 데스크톱 서비스 중 사용자 허가를 설명하기 위한 도면이다.
도 14는 본 발명의 실시예에 따른 가상 데스크톱 서비스 지원을 위한 관리 서버의 구성을 개략적으로 나타낸 도면이다.
도 15는 본 발명의 실시예에 따른 가상 데스크톱 서비스 중 Allocated User의 가상 머신 생성 및 할당을 설명하기 위한 도면이다.
도 16은 본 발명의 실시예에 따른 가상 데스크톱 서비스 중 Pooled User의 가상 머신 생성 및 할당을 설명하기 위한 도면이다.
도 17은 본 발명의 실시예에 따른 가상 데스크톱 서비스 중 Multi-VM User의 가상 머신 생성 및 할당을 설명하기 위한 도면이다.
도 18은 사용자 요청에 따른 가상 머신 생성 방법을 설명하기 위한 도면이다.
도 19는 본 발명의 이미지 생성기 운용을 설명하기 위한 순서도이다.
도 20은 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 방법을 나타낸 동작흐름도이다.
도 21는 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 방법을 상세하게 나타낸 동작흐름도이다.
도 22은 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 장치를 이용한 가상 데스크탑 시스템을 나타낸 블록도이다.
도 23는 도 22에 도시된 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 장치의 일예를 나타낸 블록도이다.
도 24는 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 장치를 이용한 가상 데스크탑 시스템을 상세하게 나타낸 도면이다.
도 25은 종래의 하드 디스크 기반의 가상 데스크탑 시스템의 구성도이다.
도 26는 본 발명의 실시예에 따른 메인 메모리 기반의 가상 데스크탑 시스템의 개요도이다.
도 27은 본 발명의 실시예에 따른 메인 메모리 기반의 가상 데스크탑 시스템의 구성을 구체적으로 도시한 도면이다.
도 28는 도 27에 도시된 메인 메모리의 구조를 나타낸 도면이다.
도 29는 도 27에 도시된 가상 디스크에 대한 읽기 과정을 설명하기 위한 흐름도이다.
도 30은 도 27에 도시된 가상 디스크에 대한 읽기/쓰기 과정 설명에 채용되는 도면이다.
도 31은 본 발명의 실시예에 채용되는 중복 제거 테이블을 설명하는 도면이다.
도 32은 도 27에 도시된 가상 디스크에 대한 쓰기 과정을 설명하기 위한 흐름도이다.
도 33는 도 27에 도시된 메인 메모리의 가상 데스크탑 이미지 저장 및 로딩 설명에 채용되는 도면이다.
도 34은 도 27에 도시된 메모리-디스크 저장 모듈부의 동작 순서도이다.
도 35은 도 27에 도시된 디스크-메모리 로딩 모듈부의 동작 순서도이다.
이하, 본 발명의 일부 실시예들을 예시적인 도면을 통해 상세하게 설명한다. 각 도면의 구성요소들에 참조부호를 부가함에 있어서, 동일한 구성요소들에 대해서는 비록 다른 도면상에 표시되더라도 가능한 한 동일한 부호를 가지도록 하고 있음에 유의해야 한다. 또한, 본 발명을 설명함에 있어, 관련된 공지 구성 또는 기능에대한 구체적인 설명이 본 발명의 요지를 흐릴 수 있다고 판단되는 경우에는 그 상세한 설명은 생략한다.
또한, 본 발명의 구성 요소를 설명하는 데 있어서, 제 1, 제 2, A, B, (a),(b) 등의 용어를 사용할 수 있다. 이러한 용어는 그 구성 요소를 다른 구성 요소와 구별하기 위한 것일 뿐, 그 용어에 의해 해당 구성 요소의 본질이나 차례 또는 순서 등이 한정되지 않는다. 어떤 구성 요소가 다른 구성요소에 "연결", "결합" 또는 "접속"된다고 기재된 경우, 그 구성 요소는 그 다른 구성요소에 직접적으로 연결되거나 또는 접속될 수 있지만, 각 구성 요소 사이에 또 다른 구성 요소가 "연결", "결합" 또는 "접속"될 수도 있다고 이해되어야 할 것이다.
도 1은 본 발명의 실시예에 따른 가상 데스크탑 서비스(Virtual DesktopService)를 위한 서비스 아키텍처(Service Architecture)를 나타낸 도면이다.
서비스 제공자(Service Provider)의 입장에서 종단-사용자(End-User)에게 가상 데스크탑 서비스를 제공하기 위하여 몇몇의 단계들이 있으며, 이러한 단계들은 도 1에 도시된 바와 같이, 커넥션 브로커(CB: Connection Broker, 110), 리소스풀(Resource Pool, 120) 및 가상머신 인프라스트럭처(Virtual MachineInfrastructure, 130)를 포함하는 3가지의 주요 액터들(Actors)에 의해 수행될 수 있다.
이하에서는, 3가지의 주요 액터들(Actors)의 기능에 대하여 도 2를 참조하여 설명한다. 도 2는 본 발명의 실시예에 따른 가상 데스크탑 서비스를 위한 서비스 아키텍처에 대한 개념적인 다이어그램(Conceptual Diagram)이다.
도 2를 참조하면, 커넥션 브로커(110)는 사용자 단말(20)이 가상 데스크탑(Virtual Desktop, 200)에 연결되도록 하는 소프트웨어 프로그램일 수 있으며, 사용자 단말(20)과 사용자 단말(20)의 소프트웨어를 승인하기(validate) 위한 사용자 인증(User Authentication, 211) 및 라이센스 확인(License Verification, 212)기능과, 사용자 단말(20)에 할당되는 가상머신(VM: Virtual Machine)의 관리 기능과, 가상머신의 활동 레벨(Activity Level)을 측정하는 서버의 모니터링 기능(213)과, 사용자 단말(20)과 서버 간에 동일한 프로토콜이 사용되도록 하는 프로토콜 코디네이션(Protocol Coordination, 214) 기능을 수행한다. 이러한 커넥션 브로커(110)는, 백업 스토리지(Backup Storage)와 가상 데스크탑 서비스 서버(Virtual Desktop Servers) 간의 연결(Connection)을 제공할 수 있다.
도 2를 참조하면, 리소스 풀(120)은, 요구형(On-Demand) 가상 데스크탑 서비스를 제공하기 위하여, 운영체제(OS: Operating Systems), 애플리케이션(Applications) 및 사용자 프로파일들(User Profiles) 등과 같은 3개의 다른 타입의 고성능 소프트웨어 리소스들(High-Capacity Software Resources)을 관리할 수 있다. 즉, 리소스 풀(120)은, 도 2에 도시된 바와 같이, 운영체제 풀(OS Pool,221), 애플리케이션 풀(Application Pool, 222) 및 사용자 프로파일 풀(User Profile Pool, 223) 등을 포함한다. 이러한 리소스 풀(120)에 의해 관리되는 소프트웨어 리소스들은 스트리밍 형태로의 소정의 시간에 특정 가상머신으로 전달되고 특정 가상머신 상에서 실행된다.
그리고, 리소스 풀(120)은 커넥션 브로커(110)에 의한 요청으로 해당 소프트웨어 리소스에 관한 프로비전 정보(Provision Information, 224)를 제공할 수 있다. 위에서 언급한 사용자 프로파일은, 일 예로, 하드웨어 구성(예를 들면, CPU, RAM, I/O 등), 사용되는 운영체제(OS), 선택된 애플리케이션, 사용자의 컴퓨팅 환경 정보(예를 들면, 디스플레이 해상도, 인터넷 액세스 방식 등)에 대한 개별 정보를 포함할 수 있다. 이러한 사용자 프로파일은 사용자별로 관리될 수 있다.
도 2를 참조하면, 가상머신 인프라스트럭처(130)는, 하드웨어 리소스(Hardware Resources, 231)를 지원하고 가상머신(VM: Virtual Machine, 232)을 생성하는 주요 역할을 한다. 가상 데스크탑 서버(Virtual Desktop Server)에서, 일 예로, 하이퍼바이저(Hypervisor, 233)라고도 불리는 가상화 기술(Virtualization Technology)은 위에서 언급한 하드웨어 리소스(231)를 효율적으로 사용하기 위해서 매우 필요할 것 이다. 위에서 언급한 하이퍼바이저(233)는 물리적인 하드웨어 리소스들(231)을 추출(Abstract)하여 소프트웨어(234)의 상위 레벨로 동적으로 할당한다.
즉, 이러한 가상머신 인프라스트럭처(130)에서 지원되는 하드웨어 리소스(231)는, 물리적인 하드웨어 리소스(231)를 추출(Abstract)해서 소프트웨어(234)의 상위 레벨로 동적으로 할당하는 가상 데스크탑 서버 내에서의 하이퍼바이저(Hypervisor) 가상화 기술에 의해 효율적으로 사용될 수 있다. 결과적으로, 가상머신 인프라스트럭처(130)는 사용자 단말(20)의 소프트웨어(234)가 동작되는 가상머신들(232)을 제공한다. 이러한 가상머신들을 가상 데스크탑들(Virtual Desktops, 200)이라 한다.
아래에서는, 가상 데스크탑 서비스를 위한 방법을 도 3을 참조하여 설명하고, 이때, 가상 데스크탑 서비스를 위한 서비스 아키텍처에 대한 개념적인 다이어그램을 도시한 도 2를 함께 참조한다. 도 3은 본 발명의 실시예에 따른 가상 데스크탑 서비스를 위한 방법에 대한 흐름도이다.
도 3을 참조하면, 본 발명의 실시예에 따른 가상 데스크탑 서비스를 위한 방법은 사용자 단말 접속 및 사용자 확인 단계(S300), 가상머신 검색 단계(S302), 사용자 프로파일 적용 단계(S308), 세션 생성 단계(S310), 사용자 단말 연결 단계(S312), 경험 정보 커뮤니케이션 단계(S314), 로그-오프 동작 및 사용자 프로파일 업데이트 단계(S316) 등에 따라 진행된다.
사용자 단말 접속 및 사용자 확인 단계(S300)에서는, 사용자 단말(20)이 SSH(Secure Shell) 및 TLS(Transport Layer Security) 등 중 하나 이상의 보안 프
로토콜을 통하여 접속되면, 커넥션 브로커(110)는 사용자 ID 및 비밀번호로 해당
사용자를 확인(Validate)한다. 가상머신 검색 단계(S302)에서, 커넥션 브로커(110)는, 가상머신 할당을 위해서, 해당하는 사용자 프로파일(User Profile)을 식별하고, 프로비저닝 기능(Provisioning Function)을 이용하여 사용자 단말(20)의 하드웨어 구성을 만족하고 컴퓨팅 환경에 최적인 가상머신을 검색한다.
이러한 가상머신 검색 단계(S302)에서의 검색 결과에 가상머신 검색 유무를 판단(S304)하여, 적당한 가상머신이 없으면, 커넥션 브로커(110)가 하드웨어 구성에 대한 정보를 전송함으로써 가상머신 인프라스트럭처(130)에게 가상머신 생성을 요청한다. 이에 따라, 가상머신 인프라스트럭처(130)에서 가상머신이 생성된다(S306).
사용자 프로파일 적용 단계(S308)에서, 가상머신이 할당되거나 생성된 이후, 커넥션 브로커(110)는, 사용자 프로파일을 할당되거나 생성된 가상머신에 적용(Apply)한다. 이러한 사용자 프로파일 적용 단계(S308)에서, 커넥션 브로커(110)는 가상 데스크탑(200)을 구성(Construct) 하기 위한 운영체제(OS) 및 애플리케이션을 설치(Installation)할 수 있다. 세션 생성 단계(S310)에서, 가상 데스크탑(200)을 전달하기 위한 세션(Session)이 가상머신 인프라스트럭처(130) 내에서 생성되고, 생성된 세션에 대한 세션 정보가 커넥션 브로커(110)로 디스패치(Dispatch)된다. 사용자 단말 연결 단계(S312)에서, 커넥션 브로커(110)는 세션 정보를 사용자 단말(20)로 전송하고, 사용자 단말(20)은 가상머신 인프라스트럭처(130)와 연결된다.
경험 정보 커뮤니케이션 단계(S314)에서, 사용자 단말(20)은 가상 데스크탑 전송 프로토콜(VDDP: Virtual Desktop Delivery Protocol)을 이용하여 가상 데스크탑(200)에 의해서 사용자들의 경험(Experience) 정보를 커뮤니케이션(Communication)한다. 로그-오프 동작 및 사용자 프로파일 업데이트 단계(S316)에서, 사용자 단말(20)은 가상 데스크탑 서비스가 종료될 때 사용자 데이터의 손실을 방지하기 위하여 로그-오프(Log-Off) 동작을 실행하고, 이러한 로그-오프 동작 도중에, 커넥션브로커(110)는 변경된 사용자 프로파일을 사용자 프로파일 풀(User Profile Pool,223) 내에 업데이트한다. 이러한 로그-오프 동작 및 사용자 프로파일 업데이트 단계(S316)에서, 커넥션 브로커(110)는 해당 가상머신이 이용 가능한 상태가 되도록 해당 가상머신을 리턴(Return) 시킬 수 있다.
이하에서는, 본 발명의 실시예에 따른 가상 데스크탑 서비스의 기능상 레이어(Functional Layer)에 대하여 도 4 및 도 5를 참조하여 설명한다. 도 4는 본 발명의 실시예에 따른 가상 데스크탑 서비스를 위한 기능상 계층화된 아키텍처(Functional Layered Architecture)를 나타낸 도면이다.
도 4를 참조하면, 본 발명의 실시예에 따른 가상 데스크탑 서비스를 위한 기능상 계층화된 아키텍처는, 사용자 레이어(User Layer, 410), 클라우드 액세스 및 퍼블리케이션 레이어(Cloud Access and Publication Layer, 420), 클라우드 네트워
크 서비스 오케스트레이션 레이어(Cloud Network Service Orchestration Layer,
430), 클라우드 서비스 레이어(Cloud Services Layer, 440) 및 리소스 레이어(Resource Layer, 450) 등의 기능적인 레이어(Functional Layer)를 포함한다.
아래에서는, 위에서 언급한 기능적인 레이어 각각에 대하여 도 5를 참조하여 설명한다. 도 5는 본 발명의 실시예에 따른 가상 데스크탑 서비스를 위한 기능상 계층화된 아키텍처를 나타낸 도면이다.
도 5를 참조하면, 사용자 레이어(410)는, 사용자 단말(50)과 클라우드 인프라스트럭처(Cloud Infrastructure) 간의 인터랙션(Interaction)을 수행하고, 클라우드 서비스 요청을 전송하며, 클라우드 서비스 액세스를 수행하고, 클라우드 리소스를 관리하거나 모니터하기 위해 사용되고, 종단 사용자 기능(End User Function,511), 단말 적응 기능(Terminal Adaptation Function, 512), 관리 기능(Administration Function, 513), 파트너(510)와의 파트너 기능(Partner Function, 514) 및 인터-클라우드 기능(Inter-Cloud Function, 515) 등을 포함한다.
클라우드(Cloud)가 클라우드 서비스 요청을 수신할 때, 클라우드는 인터-클라우드 기능(515)을 통해 자신의 리소스 또는 다른 클라우드의 리소스를 조직(Orchestrate)하고, 클라우드 서비스를 사용자 레이어(515)를 통해 제공한다. 종단 사용자 기능(511)은 종단 사용자, 즉 사용자 단말(50)이 클라우드 서비스에 액세스하고 클라우드 서비스를 소비(consume)하도록 지원한다. 관리 기능(513)은 기업 관리자가 비즈니스 프로세스 내에서 클라우드 리소스 및 서비스를 관리하는 것을 지원한다. 파트너 기능(514)은 클라우드 서비스 공급자를 통해 파트너 관계를 가능하게 한다.
인터-클라우드 기능(515)은 여러 개의 CSP(Cloud Service Provider)들의 클라우드들과 인터커넥트(Interconnection)하기 위하여 인터커넥션 인터페이스 (Interconnection Interface) 및 브로커(Broker) 기능을 제공한다. 이러한 인터- 클라우드 기능(515)은 인터-클라우드 서비스 브로커 기능(Inter-Cloud Service Broker function), 인터-클라우드 포털 기능(Inter-Cloud Portal function) 등을 포함한다. 인터-클라우드 브로커 기능은 다른 CSP들(52)의 클라우드 서비스 및 리소스에 접근하기 위하여 클라우드 사용자들 또는 애플리케이션들에 대한 대체 가능한솔루션(Alternative Solution)을 제공한다. 가상 데스크탑 서비스를 위한 사용자 단말은 랩탑(Laptop), 데스크탑 PC, 씬클라이언트(Thin Client), 모바일 폰 등과 같이 다양한 종류일 수 있다. 또한, 단말 적응(Terminal Adaptation)은 다른 대역 환경에서 다른 주변기기(Peripherals)를 가지는 다양한 해상도 중에서 단말 장치가 적당한 데스크탑을 제공할 수 있도록 하는 기능을 의미한다.
도 5를 참조하면, 클라우드 액세스 및 퍼블리케이션 레이어(420)는, 수동 및 자동화된 클라우드 액션 및 소비(Cloud Actions and Consumption)를 위해 커먼 인 터페이스(Common Interface)를 제공하고, 클라우드 서비스 제공자(CSP: Cloud Service Provider)들의 서비스 및 리소스에 액세스하기 위한 클라우드 애플리케이션 프로그램 인터페이스(API: Application Program Interface)들을 사용하여 소비자 또는 비즈니스 프로세스들의 클라우드 서비스 소비 요청을 수락하고, 네트워크종료 기능(Network termination function), API 종료 기능(API termination function) 및 인터-클라우드 중재 기능(Inter-Cloud Mediation function) 등을 포함한다.
도 5를 참조하면, 클라우드 네트워크 서비스 오케스트레이션 레이어(430)는, 전체 정보 시스템 환경으로의 접근 또는 네트워크를 통한 원격 클라이언트 디바이스로의 접근을 인캡슐레이션(Encapsulation) 하고 전달하는 가상 데스크탑 전송 기능(Virtual Desktop Delivery Function, 531)과, 커넥션 브로커가 사용자 데스크탑세션을 인증하기 위하여 디렉토리 서버를 참조(Consult)함으로써 다른 보안 레벨에대한 개인화된 애플리케이션의 조합으로 승인된 접근을 제공하는 인증(Authentication) 엔티티(Entity), 사용자 단말과 가상 데스크탑 간에 다양한 통신 프로토콜이 있을 수 있는데, 커넥션 브로커가 사용자 데스크탑 세션이 인증 이후에 데이터 및 비디오 전송을 위한 공통 통신 프로토콜이 사용자 단말과 가상 데스크탑 간에 사용되도록 코디네이트하는 기능을 수행하는 코디네이션(Coordination) 엔티티, 커넥션 브로커가 가상머신의 런타임(Runtime) 상태 모니터링을 수행하고 필요한 애플리케이션에 대한 동작 환경을 보장하는 액션을 수행하는 모니터링 및 관리(Monitoring and Management) 엔티티, 및 커넥션 브로커가 사용자 단말(50)로 하여금 가상 데스크탑에 호스트되어 있는 승인된 애플리케이션에 접근할 수 있도록 하기 위하여 소프트웨어 라이센스 확인 기능을 제공하는 확인(Verification) 엔티티로 구성된 커넥션 브로커 기능(Connection Broker Function, 532) 등을 포함한다.
전술한 가상 데스크탑 전송 기능(Virtual Desktop Delivery Function, 531)에서, 가상 데스크탑 전송 프로토콜(VDDP)는 가상 데스크탑 전송 기능(531)의 핵심구성요소이며, 일 예로, 디스플레이, 입력, 커서, 제어 및 구성, 모니터링 정보 등의 모든 상호작용 정보(인터랙션 정보)를 전달하기 위해서 DaaS(Desktop as aService)를 위한 서버와 사용자 단말(50) 사이에 통신 채널을 제공한다. 또한, 전술한 모니터링 및 관리(Monitoring and Management) 엔티티에서 커넥션 브로커는, 새로 도달한 요청에 대하여 새로운 아이들(Idle) 가상머신 인스턴스(Virtual Machine Instance)를 할당하거나, 또는 시스템 실패(Failure)로부터 복구된 이후에 클라이언트 측 디바이스에 의해 제기된 요청에 대하여 이전 인스턴스(Previous Instance)를 할당하도록 가상머신 인프라스트럭처에게 지시하고, 커넥션 브로커가 새로운 로그인 사용자 세션(Login User Session)을 위하여 새로운 클라우드 가상머신을 준비하도록 가상머신 인프라스트럭처에게 요청할 수 있다. 전술한 클라우드 네트워크 서비스 오케스트레이션 레이어(430)는, 기록 기능(Records Function, 533), 구성 기능(Configuration Function, 534) 등을 더 포함한다.
도 5를 참조하면, 클라우드 서비스 레이어(440)는, 광대역 네트워크를 통해서 사용자 단말(50)에게 가상 데스크탑 서비스를 제공하는 DaaS(Desktop as a Service) 기능(541)과, 게스트 OS(Guest OS) 및 애플리케이션이 직렬화되어(Serialized) 저장되어 있는 광역 리소스 저장(Repository) 또는 저장 서버 세트(Repository Server Set) 이고, 클라우드 가상머신이 가상머신 인프라스트럭처에서 생성되도록 하는 가상 템플릿을 생성하기 위한 시각화된 모델링 툴(Visualized Modeling Tool)을 구비하며, 실행중인 가상 데스크탑으로부터 필요하고 운영체제,애플리케이션 소프트웨어, 사용자 프로파일 및 시스템 구성을 포함하는 리소스를 동적으로 어셈블(Assemble)하고 해당되는 이미지 파일을 생산하는 능력을 가지고, 상기 가상머신 인프라스트럭처와의 통신을 가능하게 하고 직렬화된 이미지 파일로부터 원격에서 가상 데스크탑을 생성하는 것을 가능하게 하는 네트워크 기반의 부트 스트랩 프로토콜(Boot Strap Protocol)을 지원하는 리소스 풀(Resource Pool)기능(545)을 포함한다. 전술한 클라우드 서비스 레이어(440)는, 도 5에 도시된 바와 같이, 서비스 오케스트레이션 기능(Service Orchestration function, 542), 서비스 퍼블리케이션기능(Service Publication function, 543) 및 서비스 적응 기능(Service Adaptation function, 544) 등을 더 포함할 수 있다.
도 5를 참조하면, 리소스 레이어(450)는, 컴퓨팅 리소스, 저장 리소스, 네트워크 리소스, 파워 리소스(Power Resource) 및 클라우드 컴퓨팅 환경 내에 필수적인 다른 구성들(Facilities)을 포함하는 물리적인 리소스(Physical Resource, 551)와, 가상머신, 가상 네트워크 리소스 및 가상 스토리지 리소스를 포함하는 가상 리
소스(Virtual Resource, 552)를 가진다. 가상머신은 XEN, KVM 등과 같은 각각 다른 서버 가상화 기술(Server Virtualization Technologies)에 의하여 가상머신 인프라스트럭처(553) 내에 생성되는 가상화 머신을 의미한다. 도 5를 참조하면, 본 발명의 실시예에 따른 가상 데스크탑 서비스를 위한 기능상 계층화된 아키텍처는 모니터링 및 SLA 기능과 관리, 지원 및 보안 기능을 포함하는 크로스 레이어 기능(Cross Layer Function, 560)을 더 제공할 수 있다.
위에서 언급한 가상머신 인프라스트럭처(553)는 HA 특성을 가지는 클러스트환경을 의미하며, 그 내부에서는 많은 실행 가상머신 인스턴스가 동일한 가상머신템플릿(Template)으로부터 생성되어 동일한 파라미터로 구성되어 있다. 거의 모든가상머신 인프라스트럭처(553)는 가상머신 이동 능력(Migration Capability)을 제공하고 있어서, 비즈니스 연속성을 유지하기 위하여 시스템 실패(Failure)의 경우실행중인 인스턴스가 다른 호스팅 서버로 이동하는 것을 가능하게 한다. 본 명세서에서 기재된 가상 데스크탑 서비스(Virtual Desktop Service)는 데이터 저장 하드디스크와 애플리케이션 등을 인터넷 공간에 제공하는 서비스일 수 있으며, 즉, 개인용 PC 또는 업무용 데스크탑을 실제 물리적 하드웨어를 이용하는 것이 아니라 데스크탑 가상화 기술을 적용하여 가상머신을 이용한 데스크탑 서비스일 수 있다. 이때 생성된 데스크탑 용 가상머신은 인터넷 데이터 센터 등 원격에 위치하고 언제 어디서나 마치 로컬 데스크탑처럼 사용이 가능하다. 본 명세서에서 기재된 가상 데스크탑 서비스(Virtual Desktop Service)는 DaaS(Desktop as a Service) 서비스 또는 클라우드 컴퓨팅(Cloud Computing) 서비스 또는 클라우드 데스크탑 서비스(Cloud Desktop Service) 등일 수 있다. 본 발명의 실시예에 따른 가상 데스크탑 서비스를 위한 아키텍처(서비스 아키텍처 및 기능상 계층화된 아키텍처)는, 가상 데스크탑 서비스를 사용자 단말로 제공하는 시스템(System) 또는 서버(Server)의 설계 방식이거나, 가상 데스크탑 서비스를 사용자 단말로 제공하는 시스템(System) 또는 서버(Server) 그 자체일 수도 있다.
도 6은 본 발명의 일실시예에 따른 데스크탑 가상화 시스템의 구성을 나타내 는 도면이다.
도 6을 참고하면, 본 발명의 일실시예에 따른 데스크탑 가상화 시스템(이하, DaaS 시스템이라고도 한다.)은 가상화 데스크탑 매니저 장치(1000) 및 가상화 데스크탑 클라이언트 장치(2000)를 포함하여 구성된다.
가상화 데스크탑 매니저 장치(1000)는 사용자의 요청에 따라 가상화 데스크탑 클라이언트 장치(2000)에 가상화 데스크탑 서버를 할당하고 가상 머신의 생성, 관리, 소멸 및 마이그레이션을 관리하는 기능을 제공한다. 가상화 데스크탑 매니저 장치(1000) 및 가상화 데스크탑 클라이언트 장치(2000)의 세부구성은 이하 도 7 및 도 8을 통해서 상세히 후술한다.
도 7은 본 발명의 일실시예에 따른 가상화 데스크탑 매니저 장치를 나타내는 도면이다.
도 7을 참고하면, 본 발명의 일실시예에 따른 가상화 데스크탑 매니저 장치(1000)는 연결모듈(1100), 할당모듈(1200), 관리모듈(1300) 및 웹 서버모듈(1400)을 포함하여 구성된다.
연결모듈(1100)은 사용자 인증을 완료한 사용자에 대하여 가상화 데스크탑 클라이언트 장치(2000)와 가상화 데스크탑 서버의 연결을 허용한다. DaaS 시스템을 통해 사용자가 원격으로 가상화 데스크탑 서비스를 제공받기 위해서는 가상화 데스크탑 서버와 연결시켜주는 연결모듈(1100)과 접속을 한다. 이 때, 연결모듈(1100)은 사용자 인증에 따라 접속을 하게 된 사용자에 한하 여 사용자의 요청 정보와 현재 시스템을 구성하는 가상화 데스크탑 서버의 가상 머신 정보를 통해서 임의의 가상 머신의 할당을 허용한다. 또한, 연결모듈(1100)은 가상화 데스크탑 서버의 할당 이후, 할당된 가상 머신의 원격 접속 프로토콜을 이용한 가상화 데스크탑 환경의 연결 기능 및 화면 리다이렉션 기능을 제공할 수 있다. 또한, 연결모듈(1100)은 사용자에 의하여 할당된 가상 머신의 사용이 끝나
면, 사용자가 원하는 시점에 다시 접속 가능하도록 사용자 계정에 따른 현재 환경
설정을 저장하고 가상화 데스크탑 연결 기능을 제거 하고 화면 리다이렉션 기능도
제거할 수 있다.
할당모듈(1200)은 가상화 데스크탑 서버의 운용 상태를 파악해서 가상화 데스크탑 클라이언트 장치(2000)에 최적의 가상화 데스크탑 서버를 할당한다. 이 때, 할당모듈(1200)은 연결모듈(1100)을 통해 가상화 데스크탑 서비스를 요청하는 원격 사용자에게 최상의 가상화 데스크탑 서비스를 지원하는 가상 머신을 할당하기 위해서 가상화 데스크탑 서버들의 자원 사용 및 가상 머신의 할당 정보를 실시간 모니터링하는 가상 머신 프로비져닝 기능을 제공할 수 있다. 이 때, 할당모듈(1200)은 DaaS 시스템을 구성하는 가상화 데스크탑 서버들의 자원 할당 상태, 사용 정보 및 생성된 가상 머신들의 사용 여부를 실시간으로 모니터링할 수 있다. 이 때, 할당모듈(1200)은 원격 사용자에게 최상의 사용자 맞춤형 가상화 데
스크탑 서버를 제공하며, 가상 머신에 대한 문제 발생시 실시간으로 다른 가상 머
신을 할당할 수 있다. 이 때, 할당모듈(1200)은 가상머신의 운용을 위한 이미지와 가상화 데스크탑클라이언트 장치(2000)의 사용자용 디스크 이미지를 분리하여 가상화 데스크탑 서버를 할당할 수 있다.
관리모듈(1300)은 가상화 데스크탑 서버 및 가상 머신의 운용 상태를 모니터링하고, 가상화 데스크탑 서버의 제어 명령을 수행한다. 웹 서버모듈(1400)은 사용자에게 웹 기반의 관리 툴 GUI를 제공한다.
도 8은 본 발명의 일실시예에 따른 가상화 데스크탑 클라이언트 장치를 나타낸 도면이다. 도 8을 참고하면, 본 발명의 일실시예에 따른 가상화 데스크탑 클라이언트장치(2000)는 하이퍼바이저(2100), 모니터링 정보 수집기(2300), 하드웨어 프로파일 수집기(2400), 성능 측정기(2500) 및 명령실행부(2600)를 포함하여 구성된다. 이 때, 모니터링 정보 수집기(2300), 하드웨어 프로파일 수집기(2400), 성능측정기(2500) 및 명령실행부(2600)는 가상화 데스크탑 에이전트(2050)로 구성될 수 있다.
하이퍼바이저(2100)는 하드웨어 위로 1 이상의 가상 머신(2200)을 수용한다. 하이퍼바이저(2100)는 프로그래밍된 데몬을 이용하여 가상 머신(2200) 및 가상화 데스크탑 에이전트(2050)의 구성들과 통신할 수 있다. 이 때, 가상 머신(2200)의 타입은 전가상화 또는 반가상화 형태로 구성할 수 있다. 모니터링 정보 수집기(2300)는 가상 머신(2200)을 모니터링한다.
하드웨어 프로파일 수집기(2400)는 가상화 데스크탑 클라이언트 장치(2000)의 하드웨어 정보 및 OS레벨 정보를 수집한다. 성능 측정기(2500)는 모니터링 정보 수집기(2300)에서 모니터링 된 정보를 이용하여 가상 머신(2200)의 성능 정보를 계산한다. 명령실행부(2600)는 가상화 서버로부터 전달되는 제어 명령어를 버퍼링하고실행한다. 이 때, 가상머신의 제어와 관련된 제어 명령어는 프로그래밍된 데몬을 통하여 제어되고, 가상화 데스크탑 클라이언트 장치(2000)에 관련된 명령어는 하이퍼바이저(2100) 및 OS레벨에서 처리될 수 있다.
한편, 가상화 데스크탑 시스템의 네트워크 프로토콜은 TCP/UDP를 사용하고, 관리상의 구동방법은 이하 도 9 및 도 10를 통하여 상세하게 후술한다.
도 9는 본 발명의 일실시예에 따른 가상화 데스크탑 매니저 장치를 통한 관리 방법을 나타낸 흐름도이다. 도 9를 참고하면, 본 발명의 일실시예에 따른 가상화 데스크탑 매니저 장치를 통한 관리 방법은 우선, 사용자에 의해 가상화 데스크탑 매니저 장치(1000)에 새로운 서버가 등록된다(S1000).
한편, 새로운 서버의 등록 방법을 설명하면 우선, 사용자가 가상화 데스크탑 클라이언트 장치(2000)에서 접속을 시도하여 새로운 사용자의 경우 연결모듈(1100)
에 접속을 한다. 이후, 회원가입 절차를 통하여 회원 ID 및 패스워드를 부여 받는 다. 사용자는 부여 받은 접속ID로 가상화 데스크탑 매니저 장치(1000)에 접속하고, 가상화 데스크탑 매니저 장치(1000)는 새로운 이미지를 생성한다. 가상화 데스크탑
매니저 장치(1000)는 새로운 이미지의 경우, 기존 사용자 패턴에 맞는 미리 설정(Preset)된 가상화 이미지로 선택하거나, 사용자가 원하는 CPU, Memory, HDD의
설정을 통해 이미지 생성을 한다. 생성된 이후 정보는 연결모듈(1100)이 가지고 있
게 되고 서비스를 위하여 생성된 이미지로 연결모듈(1100)이 리다이렉션 기능을 관
리모듈(1300)에 요청하고 이후 직접 관리는 관리모듈(1300)에서 지속적으로 진행한
다.
이후, 가상화 데스크탑 매니저 장치(1000)는 브로드캐스트 방식으로 동일한네트워크에 등록되어 있는 모든 서버에 가상화 데스크탑 매니저 장치(1000)의 IP와 접속 포트를 송신한다.(S1100) 이 때, 가상화 데스크탑 매니저 장치(1000)의 서버의 IP 변경 시 등록된 클라이언트 장치들의 변경 없이 전송하기 위하여, 가상화 데스크탑 매니저 장치(1000)의 IP와 접속 포트의 전송은 새로운 서버의 접속이 없을 경우에, 소정의 간격으로 한번씩 전송 및 재전송할 수 있다.
이후, 가상화 데스크탑 매니저 장치(1000)는 TCP Server로 구동되며, 브로드 캐스트한 포트에 대한 Listen을 수행한다.(S1200) 이후, 가상화 데스크탑 클라이언트 장치(2000)로부터 수신한 연결 요청 메시지(TCP Connection)를 받으면(S1300), 해당 클라이언트 장치가 관리 서버에 등록된클라이언트 장치 IP인지 확인한다.(S1400) 이 때, 등록되지 않은 클라이언트 장치의 IP일 경우 TCP 연결을 처리하지 않는다.(S1500) 한편, 등록된 IP일 경우 클라이언트 장치로부터 접속코드를 수신한다(S1600). 이 때, 접속 코드는 가상화 데스크탑 매니저 장치의 GUI를 통해 수정이 가능하도록 구성할 수 있다.
이후, 가상화 데스크탑 클라이언트 장치(2000)로부터 전송된 접속 코드를 비교하여 일치 여부에 대한 정보를 접속을 시도한 클라이언트 장치에 전송한다(S1700). 이 때, 접속 코드에 대한 일치 여부의 전송 결과는, 일치하는 경우에는 1, 일치하지 않는 경우에는 0이라는 결과값으로 전송할 수 있다.
한편, 접속 코드가 일치하지 않으면 일치하지 않는다는 결과를 전송 후, 해당 연결을 해제한다.(S1800) 반대로 접속 코드가 일치하는 경우, 접속코드가 일치한다는 결과를 알리고(S1900), 가상화 데스크탑 클라이언트 장치의 가상화 데스크탑 에이전트가 제대로 동작하는지 확인한다.(S2000) 이 때, 별도의 쓰레드 혹은 프로세스를 통해서 접속한 가상화 데스크탑 에이전트의 접속 지속 여부를 확인할 수 있다. 이 때, TCP의 킵어라이브(keepalive) 기능 이용하여 데이터의 전송이 없더라도 연결을 유지하도록 구성할 수 있다.
도 10는 본 발명의 일실시예에 따른 가상화 데스크탑 클라이언트 장치를 통한 관리방법을 나타낸 흐름도이다.
도 10를 참고하면, 본 발명의 일실시예에 따른 가상화 데스크탑 클라이언트장치를 통한 관리 방법은, 우선 가상화 데스크탑 매니저 장치(1000)와 접속하기 위하여 가상화 데스크탑 에이전트는, 첫 구동 시에 가상화 데스크탑 매니저 장치(1000)로부터 전송되는 IP와 포트 정보에 대하여 수신 대기한다.(S3000) 이 때, 가상화 데스크탑 에이전트 구동 시, 브로드 캐스트 리시버 코드가 처음 수행되며, TCP 연결 후 가상화 데스크탑 에이전트의 구동 중 TCP 연결이 끊기게되면 다시 브로드 캐스트 리시버 코드 부분이 수행되도록 구성할 수 있다. 이후, 브로드 캐스트를 통해 가상화 데스크탑 매니저 장치(1000)의 IP 주소및 포트를 수신하고(S3010), 수신된 IP주소 및 포트를 이용하여 가상화 데스크탑 매니저 장치(1000)에 접속을 요청한다.(S3020)
이후, 연결이 완료되면 가상화 데스크탑 매니저 장치(1000)로 접속 코드를 전송한다.(S3030) 이 때, 접속 코드는 별도의 파일로 저장할 수 있다. 이후, 접속 코드 처리 결과를 기다리고, 접속 오류인 경우 접속이 끊어지므로 브로드 캐스트 리시버 코드를 다시 수행한다.
본 발명에 따르면, 클라이언트 시스템의 전원 인가후 바로 가상 데스크탑 서비스에 접속 가능하며, 가상 데스크탑 서비스의 가상 머신 종료 시 클라이언트의 전원도 함께 종료됨으로써, 사용자들은 클라이언트를 구동하는 운영체제 및 가상 데스트탑 클라이언트 소프트웨어를 인지하지 않은 채 가상머신 서비스를 받을 수 있는 환경을 제공한다.
본 발명에 따르면, 가상 데스크탑 서비스를 위하여 사용자에게 할당될 사용
자 OS 이미지와 사용자 디스크 이미지를 빠른 시간에 제공할 수 있다.
또한, 미리 준비된 이미지 디스크를 할당하므로, 가상머신 생성 및 이미지복사 등의 동작을 줄여서 서버 가상화 환경에서 서버 부하를 크게 개선할 수 있다.
도 11은 본 발명의 실시예에 따른 서버중심의 가상 데스크톱 서비스 구조를 개략적으로 나타낸 도면이다.
도 11을 참조하면, 본 발명의 가상 서버중심의 가상 데스크톱 서비스 구조(610)는 클라이언트(600), 커넥션브로커(6200)(Connection Broker, 이하 ?관리서버?), 운영 서버(6300) 및 공유 스토리지(6400)를 포함하여 구성될 수 있다. 여기서 클라이언트(6100)는 적어도 하나 또는 복수개의 사용자 단말을 의미할 수 있다. 클라이언트(6100)는 관리 서버(6200)의 등록 과정에서 Allocated User, Pooled User, Multi-VM 등의 사용자 단말 등록정보를 선택할 수 있다. 이 과정에서 상술한 사용자 단말 등록 정보는 관리 서버(6200)의 관리자 승인에 따라 사용자 요청이 인증되거나 거절될 수 있다. 또는 클라이언트(6100)에 속하는 사용자 단말의 형태는 관리 서버(6200)의 등록 과정에서 관리자의 결정에 따라 달라지거나 또는 사전 정의된 일정 정책에 따라 사용자 단말 등록 정보가 결정될 수 있다. 또는 클라이언트(6100)의 등록 과정에서 사용자 선택에 의한 서비스 형태 등 다양한 요청에 따라 사용자 단말 등록 정보가 결정되거나 변경될 수 있다.
본 발명의 가상 데스크톱 서비스 구조(610)는 도 1에 나타낸 바와 같이 사용자 단말에 클라이언트 프로그램을 설치하여 데이터 센터 혹은 서비스 프로바이더의 가상화 서버에 있는 하이퍼바이저(Hypervisor) 위에 생성된 자신의 VM(가상 머신)들을 정해진 접속 프로토콜을 통하여 사용할 수 있도록 하는 서비스이다. 사용자 단말에 해당하는 클라이언트(6100)에게 VM을 제공하기 위하여 사용자 프로파일 정보(사용자 정보파일)과 사용자용 OS 이미지, 사용자용 디스크 이미지가 필요하다. 사용자 OS 이미지와 사용자 디스크는 공유 스토리지(6400)를 이용하여 운영서버(6300)들이 공유하는 형태이다. 사용자 프로파일의 경우 각각의 운영 서버(6300)에 존재할 수 있다. 클라이언트(6100)에서 VM 사용 요청이 발생하면, 관리 서버(6200)는 사용자 인증과 부하 분산을 고려한 작업 할당 등을 수행할 수 있다. 그리고 하이퍼바이저가 있는 운영 서버(6300)의 에이전트(Agent) 프로그램을 통하여 VM사용 요청의 처리가 수행될 수 있다. 운영 서버(6300)는 VM 사용 요청 처리에 따라 VM이 할당 또는 비하당 등에 대한 결과를 다시 클라이언트(6100)로 응답할 수 있다.
본 발명에서 운영 서버(6300)들은 각 사용자 단말에 대한 동일한 사용자 프로파일들을 가지고, 동일한 OS 이미지와 동일한 디스크(스토리지)를 공유하는 형태로 구성하며, 이는 하나의 운영 서버(6300)가 동작을 멈추었을 시 다른 운영 서버(6300)가 대신 서비스를 제공할 수 있도록 가용성을 높이기 위한 기능을 지원할 수 있다. 이를 위하여 운영 서버(6300)는 도시된 바와 같이 클라이언트에 제공되는 적어도 하나의 가상 머신, 상기 가상 머신 구동을 지원하는 하이퍼바이저, 공유 스토리지에 사전 저장된 OS 이미지 및 사용자 디스크 이미지를 호출하여 상기 클라이언트에게 상기 가상 머신 제공을 지원하는 에이전트를 포함할 수 있다. 여기서 상기 에이전트는 이미지 생성기를 이용하여 상기 클라이언트 관련 상기 OS 이미지 및 상기 사용자 디스크 이미지 생성을 지원하고, 상기 OS 이미지 및 상기 사용자 디스크 이미지를 상기 공유 스토리지에 저장하도록 제어할 수 있다.
본 발명에서 상기 데스크톱 서비스를 지원하기 위하여 VM 사용 방법에 따라 사용자 단말을 구분하여 가상 머신 할당한다. 이때, 관리 서버(6200)는 사용자 단말 등록 정보 구분을 Allocated User, Pooled User 및 Multi-VM 유저로 분류할 수 있다
Allocated Use는 지속적으로 자신의 할당된 가상 머신을 사용하는 사용자로서 영구히 자신의 가상 머신을 가진다. 기본적으로는 Preset or Manual 방식의 사용자로 구분할 수 있다. Preset 방식은 사용자의 가상 머신 환경을 미리 서비스 제공자가 결정하여 이를 제공하는 방법이다. Manual 방식은 사용자가 자신의 가상 머신을 설정할 수 있도록 하는 방법이다. Pooled User는 단 한번의 사용을 위한 가상 머신을 가진다. Pooled User로 구분된 사용자 단말이 운영 서버로부터 로그오프 시 자신이 사용한 가상 머신은 삭제되고 다시 접속하면 새로운 가상 머신이 할당된다. Pooled User의 사용자 단말 접속 해제 시 운영 서버(6300)는 사용자의 개인적인 프로파일을 저장하지 않는다. Multi-VM User는 하나의 사용자가 여러 개의가상 머신을 사용할 수 있도록 지정한 사용자를 말한다.
도 12는 본 발명의 실시예에 따른 고가용성(HA: High Ability) 서버가상 머신 제공 시스템의 전체 구성 중 서버 구성들을 나타낸 도면이다.
도 12에 도시된 바와 같이, 본 발명의 서버 가상 머신 제공 시스템에서 HA를 위하여 관리 서버(6200)는 Active-Standby 형태로 구성하고, 나머지 운영서버(6300)들의 경우 Active-Active 형태로 구성할 수 있다. 서버 가상 머신 제공시스템은 관리 서버(6200)와 운영 서버(6300)들 전체를 클러스터링하여 서버의 상태들을 교차(cross) 확인한다. 이러한 본 발명의 서버 가상 머신 제공 시스템은 앞서 도 1에서 설명한 바와 같이 사용자 가상 머신이 운영 서버(6300) 한 곳에만 존재하지 않고 여러 운영 서버(최소 2개 이상)에 다수로 존재하도록 지원한다. 이에 따라, 본 발명의 서버 가상 머신 제공 시스템은 가상 머신이 할당된 운영 서버의 장애 발생 시 사용자 단말에 해당하는 클라이언트(6100)에게 다른 운영 서버의 가상머신을 할당함으로써 끊임 또는 끊김 없이 가상 데스크톱 서비스를 제공할 수 있다.
도 13은 본 발명의 실시예에 따른 가상 데스크톱 서비스 중 사용자허가를 설명하기 위한 도면이다.
도 13을 참조하면, 본 발명의 가상 데스크톱 서비스 운용을 위하여 각 사용자 단말에 해당하는 클라이언트(6100)는 먼저 자신의 가상 머신을 사용할 수 있도록 허가를 받아야 한다. 이를 위하여, 클라이언트(6100)는 통신 모듈을 이용하여 관리 서버(6200)에 접속을 수행할 수 있다. 다음으로, 클라이언트(6100)는 사용자 등록을 위한 기본 사전 정보 입력을 수행할 수 있다. 이때, 클라이언트(6100)는 가상 머신을 사용하기 위한 자신의 인적 사항을 기입(성명, 고유 식별아이디,주소, 이메일, 전화번호 등)한 후, 가상 머신 할당을 서비스 제공자 예컨대 관리서버(6200)에게 요청할 수 있다. 이 과정에서 클라이언트(6100)는 관리 서버(6200)가 제공하는 웹을 통하여 직접 신청하거나 또는 이메일을 통하여 신청하는 등 다양한 방법을 이용할 수 있다. 또 일반 회사나 공공기관 등에서는 사용자 단말이 직접 신청하지 않고, 서비스 제공업체의 관리자 예컨대 관리 서버(6200)의 관리자에게 사용자 정보를 일괄 제공할 수 있다. 이를 위하여 관리 서버(6200)는 사용자 정보 일괄등록을 위한 관리도구를 이용하는 관리자 직접 등록 방법을 지원할 수 있다.
사용자 가상 머신 사용 허가가 완료되면, 클라이언트(6100)는 웹이나 클라이언트 프로그램을 이용하여 자신의 로그인 아이디 패스워드를 설정하고 관리서버(6200)에서의 로그인 과정을 진행하게 된다. 이때 로그인 아이디 패스워드 설정에 있어서 사용자 단말은 필수 항목 필드(예 주민등록번호, 사원번호 혹은 서비스 제공자가 정해준 아이디 등)으로 로그인 아이디 및 패스워드를 생성할 수 있다. 관리 서버(6200)는 사전 설정된 정보를 기반으로 클라이언트(100)의 필수 항목 필드의 정보 및 로그인 정보에 대한 인증 과정을 수행할 수 있다.
도 14는 본 발명의 실시예에 따른 가상 데스크톱 서비스 지원을 위한 관리 서버의 구성을 개략적으로 나타낸 도면이다.
도 14를 참조하면, 본 발명의 관리 서버(6200)는 사용자 관리 모듈(6210), 운영 서버 관리 모듈(6220) 및 가상 머신 할당 모듈(6230)을 포함할 수 있다.
사용자 관리 모듈(6210)은 클라이언트(6100)의 접속과 사용자 정보 등록 등을 지원한다. 사용자 관리 모듈(6210)은 관리 서버(6200)의 통신 모듈을 제어하여 클라이언트(6100)와의 통신 채널을 형성하고, 클라이언트(6100)에게 사용자 정보등록을 위한 웹 페이지 등을 제공할 수 있다. 또는 사용자 관리 모듈(6210)은 클라이언트(6100)로부터 사용자 정보가 기재된 이메일 등을 수신하면, 해당 사용자 정보를 파싱하여 사용자 정보 등록을 수행할 수 있다. 이 과정에서 사용자 관리 모듈(6210)은 클라이언트(6100)별 사용자 단말 등록 정보 분류를 수행할 수 있다. 예컨대사용자 관리 모듈(6210)은 클라이언트(6100)별로 Allocated User로서 반영구적으로 서버 VM을 할당할 사용자 단말, Pooled User로서 서버 VM을 할당할 사용자 단말, Multi-VM User로서 서버 VM을 할당할 사용자 단말을 구분할 수 있다. 이를 위하여사용자 관리 모듈(6210)은 사용자 단말 등록 정보 중 어느 하나를 선택할 수 있는 항목을 클라이언트(6100)에게 제공할 수 있다. 이 과정에서 사용자 관리 모듈(6210)은 과금 정책에 따라 서버 VM 할당과 관련한 사용자 단말 등록 정보 분류를 기록할 수 있다. 사용자 관리 모듈(6210)은 별도의 항목 선택이 없는 클라이언트(6100) 접속시에는 Pooled User로 분류할 수도 있다.
운영 서버 관리 모듈(6220)은 복수개의 운영 서버들의 상태 관리를 수행할 수 있다. 예컨대, 운영 서버 관리 모듈(6220)은 운영 서버들의 서버 VM 할당상태에 대한 정보를 수집할 수 있다. 그리고 운영 서버 관리 모듈(6220)은 운영 서버들의 상태 정보를 가상 머신 할당 모듈(6230)에 전달할 수 있다. 한편, 운영 서버관리 모듈(6220)은 클라이언트(6100)가 제공한 사용자 단말 등록 정보를 운영 서버들에게 전달할 수 있다.
가상 머신 할당 모듈(6230)은 사용자 관리 모듈(6210)로부터 클라이언트(6100) 접속 정보를 수신하고, 사용자 단말 등록 정보를 확인할 수 있다. 그리고 가상 머신 할당 모듈(6230)은 사용자 단말 등록 정보를 토대로 어떠한 서버 VM을 할당할지 결정할 수 있다. 예컨대, 가상 머신 할당 모듈(6230)은 로그인 된 클라이언트(6100)에 대하여 사전 할당된 서버 VM을 제공할 것인지, 임시 서버 VM을 제공할 것인지, 복수개의 서버 VM에 대한 정보를 제공하고 선택된 특정 서버 VM을 제공할 것인지 등에 대하여 결정할 수 있다. 가상 머신 할당 모듈(6230)은 서버 VM 할당이 결정되면, 운영 서버 관리 모듈(6220)로부터 운영 서버들의 상태 정보를 확인한다. 그리고 가상 머신 할당 모듈(6230)은 운영 서버들의 상태에 따라 적어도 하나의 운영 서버에 서버 VM 할당을 요청할 수 있다. 그리고 가상 머신 할당 모듈(6230)은 해당 운영 서버로부터 서버 VM에 대한 접속 정보 및 접속 허용 정보를 수신하고 이를 클라이언트(6100)에 전달할 수 있다. 한편, 서버 VM 접속 정보 및 접속 허용 정보를 운영 서버(6300)가 클라이언트(6100)로 직접 전송할 수 있도록 설계된 경우 가상 머신 할당 모듈(6230)은 서버 VM 관련 정보의 전송 작업을 수행하지 않을 수도 있다.
가상 머신 할당 모듈(6230)은 클라이언트(6100)의 가상 머신 제공에 필요한 OS 이미지와 사용자 디스크 이미지의 제어에 관여할 수 있다. 예컨대, 가상머신 할당 모듈(6230)은 상기 OS 이미지와 사용자 디스크 이미지의 생성을 위한 이미지 생성기 운용을 제어하거나, 이미지 생성기 운용을 수행하는 특정 운영 서버(6300)의 제어를 지원할 수 있다. 이에 따라, 가상 머신 할당 모듈(6230)은 OS 이미지와 사용자 디스크 이미지의 공유 스토리지(400) 저장을 제어할 수 있다. 운영 서버(6300)의 가상 머신 제공 과정에서 OS 이미지와 사용자 디스크 이미지가 사용될 수 있도록 공유 스토리지(6400)에서의 위치 정보를 운영 서버(6300)에 제공할 수 있다. 한편, 운영 서버(6300)가 직접적으로 OS 이미지와 사용자 디스크 이미지의 생성과 저장에 관여하는 경우, 가상 머신 할당 모듈(6230)의 이미지 생성기 관련 기능을 생략될 수 있다.
도 15는 본 발명의 실시예에 따른 가상 데스크톱 서비스 중 Allocated User의 가상 머신 생성 및 할당을 설명하기 위한 도면이다. 이러한 도 15에서는 클라이언트(6100)가 최초 로그인 과정이 진행되었을 시 관리 서버(6200)는 클라이언트(6100)가 어떤 사용자 단말 등록 정보를 가지고 있는지 확인하고, 해당 정보에 따라 어떤 가상 머신을 할당하여야 하는지에 대한 과정을 수행할 수 있다.
도 15를 참조하면, 관리 서버(6200)는 S6101 단계에서 클라이언트(6100)가 접속되면 사용자 단말 등록 정보를 확인하고, 사용자 단말 등록 정보가 Allocated user 정보를 포함한 경우 클라이언트(6100)를 위한 서버 VM 생성 및 할당을 위한 절차를 수행할 수 있다. 이를 위하여, 관리 서버(6200)는 Allocated User 클라이언트(6100) 접속 및 로그인 시 해당 클라이언트에게 할당된 사용자 VM이 존재하는 지에 대한 여부를 S6103 단계에서 판단할 수 있다.
관리 서버(6200)는 해당 클라이언트(6100)에 사용자 VM이 할당되어 있지 않으면, S6105 단계로 분기하여 클라이언트(6100)에게 가상 머신을 생성하라고 요청할 수 있다. 이를 위하여 관리 서버(6200)는 웹 페이지나 메시지 등을 이용하여 가상 머신 생성 요청 메시지를 클라이언트(6100)에 전달할 수 있다. 그러면 클라이언트(6100)는 사용자 단말의 특성에 맞는 또는 사용자 요청에 따른 가상 머신을 생성하기 위한 절차를 수행한다. 이때, 가상 머신 생성 실패 시 클라이언트(6100)는 관리 서버(6200)의 관리자에게 요청하여 작업을 진행할 수 있다. 가상 머신 생성이 완료되면 생성된 가상 머신 정보가 DB에 저장이 되고 이 DB값을 이용하여 클라이언트(6100)가 관리 서버(6200)에 로그인 하는 경우 관리 서버(6200)는 해당 클라이언트(6100)의 사용자 가상 머신이 존재하는지를 다시 판단할 수 있다. 앞서 도 1 및 도2에서 설명한 바와 같이 관리 서버(6200) 및 운영 서버(6300)는 같은 가상 머신이 여러 개가 존재 하는 부하분산 및 Fail Over(장애극복) 기능을 지원하는 형태의 시스템을 구성할 수 있다.
한편, S6103 단계에서 사용자 VM이 존재하는 경우, 관리 서버(6200)는 S6107 단계로 분기하여 해당 클라이언트(6100)에 할당된 VM이 복수개인지 확인할 수 있다. 여기서 해당 VM이 복수개인 경우, 관리 서버(6200)는 S6109 단계로 분기하여 서버 전력 측정치가 작은 쪽의 VM을 선택하도록 제어할 수 있다. 이를 위하여 관리서버(6200)는 운영 서버들의 특성을 확인하고 상대적으로 양호한 데이터 처리 특성을 가지는 운영 서버를 선택하도록 제어할 수 있다. 한편, 관리 서버(6200)는 S6107단계에서 해당 클라이언트(6100)에 할당된 VM이 단수개인 경우 S6111 단계로 분기하여 단일 VM을 선택하도록 제어할 수 있다.
다음으로, 관리 서버(6200)는 S6113 단계에서 선택된 VM 상태 확인을 수행하여 현재 ON 상태인지 또는 OFF 상태인지 확인할 수 있다. 선택된 VM이 OFF상태인 경우 관리 서버(6200)는 S6115 단계로 분기하여 해당 서버 VM에 ON 명령을 전송할 수 있다. 다음으로, 관리 서버(6200)는 S6117 단계로 분기하여 선택된 VM의 접속 정보를 클라이언트(6100)에게 전송하는 한편 접속 허용 정보를 전송하여 접속하도록 지원할 수 있다.
도 16은 본 발명의 실시예에 따른 가상 데스크톱 서비스 중 Pooled User의 가상 머신 생성 및 할당을 설명하기 위한 도면이다.
도 16을 참조하면, 관리 서버(6200)는 S6201 단계에서 클라이언트 접속이 수행되면, 클라이언트 접속 시 획득된 로그인 정보를 이용하여 사용자 단말 등록 정보를 확인할 수 있다. 그리고 관리 서버(6200)는 사용자 단말 등록 정보가 Pooled User인 경우 해당 클라이언트(100)에게 할당된 가상 머신이 존재하지 않는 타입으로 판단하고 S6203 단계로 분기하여 VM Pool(가상 머신 풀)이 존재하는지 확
인할 수 있다. S6203 단계에서 VM Pool이 존재하지 않는 경우, 관리 서버(6200)는
S6205 단계로 분기하여 Pooled VM 미생성을 클라이언트(6100)에 알릴 수 있다. 그러면, 클라이언트(6100)는 서버 VM 서비스 이용을 위해 웹 접속 또는 이메일 전송 등 다양한 방식을 통해 VM Pool 생성 요청 및 이를 위한 일련의 과정을 처리할 수 있다. 클라이언트(6100)는 VM Pool 생성 과정 완료 이후 다시 관리 서버(6200) 접속을 수행할 수 있다.
S6203 단계에서 VM Pool이 존재하면, 관리 서버(6200)는 S6207 단계로 분기하여 VM Pool의 VM Name 전체 할당 여부를 확인할 수 있다. 그리고 관리 서버(6200)는 Pool의 VM Name 전체가 이미 할당된 경우 S6209 단계로 분기하여 VM 할당 요청한 클라이언트(6100)에게 전체 할당 알림을 수행할 수 있다. 즉, 관리 서버(6200)는 클라이언트(6100)에게 할당할 VM이 없음을 안내할 수 있다. 이때 관리 서버(6200)는 통계적 실험 자료 등을 토대로 클라이언트(6100)에게 대기 예상 시간 정보를 제공할 수 있다.
한편, S6207 단계에서 VM Pool의 VM Name이 전체 할당되어 있지 않은 경우 즉 클라이언트(6100)에게 할당 가능한 VM Name이 존재하면, 관리 서버(6200)는 S6211 단계로 분기하여 VM Pool에 속한 운영 서버들 중에 서버 전력 측정치가 작은 쪽의 운영 서버 선택을 수행할 수 있다. 그리고 관리 서버(6200)는 S6213 단계에서 선택된 운영 서버 내의 VM 순서대로 VM 할당을 위한 VM 선택을 수행할 수 있다. 이
후 관리 서버(6200)는 S6215 단계에서 선택된 VM의 상태를 체크하고, OFF 상태인 경우 S6217 단계로 분기하여 해당 서버 VM에 ON 명령을 전송할 수 있다. 관리 서버
(6200)는 S6219 단계에서 클라이언트(6100)에게 선택된 VM의 접속 정보를 전송 및 접속 허용 정보 전송을 수행할 수 있다.
상술한 본 발명의 관리 서버(6200)는 Pooled User에게 한시적으로 사용 가능한 VM을 가상 머신 풀에서 할당할 수 있도록 지원한다. 이러한 본 발명에서 가상 머신 풀 내에 속한 가상 머신은 관리 서버(6200) 제어에 따라 운영 서버(6300)에서 미리 생성해 놓은 가상 머신을 사용하게 되므로 클라이언트(6100) 요청에 따라 생성하는 기능은 지원하지 않는다.
도 17은 본 발명의 실시예에 따른 가상 데스크톱 서비스 중 Multi-VM User의 가상 머신 생성 및 할당을 설명하기 위한 도면이다.
도 17을 참조하면, 본 발명의 가상 데스크톱 서비스 제공을 위해 관리 서버(6200)는 S6301 단계에서 클라이언트 접속 처리를 지원할 수 있다. 클라이언
트(6100)는 관리 서버(6200) 접속 시 로그인을 수행할 수 있다. 이 과정에서 관리 서버(6200)는 사용자 단말 등록 정보 확인을 통해 Multi-VM User 임을 확인할 수 있으며, S6303 단계에서 해당 클라이언트(6100)에게 할당된 사용자 VM이 존재하는지 확인할 수 있다. 이 단계에서 사용자 VM이 존재하지 않으면, 관리 서버(6200)는 S6305 단계에서 사용자 VM 생성 요청을 클라이언트(6100)에 전송할 수 있다. 그러면 클라이언트(6100)는 웹 접속 또는 이메일 등 다양한 방식을 통하여 사용자 VM 생성 처리를 수행할 수 있다. S6303 단계에서 사용자 VM이 존재하면, 관리 서버(6200)는 S6307 단계에서 할당된 Domain 이름 OS Type을 클라이언트로 전송할 수 있다. Multi-VM User 타입의 사용자 단말 등록 정보에 따라 해당 클라이언트(6100)는 할당된 복수 개의 가상 머신을 가질 수 있다. 이에 따라, 관리 서버(6200)는 클라이언트(6100)에 할당된 모든 VM의 정보를 전송한다. 이를 위하여 관리 서버(6200)는 운영 서버(6300)들의 가상 머신 할당 상태에 대한 정보를 수집 및 관리할 수 있다.
다음으로, 관리 서버(6200)는 S6309 단계로부터 클라이언트(6100)의 VM선택 정보를 수신할 수 있다. 이 과정에서 클라이언트(6100)는 관리 서버(6200)가 제공한 복수개의 VM 정보들 중에 자신이 접속하고자 하는 VM 선택 정보를 관리 서버(6200)에 전송할 수 있다. 관리 서버(6200)는 S6311 단계에서 같은 Domain이 복수 개인지 여부를 확인하고, 복수개의 Domain이 존재하면, S6313 단계로 분기하여 서버 파워가 작은 쪽의 VM 선택을 수행할 수 있다. 한편 같은 Domain이 하나인 경우 관리서버(6200)는 S6315 단계에서 하나의 VM을 선택할 수 있다. 이후 관리 서버(6200)는 S6317 단계에서 선택된 VM 상태 체크를 수행하고, VM이 OFF 상태이면 S6319 단계로 분기하여 해당 서버 VM에 ON 명령을 수행할 수 있다. 관리 서버(6200)는 선택된 VM 그리고 ON 상태의 VM에 대하여 클라이언트(6100)에게 접속 정보 전송 및 접속 허용정보 전송을 수행할 수 있다.
상술한 바와 같이 본 발명의 Multi-VM User 타입 VM 할당을 위하여 관리 서버(6200)는 클라이언트(6100)가 접속하고 싶은 가상 머신을 선택할 수 있도록 지원한다. 클라이언트(6100)가 가상 머신을 선택한 이후 동작은 앞서 설명한 Allocated user의 경우와 동일한 방법으로 할당하고 접속 진행을 처리할 수 있다.
한편, Allocated User 및 Multi-VM user의 경우 사용자로 등록이 된 사용자만 자신의 VM을 클라이언트에서 생성할 수 있다. 클라이언트(6100)는 자신이 사용할 가상 머신의 이름 및 CPU 개수 메모리 크기, 저장공간의 크기 및 사용할 운영체제 정보 등을 입력하여 VM을 생성한다. 상술한 기능은 사용자가 아닌 관리자에게 요청을 하여도 가능하며, 요청 받은 내용을 관리자가 관리 툴을 사용하여 로컬에서 실행 할 수도 있다.
도 18은 사용자 요청에 따른 가상 머신 생성 방법을 설명하기 위한 도면이다.
도 18을 참조하면, 클라이언트(6100)는 S6401 단계에서 관리 서버(6200)에 접속을 수행하고, VM 정보 요청을 수행할 수 있다. 관리 서버(6200)는 S403 단계에서 클라이언트(6100)가 입력한 사용자 정보를 수집할 수 있으며, S6405 단계에서 가상 머신 생성 요청을 수신할 수 있다. 여기서 사용자 정보는 VM에 사용할 리소스의 정보 및 OS 정보이다. 관리 서버(6200)는 사용자 정보를 이용하여 가상 머신 생성 요청을 운영 서버(6300) 쪽으로 전송할 수 있으며, 운영 서버(6300)는 가상 머신템플릿 파일을 생성하게 된다. 이 과정에서 운영 서버(6300)는 상기 사용자 정보에 대응하는 가상 머신 템플릿 파일이 존재하는지 여부를 S6407 단계에서 확인할 수 있다. 여기서 가상 머신 템플릿 파일이 존재하지 않으면, S6409 단계로 분기하여 가상머신 템플릿 파일 생성 요청 및 처리를 수행할 수 있다.
가상 머신 템플릿 파일 생성 요청이 클라이언트(6100)에 전송되면, 클라이언트(6100)는 가상 머신 템플릿 파일 생성 요청에 따라 가상 머신 템플릿 파
일 생성을 위한 절차를 수행할 수 있다. 가상 머신 템플릿 파일은 사용되는 가상 머신의 속성을 저장한 파일이고 관리자가 미리 설정한 골든(Golden) 템플릿 파일이
존재한 상태에서 서비스가 가능하다. 만약에 미리 설정한 골든 템플릿 파일이 존재
하지 않으면 템플릿 생성기를 통하여 가상 머신 템플릿 파일을 생성하도록 지원하
고, 골든 템플릿 파일 생성 시까지 가상 머신 생성 요청에 따른 작업은 일시적으로
중단될 수 있다. 한편 S6407 단계에서 가상 머신 템플릿 파일이 존재하면, 운영 서
버(6300)는 S6411 단계로 분기하여 템플릿 복사 및 사용자 정보 갱신을 수행할 수 있다. 이후 운영 서버(6300)는 S6413 단계에서 템플릿 생성 완료 여부를 확인하고, 미완료 시 S6407 단계 이전으로 분기할 수 있다.
S6413 단계에서 가상 머신 템플릿 파일이 생성 완료 되면 운영 서버(6300)는 클라이언트(6100)의 OS 이미지와 사용자 디스크를 할당하고 S6415 단계에서 이미 생성되어 있는 템플릿 이미지가 존재하는지 체크한다. 이 단계에서 클라이언트(6100)의 요청 OS에 해당하는 템플릿 이미지가 존재하지 않는 경우 S6417 단계로 분기하여 클라이언트(6100)에 템플릿 이미지 생성 요청 및 처리를 수행할 수 있다. 이때 템플릿 이미지 생성을 위하여 이미지 생성기를 이용한 파일 생성을 요청하고 작업은 일시적으로 중단한다. S6415 단계에서 템플릿 이미지가 존재 할 경우 S6419단계에서 클라이언트(100)에 의해 요청된 크기의 사용자 디스크가 존재하는지 여부를 확인할 수 있다. 해당 사용자 디스크가 존재하지 않으면 S6417 단계에서 클라이언트(6100)에게 사용자 디스크 이미지 생성 요청 및 처리를 수행할 수 있다. 템플릿이미지와 사용자 디스크가 존재하는 경우 운영 서버(6300)는 S6421 단계에서 템플릿파일에 설정한 이름대로 Rename하여 클라이언트(6100)에게 할당하고 사용자 디스크 역시 같은 방법으로 Rename한다.
한편, 상술한 과정에서 템플릿 이미지 생성 요청 및 사용자 디스크이미지 생성 요청은 운영 서버(6300) 제어에 따라 수행될 수도 있고, 또는 관리 서버(6200)에 제어에 따라 수행될 수 있다. 관리 서버(6200) 제어에 따라 수행되는 경우, 운영 서버(6300)는 관리 서버(6200)를 통하여 상술한 이미지 생성 요청을 클라이언트(6100)에 전달하고, 클라이언트(6100)는 관리 서버(6200)를 통하여 상술한 이미지생성 요청에 대한 처리를 수행할 수 있다. 또는 운영 서버(6300)가 클라이언트(6100)와의 통신 채널을 형성하고 이미지 생성 요청 전송 및 처리를 지원할 수 있도록 설계되는 경우, 클라이언트(6100)는 운영 서버(6300)를 통하여 상술한 이미지 생성요청 처리를 수행할 수도 있다.
한편, 상술한 가상 머신 생성 플로우가 성립하기 위하여 관리자는 사전에 서비스를 위한 템플릿 파일을 준비하고 시스템에서 인식되도록 한다.
사용자의 OS 이미지와 사용자 디스크 이미지는 미리 준비된 상태에서 클라이언트(6100) 생성 요청에 따라 제공될 수 있다. 이를 위하여 클라이언트(6100)는 OS 이미지 및 사용자 디스크 이미지 생성을 템플릿 파일 생성기 및 이미지생성기를 통하여 사전에 작업할 수 있다. 이에 따라 기본 골든 템플릿 파일 및 골든 이미지 파일이 VM 할당 이전에 생성 및 저장되어 시스템 운용 시 이용될 수 있다. 이렇게 작업된 골든 이미지 파일 및 골든 템플릿 파일은 클라이언트(6100) 요청시 실시간으로 제공될 수 있고, 템플릿 파일의 단순 복사 및 재구성 그리고 템플릿 이미지의 사전 복사 및 특정 개수 유지, 리네임 할당에 이용될 수 있다.
템플릿 파일의 경우 그 크기가 크기 않기 때문에 단순히 복사만 가능한 방법으로 진행될 수 있다. 그러나 OS 이미지의 경우 그 크기가 매우 크기 때문에 실시간 가상 머신에 요청을 수행하기 위하여서는 이미지 생성기를 구동하여 요청할 때 제공될 OS 이미지와 사용자 디스크 이미지를 미리 설정하여 두는 방법이 효율적이다.
도 19는 본 발명의 이미지 생성기 운용을 설명하기 위한 순서도이다.
도 19를 참조하면, 본 발명의 이미지 생성기 운용을 위하여 운영 서버(6300)는 S6501 단계에서 이미지 생성기 구동을 수행한다. 그리고 운영 서버(6300)는 S6503 단계에서 설정 파일 읽기를 수행할 수 있다. 초기의 설정 파일로 Xvm_limit 값과 Xpre_vm, 그리고 사용되는 OS 타입, 그리고 골든 이미지 파일 및 골든 템플릿 파일의 위치를 가져올 수 있다.
다음으로, 운영 서버(6300)는 S6505 단계에서 서버 초기화를 수행할 수 있다. 서버 초기화 작업에서는 설정 파일에 관한 사항을 체크한다. 운영 서버(6300)는 만약 골든 이미지 파일 및 골든 템플릿 파일이 없으면 동작을 일시 중지할 수 있다. 다음으로 운영 서버(6300)는 S6507 단계에서 서버 VM 상태 체크를 수행할 수 있다. 운영 서버(6300)는 S6509 단계에서 현재 VM 개수(Xcur)가 운영 서버당 최고 설치 가능한 이미지 개수(Xvm_limit)와 동일한지 여부를 확인할 수 있다. 즉, 운영서버(6200)는 상술한 초기화 작업이 진행되면 현재 VM 개수를 체크하여 Xvm_limit값과 같은지 확인하고, 같은 경우 해당 운영 서버에서는 더 이상의 가상 머신은 설치할 수 없으므로 S6507 단계 이전으로 분기하여 서버 VM 상태 체크를 지속적으로 수행할 수 있다.
한편, S6509 단계에서 Xcur와 Xvm_limit이 동일하지 않은 경우, 운영서버(6300)는 S6511 단계에서 다음 수학식 1과 같은 조건을 만족하는지 여부를 확인할 수 있다.
Figure pat00001
상기 수학식 1에서 Xcur는 현재 VM 개수이며, Xpre_cur는 현재 준비된 VM 개수, Xvm_limit은 운영 서버당 최고 설치 가능한 이미지 개수, Xpre_vm은 운영 서버당 최고 유지 이미지 개수이다.
S6509 단계에서 Xvm_limit&Xpre_cur의 조건이 만족되지 않은 경우 운영 서버(6300)는 S6507 단계 이전으로 분기하여 이하 과정을 재수행하도록 제어할 수
있다. 그리고 S6509 단계에서 조건이 만족되는 경우 운영 서버(6300)는 S6513 단계로 분기하여 다음 수학식 2를 만족하는지 여부를 확인할 수 있다.
Figure pat00002
상기 수학식 2에서 Xpre_cur는 현재 준비된 VM 개수, Xpre_min은 운영 서버당 최소 유지 이미지 개수이다.
S6513 단계에서 설명한 조건이 만족되면, 운영 서버(6200)는 S6515 단계에서 OS 이미지 복사 및 데이터 이미지 복사를 수행할 수 있다. 이후 운영 서버(6300)는 S6511 단계로 분기하여 해당 조건 만족 여부를 확인할 수 있다. 한편, S6513단계에서 해당 조건이 만족되지 않으면 운영 서버(6300)는 S6517 단계로 분기하여 운영 서버가 작업할 수 있는 가용량(Ppref)이 서버 가용량(Pcur)보다 작은지 여부를 확인할 수 있다. 즉 운영 서버(6300)는 서버 전력 측정치 또는 서버 가용량을 조사하여 이보다 작을 때까지 기다려서 이미지 복사를 수행한다. 이러한 동작은 서버의 카피로 인한 CPU의 활용도를 높이기 위한 방법이다.
한편, 상기 이미지 생성기 구동을 운영 서버(6300)에서 운용하는 것으로 설명하였으나, 본 발명이 이에 한정되는 것은 아니다. 즉, 이미지 생성기는 관리 서버(6200)가 클라이언트(6100)에 제공하고 OS 이미지와 사용자 디스크 이미지를 생성할 수 있도록 지원한 후, 공유 스토리지(6400)에 저장하도록 하거나 운영 서버(6300)를 통하여 공유 스토리지(6400)에 저장하도록 지원할 수 있다. 상기 관리 서버(6300) 및 운영 서버(6300)는 가상 머신 제공을 위하여 공유 스토리지(6400)에 저장된 OS 이미지와 사용자 디스크 이미지의 위치 정보를 클라이언트별로 관리할 수 있다.
상술한 바와 같이, 본 발명의 실시예에 따른 서버 가상 머신 제공방법 및 시스템과 이를 지원하는 장치는 사용자 단말 등록 정보 또는 사용자 단말에 대응하는 클라이언트(6100)가 사전 등록한 사용자 단말 타입에 따라 VM 제공 형태를 다르게 지원할 수 있다. 이러한 동작은 결과적으로 클라이언트(6100)에게 할당될 사용자 OS 이미지와 사용자 디스크 이미지를 빠른 시간에 제공할 수 있도록 지원하며, 가상 머신 할당 속도를 개선할 수 있다. 그리고 본 발명은 미리 준비된 이미지 파일을 할당하기 때문에 VM 생성이나 이미지 복사 등의 동작을 최소화하여 서버 부하를 최소화할 수 있다.
본 발명에 따른 가상 데스크탑 제공 방법 및 가상 데스크탑 제공 서버는 네트워크 환경이 좋지 않은 곳에서도 원활하게 가상 데스크탑 서비스를 지원하는 경량 프로토콜 기술에 관한 것으로, 클라이언트 단말의 접속 환경에 최적화된 가상데스크탑 서비스를 제공하기 위하여 제어 엔진 및 화면 전송 시 네트워크 대역폭을 줄이기 위한 이미지 압축 엔진을 추가한 경량 프로토콜을 제공한다.
본 발명에 따른 가상 데스크탑 제공 방법 및 가상 데스크탑 제공 서버는 클라이언트 단말의 네트워크 트래픽, 장치 사양 및 컴퓨팅 자원을 수집 분석하여 최적의 서비스를 제공하여, 사용자가 자신의 네트워크 상황이나 컴퓨팅 자원의 변화에 따라 적응적으로 최적의 가상 데스크탑 서비스를 제공받을 수 있도록 한다.
도 20은 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 방법을 나타낸 동작흐름도이다.
종래의 가상 데스크탑 시스템의 경우에는 이기종의 서로 다른 서버에서 가상 데스크탑을 구동하기 위해서는 사용자가 수동으로 프로파일을 수정하거나 오랜 시간 동안의 마이그레이션을 통하여 가상 데스크탑을 구동할 수 있었다. 그러나 이와 같은 방법은 번거로울 뿐만 아니라 시간도 많이 소비됨으로써 시스템의 운영에 있어서 문제점으로 대두되었다. 따라서, 본 발명에서는 서로 다른 이기종의 서버에서 가상 데스크탑을 구동할 수 있도록 사용자 프로파일, 가상 데스크탑 이미지와 함께 가상 데스크탑 구동 프로파일을 공유된 스토리지에 저장하여 사용할 수 있는 방법을 제시하고자 한다.
도 20을 참조하면, 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 방법은 복수 개의 운영서버들 중 가상 데스크탑을 구동할 어느 하나의 최적 운영서버를 할당할 수 있다(S8110). 예를 들어, 사용자는 가상 데스크탑 시스템에 로그인을 통하여 접속할 수 있고, 이를 통하여 사용자는 자신이 가상 데스크탑의 할당을 요청할 수 있는데, 이와 같은 가상 데스크탑을 구동하기 위해 먼저 가상 데스크탑을 구동할 수 있는 최적 운영서버를 할당할 수 있다.
이 때, 복수 개의 운영서버들 중 어떠한 서버에서도 사용자가 요청하는 가상 데스크탑을 구동할 수 있고, 이를 위해 필요한 프로파일을 생성하여야 할 수 있다.
이 때, 최적 운영서버가 정상적으로 동작하지 않는 경우에 복수 개의 운영서버들과 별도로 관리되는 예비 운영서버를 할당할 수 있다. 예를 들어, 복수 개의 운영서버들을 N+1의 형태로 항상 1대의 예비 운영서버를 서비스 레디 상태로 대기시킬 수 있다. 만약 서비스를 수행하던 다른 운영서버가 다운되면 대기 중이던 예비 운영서버가 실시간으로 인식되어 다운된 운영서버가 서비스 중이던 가상 데스크탑을 구동할 수 있다. 이와 같은 예비 운영서버를 통해 전체 시스템의 고가용성을 향상시킬 수 있다.
이 때, 복수 개의 운영서버들에 상응하는 서버 가용률 및 활용도 중 적어도 하나를 고려하여 최적 운영서버를 할당할 수 있다. 즉, 복수 개의 운영서버들 중에서 로드 밸런싱을 위해 가장 적합한 운영서버를 최적 운영서버로 결정하여 할당할 수 있다.
또한, 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 방법은 복수 개의 운영서버들에 상응하는 복수 개의 하드웨어 프로파일들과 최적 운영서버에 상응하는 타겟 하드웨어 프로파일을 비교할 수 있다(S8120).
즉, 복수 개의 하드웨어 프로파일들 중에 타겟 하드웨어 프로파일이 존재하는지 여부를 판단할 수 있다(S8125).
이 때, 하드웨어 프로파일은 사용자가 가상 데스크탑을 생성하기 위해 참조되는 운영서버의 하드웨어 정보를 포함한 프로파일에 상응할 수 있다. 따라서 복수 개의 운영서버들 각각 서로 다른 하드웨어 정보를 포함할 수 있다.
따라서, 하드웨어 프로파일을 비교함으로써 최적 운영서버가 기존에 존재한 서버인지 또는 이기종의 서버인지를 판단할 수 있다.
단계(S8125)의 판단결과 복수 개의 하드웨어 프로파일들 중 타겟 하드웨어 프로파일이 존재하지 않는 경우에, 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 방법은 타겟 하드웨어 프로파일을 기반으로 가상 데스크탑을 구동하기 위한 가상 데스크탑 구동 프로파일을 생성할 수 있다(S8130).
또한, 단계(S8125)의 판단결과 복수 개의 하드웨어 프로파일들 중 타겟 하드웨어 프로파일이 존재하는 경우에는 공유 스토리지에 가상 데스크탑 프로파일이 존재하기 때문에 가상 데스크탑을 구동할 수 있다.
즉, 타겟 하드웨어 프로파일과 동일한 정보가 복수 개의 하드웨어 프로파일들 중에 존재하지 않는다는 의미는 타겟 하드웨어 프로파일에 상응하는 최적 운영서버가 할당된 적이 없는 이기종의 운영서버라는 의미일 수 있다. 즉, 최적 운영서버는 하드웨어 특성이 다르기 때문에 공유 스토리지를 통해 공유되는 가상 데스크탑 구동 프로파일을 사용할 수 없을 수 있다. 그러므로 최적 운영서버가 가상 데스크탑을 구동하기 위한 가상 데스크탑 구동 파일을 생성할 수 있다.
이 때, 타겟 하드웨어 프로파일에 상응하는 가상 데스크탑 템플릿을 생성하고, 가상 데스크탑 템플릿을 이용하여 가상 데스크탑 구동 프로파일을 생성할 수 있다. 또한, 복수 개의 운영서버들에 대해서도 각각의 해당하는 가상 데스크탑 템플릿이 존재할 수 있으며, 시스템에 존재하는 가상 데스크탑 템플릿에 정보는 타겟 하드웨어 프로파일에 상응하게 생성된 가상 데스크탑 템플릿을 포함하도록 업데이트 될 수 있다.
이 때, 가상 데스크탑 구동 프로파일은 가상 데스크탑의 구동을 위해 필요한 가상 장치의 종류 및 가상 장치의 개수 중 적어도 하나의 정보를 포함할 수 있다. 예를 들어, 가상의 CPU, 메모리, 하드 디스크 및 각종 디바이스에 상응하는 정보를 포함할 수 있다.
또한, 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 방법은 최적 운영서버가 가상 데스크탑을 구동할 수 있도록, 가상 데스크탑을 구동하는데 필요한 적어도 하나의 프로파일과 함께 가상 데스크탑 구동 프로파일을 최적 운영서버에게 공유할 수 있다(S8140).
이 때, 적어도 하나의 프로파일은 가상 데스크탑을 요청한 사용자의 정보에 상응하는 사용자 프로파일 및 가상 데스크탑이 구동된 후 사용자에 의해 진행된 현재 상태 정보에 상응하는 가상 데스크탑 상태 프로파일 중 적어도 하나를 포함할 수 있다. 즉, 최적 운영서버에서는 가상 데스크탑 구동 프로파일과 사용자 프로파일 및 가상 데스크탑 상태 프로파일 등을 이용하여 가상 데스크탑을 구동할 수 있다. 예를 들어, 사용자 프로파일은 사용자의 아이디, 패스워드 및 신상정보 등에 상응하는 개인정보, 사용자의 가상 데스크탑 이름과 같은 정보 및 윈도우 사용자 프로파일과 같은 가상 데스크탑 환경 정보를 포함할 수 있다.
이 때, 복수 개의 운영서버들에게 가상 데스크탑을 부팅하기 위한 가상 데스크탑 이미지를 공유할 수 있다. 가상 데스크탑 이미지는 가상 데스크탑의 가상 디스크에 상응할 수 있다. 즉, 원격에서 부팅을 수행하는 것과 유사하게 가상 디스크를 이용하여 가상 데스크탑을 부팅할 수 있다.
이 때, 복수 개의 운영서버들은 사용자가 재접속하여 가상 데스크탑을 요청하는 경우에 사용자 프로파일을 기반으로 가상 데스크탑 상태 프로파일을 로드하여 현재 상태 정보에 상응하게 가상 데스크탑을 구동할 수 있다. 예를 들어, 가상 데스크탑이 구동되면 가상 데스크탑이 구동된 상태를 프로파일의 형태로 저장하여 업데이트할 수 있는데, 가상 데스크탑 상태 프로파일이 이와 같은 프로파일에 상응할 수 있다. 따라서 가상 데스크탑 상태 프로파일은 사용자의 현재 진행 상황에 대한 메모리 정보를 포함할 수 있으므로, 사용자가 추후에 재접속한 경우에는 운영서버에서 가상 데스크탑 상태 프로파일을 로딩하여 사용자의 환경을 그대로 유지할 수 있다.
이 때, 가상 데스크탑 상태 프로파일은 복수 개의 운영서버들 각각에 상응하는 MEM 메모리에 별도로 저장될 수 있다.
즉, 가상 데스크탑의 성능은 기본적으로 에뮬레이션 된 하드웨어 장치를 이용하여 서비스를 제공하므로 부팅 속도 및 동작 속도가 느리게 되고, 저장장치의 I/O 한계로 인하여 그 성능을 일반 PC와 비교하기 어려울 수 있다. 그러므로 이와 같은 속도의 한계를 극복하기 위해서 가상 데스크탑의 구동에 필요한 사용자 프로파일과 현재 상태 정보가 포함된 가상 머신 상태 프로파일을 운영서버의 MEM 메모리에 저장하여 사용함으로써 가상 데스크탑의 구동속도를 향상시키는데 활용할 수도 있다.
또한, 도 1에는 도시하지 아니하였으나, 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 방법은 복수 개의 운영서버들로부터 복수 개의 하드웨어 정보를 수집할 수 있다.
이 때, 복수 개의 운영서버들에 상응하는 운영체제 상의 하드웨어 정보 및 복수 개의 운영서버들의 하드웨어 컨트롤러 중 적어도 하나를 이용하여 복수 개의 하드웨어 정보들을 수집할 수 있다. 예를 들어, 운영체제 상의 하드웨어 정보라 함은 윈도우의 경우에는 repository, 리눅스의 경우에는 proc 파일 시스템을 의미할 수 있다. 또한, 프로파일 관리 장치가 복수 개의 운영서버들 각각에 존재하는 out-of-band Management를 위하여 만들어진 BMC(Baseboard Management Contotoller)에 접속하여 하드웨어 정보를 네트워크를 이용하여 수집할 수도 있다.
이 때, 복수 개의 운영서버들에서는 하드웨어 정보의 수집을 위한 에이전트를 둘 수 있고, 이를 이용하여 프로파일 관리 장치로 하드웨어 정보를 송신할 수 있다.
또한, 도 20에는 도시하지 아니하였으나, 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 방법은 복수 개의 하드웨어 정보를 기반으로 생성된 복수 개의 하드웨어 프로파일들을 저장할 수 있다.
도 21는 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 방법을 상세하게 나타낸 동작흐름도이다.
도 21를 참조하면, 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 방법은 먼저 사용자가 가상 데스크탑 시스템에 로그인을 통하여 접속할 수 있고, 이를 통하여 가상 데스크탑의 할당을 요청할 수 있다(S8202).
이 후, 최적 운영서버의 할당을 위해 복수 개의 운영서버들의 서버 가용률 및 활용도를 체크할 수 있다(S8204).
이 후, 복수 개의 운영서버들 중 가상 데스크탑을 구동할 어느 하나의 최적 운영서버를 할당할 수 있다(S8206). 즉, 복수 개의 운영서버들 중에서 로드 밸런싱을 위해 가장 적합한 운영서버를 최적 운영서버로 결정하여 할당할 수 있다.
이 후, 최적 운영서버의 하드웨어 정보를 수집할 수 있다(S8208).
이 때, 최적 운영서버에 상응하는 운영체제 상의 하드웨어 정보 및 최적 운영서버의 하드웨어 컨트롤러 중 적어도 하나를 이용하여 최적 운영서버의 하드웨어 정보를 수집할 수 있다.
이 후, 최적 운영서버의 하드웨어 정보를 기반으로 타겟 하드웨어 프로파일을 생성할 수 있다(S8210).
이 후, 하드웨어 프로파일 데이터베이스에 타겟 하드웨어 프로파일이 존재하는지 여부를 판단할 수 있다(S8512).
이 때, 하드웨어 프로파일 데이터베이스에 포함된 복수 개의 운영서버들에 상응하는 복수 개의 하드웨어 프로파일들과 최적 운영서버에 상응하는 타겟 하드웨어 프로파일을 비교하여 존재여부를 판단할 수 있다.
단계(S8212)의 판단결과 타겟 하드웨어 프로파일이 존재하지 않으면, 타겟 하드웨어 프로파일을 기반으로 가상 데스크탑을 구동하기 위한 가상 데스크탑 템플릿을 생성할 수 있다(S8214).
이 후, 가상 데스크탑 템플릿을 이용하여 가상 데스크탑 구동 프로파일을 생성할 수 있다(S8216).
이 후, 공유 스토리지에 사용자 프로파일과 가상 데스크탑 구동 프로파일을 저장할 수 있다(S8218).
이 때, 가상 데스크탑 구동 프로파일은 가상 데스크탑의 구동을 위해 필요한 가상 장치의 종류 및 가상 장치의 개수 중 적어도 하나의 정보를 포함할 수 있다. 예를 들어, 가상의 CPU, 메모리, 하드 디스크 및 각종 디바이스에 상응하는 정보를 포함할 수 있다.
이 때, 사용자 프로파일도 함께 공유 스토리지에 저장할 수 있다. 예를 들어, 사용자 프로파일은 사용자의 아이디, 패스워드 및 신상정보 등에 상응하는 개인정보, 사용자의 가상 데스크탑 이름과 같은 정보 및 윈도우 사용자 프로파일과 같은 가상 데스크탑 환경 정보를 포함할 수 있다.
이 후, 최적 운영서버가 공유 스토리지에서 가상 데스크탑 이미지, 사용자 프로파일 및 가상 데스크탑 구동 프로파일을 공유할 수 있다(S8220).
이 때, 가상 데스크탑 이미지는 가상 데스크탑의 가상 디스크에 상응할 수 있다. 즉, 원격에서 부팅을 수행하는 것과 유사하게 가상 디스크를 이용하여 가상 데스크탑을 부팅할 수 있다.
이 후, 최적 운영서버에서 가상 데스크탑을 실행할 수 있다(S8222).
도 22은 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 장치를 이용한 가상 데스크탑 시스템을 나타낸 블록도이다.
도 22을 참조하면, 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 장치를 이용한 가상 데스크탑 시스템은 프로파일 관리 장치(8310), 운영서버(8320-1~ 8320-N) 및 사용자(8330)를 포함할 수 있다.
프로파일 관리 장치(8310)는 복수 개의 운영서버 운영서버(8320-1~ 8320-N)들 중 가상 데스크탑을 구동할 어느 하나의 최적 운영서버를 할당할 수 있다.
이 때, 최적 운영서버가 정상적으로 동작하지 않는 경우에 복수 개의 운영서버(8320-1~ 8320-N)들과 별도로 관리되는 예비 운영서버를 할당할 수 있다.
이 때, 복수 개의 운영서버(8320-1~ 8320-N)들에 상응하는 서버 가용률 및 활용도 중 적어도 하나를 고려하여 최적 운영서버를 할당할 수 있다.
또한, 프로파일 관리 장치(8310)는 복수 개의 운영서버(8320-1~ 8320-N)들로부터 복수 개의 하드웨어 정보를 수집할 수 있다.
이 때, 복수 개의 운영서버(8320-1~ 8320-N)들에 상응하는 운영체제 상의 하드웨어 정보 및 복수 개의 운영서버(8320-1~ 8320-N)들의 하드웨어 컨트롤러 중 적어도 하나를 이용하여 복수 개의 하드웨어 정보를 수집할 수 있다.
또한, 프로파일 관리 장치(8310)는 복수 개의 하드웨어 정보를 기반으로 생성된 복수 개의 하드웨어 프로파일들을 저장할 수 있다.
또한, 프로파일 관리 장치(8310)는 복수 개의 운영서버(8320-1~ 8320-N)들에 상응하는 복수 개의 하드웨어 프로파일들과 최적 운영서버에 상응하는 타겟 하드웨어 프로파일을 비교할 수 있다.
또한, 프로파일 관리 장치(8310)는 복수 개의 하드웨어 프로파일들 중 타겟 하드웨어 프로파일이 존재하지 않는 경우에 타겟 하드웨어 프로파일을 기반으로 가상 데스크탑을 구동하기 위한 가상 데스크탑 구동 프로파일을 생성할 수 있다.
이 때, 타겟 하드웨어 프로파일에 상응하는 가상 데스크탑 템플릿을 생성하고, 가상 데스크탑 템플릿을 이용하여 가상 데스크탑 구동 프로파일을 생성할 수 있다.
이 때, 가상 데스크탑 구동 프로파일은 가상 데스크탑의 구동을 위해 필요한 가상 장치의 종류 및 가상 장치의 개수 중 적어도 하나의 정보를 포함할 수 있다.
또한, 프로파일 관리 장치(8310)는 최적 운영서버가 가상 데스크탑을 구동할 수 있도록, 가상 데스크탑을 구동하는데 필요한 적어도 하나의 프로파일과 함께 가상 데스크탑 구동 프로파일을 최적 운영서버에게 공유할 수 있다.
이 때, 적어도 하나의 프로파일은 가상 데스크탑을 요청한 사용자(8330)의 정보에 상응하는 사용자 프로파일 및 가상 데스크탑이 구동된 후 사용자(8330)에 의해 진행된 현재 상태 정보에 상응하는 가상 데스크탑 상태 프로파일 중 적어도 하나를 포함할 수 있다.
이 때, 복수 개의 운영서버(8320-1~ 8320-N)들에게 가상 데스크탑을 부팅하기 위한 가상 데스크탑 이미지를 공유할 수 있다.
이 때, 복수 개의 운영서버(8320-1~ 8320-N)들은 사용자(8330)가 재접속하여 가상 데스크탑을 요청하는 경우에 사용자 프로파일을 기반으로 가상 데스크탑 상태 프로파일을 로드하여 현재 상태 정보에 상응하게 가상 데스크탑을 구동할 수 있다.
이 때, 가상 데스크탑 상태 프로파일은 복수 개의 운영서버(8320-1~ 8320-N)들 각각에 상응하는 MEM 메모리에 별도로 저장될 수 있다.
운영서버(8320-1~ 8320-N)는 가상 데스크탑을 구동하기 위해 사용자(8330)에게 할당되는 서버일 수 있다. 즉, 사용자는 가상 데스크탑 서비스 시스템에 접속하여 가상 데스크탑을 요청할 수 있고, 프로파일 관리 장치(8310)가 복수 개의 운영서버(8320-1~ 8320-N)들 중에서 가상 데스크탑을 구동하기에 가장 적합한 어느 하나의 최적 운영서버를 할당할 수 있다.
사용자(8330)는 가상 데스크탑 서비스를 제공받기 위해 가상 데스크탑 서비스 시스템에 접속할 수 있으며, 프로파일 관리 장치(8310)를 통해 할당 받은 최적 운영서버에서 구동되는 가상 데스크탑을 할당 받아 사용할 수 있다.
도 23는 도 22에 도시된 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 장치의 일예를 나타낸 블록도이다.
종래의 가상 데스크탑 시스템의 경우에는 이기종의 서로 다른 서버에서 가상 데스크탑을 구동하기 위해서는 사용자가 수동으로 프로파일을 수정하거나 오랜 시간 동안의 마이그레이션을 통하여 가상 데스크탑을 구동할 수 있었다. 그러나 이와 같은 방법은 번거로울 뿐만 아니라 시간도 많이 소비됨으로써 시스템의 운영에 있어서 문제점으로 대두되었다. 따라서, 본 발명에서는 서로 다른 이기종의 서버에서 가상 데스크탑을 구동할 수 있도록 사용자 프로파일, 가상 데스크탑 이미지와 함께 가상 데스크탑 구동 프로파일을 공유된 스토리지에 저장하여 사용할 수 있는 방법을 제시하고자 한다.
도 23를 참조하면, 도 3에 도시된 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 장치(8310)는 서버 할당부(8410), 하드웨어 정보 수집부(8420), 하드웨어 프로파일 데이터베이스(8430), 프로파일 비교부(8440), 프로파일 생성부(8450) 및 공유 스토리지(8460)를 포함할 수 있다.
서버 할당부(8410)는 복수 개의 운영서버들 중 가상 데스크탑을 구동할 어느 하나의 최적 운영서버를 할당할 수 있다. 예를 들어, 사용자는 가상 데스크탑 시스템에 로그인을 통하여 접속할 수 있고, 이를 통하여 사용자는 자신이 가상 데스크탑의 할당을 요청할 수 있는데, 이와 같은 가상 데스크탑을 구동하기 위해 먼저 가상 데스크탑을 구동할 수 있는 최적 운영서버를 할당할 수 있다.
이 때, 복수 개의 운영서버들 중 어떠한 서버에서도 사용자가 요청하는 가상 데스크탑을 구동할 수 있고, 이를 위해 필요한 프로파일을 생성하여야 할 수 있다.
이 때, 최적 운영서버가 정상적으로 동작하지 않는 경우에 복수 개의 운영서버들과 별도로 관리되는 예비 운영서버를 할당할 수 있다. 예를 들어, 복수 개의 운영서버들을 N+1의 형태로 항상 1대의 예비 운영서버를 서비스 레디 상태로 대기시킬 수 있다. 만약 서비스를 수행하던 다른 운영서버가 다운되면 대기 중이던 예비 운영서버가 실시간으로 인식되어 다운된 운영서버가 서비스 중이던 가상 데스크탑을 구동할 수 있다. 이와 같은 예비 운영서버를 통해 전체 시스템의 고가용성을 향상시킬 수 있다.
이 때, 복수 개의 운영서버들에 상응하는 서버 가용률 및 활용도 중 적어도 하나를 고려하여 최적 운영서버를 할당할 수 있다. 즉, 복수 개의 운영서버들 중에서 로드 밸런싱을 위해 가장 적합한 운영서버를 최적 운영서버로 결정하여 할당할 수 있다.
하드웨어 정보 수집부(8420)는 복수 개의 운영서버들로부터 복수 개의 하드웨어 정보를 수집할 수 있다.
이 때, 복수 개의 운영서버들에 상응하는 운영체제 상의 하드웨어 정보 및 복수 개의 운영서버들의 하드웨어 컨트롤러 중 적어도 하나를 이용하여 복수 개의 하드웨어 정보들을 수집할 수 있다. . 예를 들어, 운영체제 상의 하드웨어 정보라 함은 윈도우의 경우에는 repository, 리눅스의 경우에는 proc 파일 시스템을 의미할 수 있다. 또한, 프로파일 관리 장치가 복수 개의 운영서버들 각각에 존재하는 out-of-band Management를 위하여 만들어진 BMC(Baseboard Management Contotoller)에 접속하여 하드웨어 정보를 네트워크를 이용하여 수집할 수도 있다.
이 때, 복수 개의 운영서버들에서는 하드웨어 정보의 수집을 위한 에이전트를 둘 수 있고, 이를 이용하여 프로파일 관리 장치로 하드웨어 정보를 송신할 수 있다.
하드웨어 프로파일 데이터베이스(8430)는 복수 개의 하드웨어 정보를 기반으로 생성된 복수 개의 하드웨어 프로파일들을 저장할 수 있다.
프로파일 비교부(8440)는 복수 개의 운영서버들에 상응하는 복수 개의 하드웨어 프로파일들과 최적 운영서버에 상응하는 타겟 하드웨어 프로파일을 비교할 수 있다.
즉, 복수 개의 하드웨어 프로파일들 중에 타겟 하드웨어 프로파일이 존재하는지 여부를 판단할 수 있다.
이때, 하드웨어 프로파일은 사용자가 가상 데스크탑을 생성하기 위해 참조되는 운영서버의 하드웨어 정보를 포함한 프로파일에 상응할 수 있다. 따라서 복수 개의 운영서버들 각각 서로 다른 하드웨어 정보를 포함할 수 있다.
따라서, 하드웨어 프로파일을 비교함으로써 최적 운영서버가 기존에 존재한 서버인지 또는 이기종의 서버인지를 판단할 수 있다.
프로파일 생성부(8450)는 복수 개의 하드웨어 프로파일들 중 타겟 하드웨어 프로파일이 존재하지 않는 경우에 타겟 하드웨어 프로파일을 기반으로 가상 데스크탑을 구동하기 위한 가상 데스크탑 구동 프로파일을 생성할 수 있다.
또한, 복수 개의 하드웨어 프로파일들 중 타겟 하드웨어 프로파일이 존재하는 경우에는 공유 스토리지에 가상 데스크탑 프로파일이 존재하기 때문에 가상 데스크탑을 구동할 수 있다.
즉, 타겟 하드웨어 프로파일과 동일한 정보가 복수 개의 하드웨어 프로파일들 중에 존재하지 않는다는 의미는 타겟 하드웨어 프로파일에 상응하는 최적 운영서버가 할당된 적이 없는 이기종의 운영서버라는 의미일 수 있다. 즉, 최적 운영서버는 하드웨어 특성이 다르기 때문에 공유 스토리지를 통해 공유되는 가상 데스크탑 구동 프로파일을 사용할 수 없을 수 있다. 그러므로 최적 운영서버가 가상 데스크탑을 구동하기 위한 가상 데스크탑 구동 파일을 생성할 수 있다.
이 때, 타겟 하드웨어 프로파일에 상응하는 가상 데스크탑 템플릿을 생성하고, 가상 데스크탑 템플릿을 이용하여 가상 데스크탑 구동 프로파일을 생성할 수 있다. 또한, 복수 개의 운영서버들에 대해서도 각각의 해당하는 가상 데스크탑 템플릿이 존재할 수 있으며, 시스템에 존재하는 가상 데스크탑 템플릿에 정보는 타겟 하드웨어 프로파일에 상응하게 생성된 가상 데스크탑 템플릿을 포함하도록 업데이트 될 수 있다.
이 때, 가상 데스크탑 구동 프로파일은 가상 데스크탑의 구동을 위해 필요한 가상 장치의 종류 및 가상 장치의 개수 중 적어도 하나의 정보를 포함할 수 있다. 예를 들어, 가상의 CPU, 메모리, 하드 디스크 및 각종 디바이스에 상응하는 정보를 포함할 수 있다.
공유 스토리지(8460)는 최적 운영서버가 가상 데스크탑을 구동할 수 있도록, 가상 데스크탑을 구동하는데 필요한 적어도 하나의 프로파일과 함께 가상 데스크탑 구동 프로파일을 최적 운영서버에게 공유할 수 있다.
이 때, 적어도 하나의 프로파일은 가상 데스크탑을 요청한 사용자의 정보에 상응하는 사용자 프로파일 및 가상 데스크탑이 구동된 후 사용자에 의해 진행된 현재 상태 정보에 상응하는 가상 데스크탑 상태 프로파일 중 적어도 하나를 포함할 수 있다. 즉, 최적 운영서버에서는 가상 데스크탑 구동 프로파일과 사용자 프로파일 및 가상 데스크탑 상태 프로파일 등을 이용하여 가상 데스크탑을 구동할 수 있다. 예를 들어, 사용자 프로파일은 사용자의 아이디, 패스워드 및 신상정보 등에 상응하는 개인정보, 사용자의 가상 데스크탑 이름과 같은 정보 및 윈도우 사용자 프로파일과 같은 가상 데스크탑 환경 정보를 포함할 수 있다.
이 때, 복수 개의 운영서버들에게 가상 데스크탑을 부팅하기 위한 가상 데스크탑 이미지를 공유할 수 있다. 가상 데스크탑 이미지는 가상 데스크탑의 가상 디스크에 상응할 수 있다. 즉, 원격에서 부팅을 수행하는 것과 유사하게 가상 디스크를 이용하여 가상 데스크탑을 부팅할 수 있다.
이 때, 복수 개의 운영서버들은 사용자가 재접속하여 가상 데스크탑을 요청하는 경우에 사용자 프로파일을 기반으로 가상 데스크탑 상태 프로파일을 로드하여 현재 상태 정보에 상응하게 가상 데스크탑을 구동할 수 있다. 예를 들어, 가상 데스크탑이 구동되면 가상 데스크탑이 구동된 상태를 프로파일의 형태로 저장하여 업데이트할 수 있는데, 가상 데스크탑 상태 프로파일이 이와 같은 프로파일에 상응할 수 있다. 따라서 가상 데스크탑 상태 프로파일은 사용자의 현재 진행 상황에 대한 메모리 정보를 포함할 수 있으므로, 사용자가 추후에 재접속한 경우에는 운영서버에서 가상 데스크탑 상태 프로파일을 로딩하여 사용자의 환경을 그대로 유지할 수 있다.
이 때, 가상 데스크탑 상태 프로파일은 복수 개의 운영서버들 각각에 상응하는 MEM 메모리에 별도로 저장될 수 있다.
즉, 가상 데스크탑의 성능은 기본적으로 에뮬레이션 된 하드웨어 장치를 이용하여 서비스를 제공하므로 부팅 속도 및 동작 속도가 느리게 되고, 저장장치의 I/O 한계로 인하여 그 성능을 일반 PC와 비교하기 어려울 수 있다. 그러므로 이와 같은 속도의 한계를 극복하기 위해서 가상 데스크탑의 구동에 필요한 사용자 프로파일과 현재 상태 정보가 포함된 가상 머신 상태 프로파일을 운영서버의 MEM 메모리에 저장하여 사용함으로써 가상 데스크탑의 구동속도를 향상시키는데 활용할 수도 있다.
도 24는 본 발명의 일실시예에 따른 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 장치를 이용한 가상 데스크탑 시스템을 상세하게 나타낸 도면이다.
도 24를 참조하면, 본 발명의 일실시예에 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 장치를 이용한 가상 데스크탑 시스템은 사용자(8500), 프로파일 관리 장치(8510) 및 운영서버 그룹(8520)에 포함된 운영서버(8530, 8540, 8550)를 포함할 수 있다.
도 25에 포함된 구성요소들을 이용하여 이기종 서버에서의 가상 데스크탑 구동을 위한 프로파일 관리 과정을 설명하면, 먼저 사용자(8500)로부터 가상 데스크탑의 할당을 요청 받으면, 프로파일 관리 장치(8510)의 서버 할당부(8511)가 운영서버 그룹(8520)에 포함된 복수 개의 운영서버(8530, 8540, 8550)들 중 최적 운영서버를 할당할 수 있다.
이 때, 최적 운영서버는 복수 개의 운영서버(8530, 8540, 8550)들 각각의 서버 가용률 및 활용도를 고려하여 할당될 수 있다.
예를 들어, 운영서버(8530)가 최적 운영서버이자 이기종의 운영서버라고 가정한다면, 하드웨어 정보 수집부(8512)가 운영서버(8530)의 하드웨어 정보를 수집하고, 타겟 하드웨어 프로파일을 생성하여 하드웨어 프로파일 데이터베이스(8513)에 저장할 수 있다.
이 후, 프로파일 비교부(8514)에서 하드웨어 프로파일 데이터베이스(8513)에 저장된 복수 개의 하드웨어 프로파일들과 타겟 하드웨어 프로파일을 비교할 수 있다.
이 때, 이 때, 운영서버(8530)가 이기종 서버이기 때문에 복수 개의 하드웨어 프로파일들에는 타겟 하드웨어 프로파일에 상응하는 하드웨어 프로파일이 존재하지 않을 수 있다.
따라서, 프로파일 생성부(8515)에서는 운영서버(8530)에서 가상 데스크탑을 구동시키기 위해 타겟 하드웨어 프로파일에 상응하는 가상 데스크탑 템플릿을 생성하고, 가상 데스크탑 템플릿을 이용하여 운영서버(8530)에 상응하는 가상 데스크탑 구동 프로파일을 생성할 수 있다.
이 후, 생성한 가상 데스크탑 구동 프로파일을 사용자 프로파일과 함께 공유 스토리지(8516)에 저장함으로써 최적 운영서버인 운영서버(8530)를 비롯한 나머지 복수 개의 운영서버(8540, 8550)들이 공유할 수 있다.
따라서, 사용자에게 할당된 운영서버(8530)는 공유 스토리지(8516)를 통해 가상 데스크탑 이미지, 사용자 프로파일 및 가상 데스크탑 구동 프로파일을 공유 받아 가상 데스크탑(8531, 8533)을 구동할 수 있다.
예를 들어, 사용자(8500)가 재접속을 수행하여 다시 동일한 가상 데스크탑의 할당을 요청한다고 가정한다면, 공유 스토리지(8516) 또는 복수 개의 운영서버(8530, 8540, 8550)들에 상응하는 MEM 메모리(8532, 8534, 8542, 8544, 8552, 8554) 중 적어도 하나에 저장된 가상 데스크탑 상태 프로파일을 로드하여 사용자(8550)가 진행하던 환경 그대로 가상 데스크탑을 구동할 수 있다. 또한, MEM 메모리(8532, 8534, 8542, 8544, 8552, 8554)에 가상 데스크탑 상태 프로파일을 저장하여 사용함으로써 가상 데스크탑을 구동하는 시간을 단축시킬 수 있어 보다 효과적인 서비스를 제공할 수 있다.
본 발명에 따르면, 서로 다른 이기종의 서버 환경에서 가상 데스크탑 서비스를 제공할 경우에 사용자가 수동으로 프로파일을 수정하거나 오랜 시간 마이그레이션을 통해 제공하는 방법 대신에 보다 효과적으로 가상 데스크탑 서비스를 제공할 수 있는 프로파일 관리 기술을 제공할 수 있다.
또한, 본 발명은 가상 데스크탑을 구동하는 서버의 메모리에 가상 데스크탑의 구동을 위한 프로파일을 저장함으로써 가상 데스크탑의 성능을 보다 향상시킬 수 있다.
도 25은 도 2를 제시된 가상머신 인프라스트럭처(130)를 좀 더 구체화한 것으로 가상 데스크탑 이미지를 하드 디스크에 저장, 운용하는 기존의 시스템이다. 도 25에서, 하이퍼바이저(9012)는 물리적 CPU(9010a), 메인 메모리(9010b), 디스크(9010c)에 기반하여 가상 CPU(9014a), 가상 메인 메모리(9014b), 가상 디스크(9014c)를 생성하여 가상 데스크탑(9014)에 제공한다. 가상 데스크탑(9014)은 이를 기반으로 동작한다.
하이퍼바이저(9012)의 가상 데스크탑 전송 모듈은 가상 데스크탑(9014)을 네트워크를 통하여 클라이언트(9016)로 전송한다.
단일 가상 데스크탑 서버에는 수십대의 가상 데스크탑(9014)이 운영되고 있으며, 가상 데스크탑 부팅과 같이 모든 가상 데스크탑(9014)이 일시에 가상 데스크탑 이미지를 접근할 경우, 가상 데스크탑 이미지가 저장되어 있는 가상 디스크(9014c)에 로드가 집중됨으로써, 전체 시스템의 성능이 저하되는 문제가 발생한다. 특히, 가상 디스크(9014c)는 가상 데스크탑 서버의 다른 자원들(CPU, 메모리)에 비해서 속도가 현저히 느림으로, 성능 저하 현상은 더 크게 발생한다.
도 26는 본 발명의 실시예에 따른 메인 메모리 기반의 가상 데스크탑 시스템의 개요도이다.
도 26에서 가상 CPU 및 가상 메모리를 생성하는 방식은 도 25과 동일하다.
그러나, 도 26에서는 하드 디스크가 아닌 메인 메모리(9020b)를 사용하여 가상 디스크(9024c)를 생성한다는 점에서 상술한 도 25과 차이난다.
도 26에서, 미설명 부호 9020은 하드웨어를 나타내고, 9022는 하이퍼바이저를 나타내고, 9024는 가상데스크탑을 나타낸다.
도 27은 본 발명의 실시예에 따른 메인 메모리 기반의 가상 데스크탑 시스템의 구성을 구체적으로 도시한 도면이다. 도 3에 도시된 구성을 인메모리 가상 데스크탑 시스템 또는 가상 데스크탑 서버라고 부를 수 있다.
본 발명의 실시예에 따른 메인 메모리 기반의 가상 데스크탑 시스템은, 하드웨어(9020), 하이퍼바이저(9022), 가상 데스크탑(9024), 및 클라이언트(9016)를 포함한다.
하드웨어(9020)는 물리적 자원으로서 CPU(9020a) 및 메인 메모리(9020b)를 포함한다. 여기서, 메인 메모리(9020b)는 다수의 가상 데스크탑 이미지(가상 데스크탑 이미지 1 ~ 가상데스크탑 이미지 N)를 저장한다.
하이퍼바이저(9022)는 하드웨어(9020)의 자원(CPU(9020a), 메인 메모리(9020b))을 가상화하여 가상 데스크탑(9024)에게 제공한다. 여기서, 가상 데스크탑(9024)은 다수개로 구성될 수 있다.
가상 데스크탑(9024)은 가상 자원을 기반으로 동작한다. 또한 동작중인 가상 데스크탑(9024)은 하이퍼바이저(9022)의 가상 데스크탑 전송 엔진(9072)을 통하여 클라이언트(9016)로 전송된다.
백업 스토리지(9026)는 메인 메모리(9020b)에 존재하는 가상 데스크탑 이미지를 백업 및 복구하기 위한 저장 장치로 사용된다.
하이퍼바이저(9022)는 CPU 가상화 엔진(9032), 메모리 가상화 엔진(9042), 인메모리 디스크 가상화 엔진(9052), 인메모리 가상 데스크탑 이미지 관리 엔진(9062), 및 가상 데스크탑 전송 엔진(9072)을 포함한다.
CPU 가상화 엔진(9032)은 하드웨어(9020)의 CPU(9020a)를 가상화하는 엔진으로서, 기존의 가상 데스크탑 시스템에서 사용되는 엔진과 동일하다.
메모리 가상화 엔진(9042)은 하드웨어(9020)의 메인 메모리(9020b)를 가상화하는 엔진으로서, 기존의 가상 데스크탑 시스템에서 사용되는 엔진과 동일하다.
인메모리 디스크 가상화 엔진(9052)은 메인 메모리(9020b)에 기반하여 가상 디스크(9024c)를 생성하고 이를 가상 데스크탑(9024)에게 제공한다.
인메모리 디스크 가상화 엔진(9052)은 가상 디스크 모듈부(9052a), 블록 중복 제거 모듈부(9052b), 및 메모리-디스크 에뮬레이션 모듈부(9052c)를 포함한다.
가상 디스크 모듈부(9052a)는 가상 디스크(9024c)에서 발생한 블록(block) 단위의 읽기/쓰기 명령어를 수신하고, 블록 중복 제거 모듈부(9052b) 및 메모리-디스크 에뮬레이션 모듈부(9052c)을 사용하여 블록 읽기/쓰기 명령어를 처리한다.
블록 중복 제거 모듈부(9052b)는 가상 디스크(9024c)상에 존재하는 블록들을 대상으로 중복 제거를 수행한다. 블록들 단위의 중복 제거를 수행함으로써, 전체 가상 데스크탑 이미지들의 물리적 크기를 감소시킬 수 있다.
메모리-디스크 에뮬레이션 모듈부(9052c)는 블록 단위로 전송된 읽기/쓰기 명령어들을 주소 단위로 접근 가능한 메인 메모리(9020b)상에 실제 읽기/쓰기 동작을 수행한다. 이를 통하여 메인 메모리(9020b)상에 가상 데스크탑(9024)을 위한 가상 데스크탑 이미지들이 저장된다.
인메모리 가상 데스크탑 이미지 관리 엔진(9062)은 메모리-디스크 저장 모듈부(9062a) 및 디스크-메모리 로딩 모듈부(9062b)를 포함한다.
메인 메모리(9020b)는 휘발성이므로, 메인 메모리(9020b)에 저장되어 있는 가상 데스크탑 이미지(가상 데스크탑 이미지 1 ~ 가상데스크탑 이미지 N)는 가상 데스크탑 서버의 전원이 꺼지면 데이터를 잃어버리게 된다.
따라서, 메모리-디스크 저장 모듈부(9062a)는 가상 데스크탑 서버의 전원이 꺼지기 전에 메인 메모리(9020b)에 있는 가상 데스크탑 이미지를 백업 스토리지(9026)로 저장한다.
디스크-메모리 로딩 모듈부(9062b)는 가상 데스크탑 서버의 전원이 켜졌을 때, 백업 스토리지(9026)에 있는 가상 데스크탑 이미지를 메인 메모리(9020b)에게로 로딩한다.
도 28는 도 27에 도시된 메인 메모리(9020b)의 구조를 나타낸 도면이다.
본 발명의 실시예에서, 메인 메모리(9020b)는 하이퍼바이저 동작 메모리 영역, 가상 메인 메모리용 영역, 및 가상 디스크용 영역을 포함한다.
하이퍼바이저 동작 메모리 영역은 하이퍼바이저(9022)가 동작하는데 필요한 메모리 영역이다.
가상 메인 메모리용 영역은 가상 데스크탑용 가상 메모리를 위해서 사용되는 영역이다. 다시 말해서, 가상 메인 메모리용 영역은 모든 가상 데스크탑(9024)을 위한 가상 메인 메모리(9024b)를 포함한다.
가상 디스크용 영역은 가상 데스크탑용 가상 디스크를 위해 사용되는 영역이다. 다시 말해서, 가상 디스크용 영역에는 가상 데스크탑 이미지가 저장된다. 그리고, 가상 데스크탑 이미지는 인메모리 디스크 가상화 엔진(9052)에 의해서 가상 디스크(9024c) 형태로 가상 데스크탑(9024)에 제공된다.
이번에는, 가상 데스크탑(9024)에서 가상 디스크(9024c)의 블록에 대한 읽기가 발생하였을 경우에 메인 메모리(9020b)에서 읽기까지의 과정을 설명한다. 도 29는 도 27에 도시된 가상 디스크에 대한 읽기 과정을 설명하기 위한 흐름도이고, 도 30은 도 27에 도시된 가상 디스크에 대한 읽기/쓰기 과정 설명에 채용되는 도면이고, 도 31은 본 발명의 실시예에 채용되는 중복 제거 테이블을 설명하는 도면이다.
예를 들어, 가상 데스크탑 2에서 블록 1에 대한 읽기가 발생하였을 경우를 가정하고 설명한다.
먼저, 가상 데스크탑(9024)에서 자신의 가상 디스크(9024c)에 대한 읽기가 발생하면, 가상 데스크탑(9024)은 읽기 명령어를 생성하여 가상 디스크 모듈부(9052a)로 전달된다(S9010). 이때, 읽기 명령어는 (가상 데스크탑 이미지ID, 블록ID, 읽기)로 표현된다. 앞서의 예에서는 가상 데스크탑 2에서 블록 1에 대한 읽기가 발생하였을 경우로 가정하였으므로, 읽기 명령어는 (가상 데스크탑 이미지 2, 블록 1, 읽기)로 표현될 것이다.
그에 따라, 가상 디스크 모듈부(9052a)는 모든 가상 데스크탑 이미지를 관리하기 위해서 단일 이미지 풀을 유지한다(도 30 참조). 이때, 단일 이미지 풀에 있는 블록들은 유일한 블록 ID를 가진다. 따라서, 가상 디스크 모듈부(9052a)는 (가상 데스크탑 이미지 ID, 블록 ID, 읽기) 명령어를 (이미지풀 블록 ID, 읽기) 명령어로 변환한다(S9012). 이때, 이미지풀 블록 ID는 "이미지풀 블록 ID = 이미지풀에서 해당 가상 데스크탑 이미지의 시작 블록 ID + 블록ID"와 같이 생성될 수 있다. 도 30을 보면, 상기 예에서는 가상 데스크탑 이미지 2의 시작 블록 ID는 4이고, 가상 데스크탑 이미지 2의 블록 1에 대해 읽기가 발생하였으므로 블록 ID는 1이 된다. 따라서, 이미지풀 블록 ID는 5가 된다. 결국, (가상 데스크탑 이미지 2, 블록 1, 읽기) 명령어는 (이미지풀 블록 5, 읽기) 명령어로 변환된다.
이후에, 블록 중복 제거 모듈부(9052b)는 (이미지풀 블록 ID, 읽기) 명령어를 (중복제거풀 블록 ID, 읽기) 명령어로 변환한다(S9014). 이러한 변환을 수행할 때 도 31의 중복 제거 테이블을 사용한다. 중복 제거 테이블은 (이미지풀 블록 ID, 중복제거풀 블럭ID) 로 표현된다. 즉, 이미지풀에 있는 블록 ID는 매핑되는 중복제거풀의 블록 ID를 나타낸다.
이미지풀은 모든 가상 데스크탑 이미지에 있는 블록들을 포함하고 있으며, 내용이 동일한 블록들은 중복제거풀의 단일 블록으로 매핑될 수 있다. 도 31에서, 패턴 모양이 같은 블록은 내용이 동일한 블럭으로 표현될 수 있다. 예를 들어서, 이미지풀의 블록 0과 블록 4는 상호 동일한 내용을 가짐으로 중복제거풀의 블록 0으로 매핑될 수 있다. 그에 따라, 블록 중복 제거 모듈부(52b)는 예를 들어 (이미지풀 블록 5, 읽기) 명령어를 (중복제거풀 블록 3, 읽기) 명령어로 변환시킨다.
이후, 메모리-디스크 에뮬레이션 모듈부(9052c)는 중복제거풀 블록 ID를 가지고 메인 메모리 블록 ID를 계산한다(S9016). 여기서, 메인 메모리 블록은 가상 데스크탑 이미지를 메인 메모리(9020b)상에 블록 단위로 저장하기 위해서 주소 단위로 접근 가능한 메인 메모리(9020b)의 가상 디스크용 영역을 블럭 단위로 구분해 놓은 것이다. 중복제거풀 블럭 ID에서 메인 메모리 블록 ID를 계산하는 방법의 예는 일대일 매핑을 사용하는 것이다. 즉, 중복제거풀 블록 i는 메인 메모리 블록 i로 매핑된다. 예를 들어, (중복제거풀 블록3, 읽기) 명령어는 (메인 메모리 블록 3, 읽기) 명령어로 변환된다.
이와 같이 메인 메모리 블록 ID가 계산되면, 메모리-디스크 에뮬레이션 모듈부(9052c)는 이를 기반으로 메인 메모리(9020b)의 주소를 계산한다(S9018). 여기서, 메인 메모리(9020b)의 주소를 계산하는 방법은 "메인 메모리 주소 = 가상 디스크용 메인 메모리 영역의 시작 주소 + 블록 크기 * 메인 메모리 블록 ID"와 같을 수 있다.
따라서, 메모리-디스크 에뮬레이션 모듈부(9052c)에 의해 (메인 메모리 블록ID, 읽기) 명령어는 (메인 메모리 주소, 읽기) 명령어로 변환된다.
메인 메모리의 주소가 결정되면, 메모리-디스크 에뮬레이션 모듈부(9052c)는 해당 메인 메모리 주소에서 블록 크기만큼의 데이터를 읽어서 가상 데스크탑(9024)으로 전달한다(S9020). 예를 들어, (메인 메모리 블록 3, 읽기)는 (메인 메모리 주소 0x30008000, 읽기) 명령어로 변환된다.
이번에는, 가상 데스크탑(9024)에서 가상 디스크(9024c)의 블록에 대한 쓰기가 발생했을 때 메인 메모리(9020b)에 저장되기까지의 과정을 설명한다. 도 32은 도 27에 도시된 가상 디스크에 대한 쓰기 과정을 설명하기 위한 흐름도이다.
가상 데스크탑(9024)에서 자신의 가상 디스크(9024c)에 대한 쓰기가 발생하면, 가상 데스크탑(9024)은 쓰기 명령어를 생성하여 가상 디스크 모듈부(9052a)로 전달한다(S9030). 이때, 쓰기 명령어는 (가상 데스크탑 이미지ID, 블록ID, 쓰기)로 표현된다.
그에 따라, 가상 디스크 모듈부(9052a)는 수신한 (가상 데스크탑 이미지 ID, 블록 ID, 쓰기) 명령어를 (이미지풀 블록 ID, 쓰기) 명령어로 변환한다(S9032). 가상 디스크 모듈부(9052a)는 (이미지풀 블록 ID, 쓰기) 명령어를 블록 중복 제거 모듈부(9052b)에게로 전달한다.
이후, 블록 중복 제거 모듈부(9052b)는 쓰고자 하는 블록의 내용과 동일한 블록이 중복제거풀에 존재하는지 조사한다(S9034).
동일한 블록이 존재한다면, 블록 중복 제거 모듈부(9052b)는 쓰고자 하는 블록에 대한 정보인 (이미지풀 블록ID, 중복제거풀 블록ID)를 중복 제거 테이블에 추가한다(S9046).
만약, 동일한 블록이 존재하지 않는다면 블록 중복 제거 모듈부(9052b)는 중복제거풀에서 사용중이지 않은(비어있는) 블록을 할당받고, 중복 제거 테이블에 쓰고자 하는 블록에 대한 정보를 추가한다(S9036).
그리고 나서, 블록 중복 제거 모듈부(9052b)는 새로 할당받은 중복제거풀 블록을 사용하여 (이미지풀 블록ID, 쓰기) 명령어를 (중복제거풀 블록ID, 쓰기) 명령어로 변환한다(S9038).
이후, 메모리-디스크 에뮬레이션 모듈부(9052c)에서 (중복제거풀 블록ID, 쓰기) 명령어를 (메인 메모리 블록ID, 쓰기) 명령어로 변환한다(S9040).
그리고, 최종적으로 메모리-디스크 에뮬레이션 모듈부(9052c)는 (메인 메모리 블록ID, 쓰기) 명령어를 (메인 메모리 주소, 쓰기) 명령어로 변환한다(S9042).
이와 같이 메인 메모리의 주소가 결정되면, 메모리-디스크 에뮬레이션 모듈부(9052c)는 해당 메인 메모리 주소에 쓰고자 하는 블록을 쓴다(S9044).
한편, 가상 데스크탑 이미지가 저장되어 있는 메인 메모리(9020b)의 가상 디스크용 영역은 휘발성 메모리이므로, 가상 데스크탑 서버의 전원이 꺼지면 가상 데스크탑 이미지를 잃어버리게 된다. 따라서, 인메모리 가상 데스크탑 이미지 관리 엔진(9062)은 메인 메모리(9020b)의 가상 디스크용 영역을 비휘발성 백업 스토리지(9026)로 저장 및 로딩하는 작업을 수행한다(도 33 참조). 도 33는 도 27에 도시된 메인 메모리(9020b)의 가상 데스크탑 이미지 저장 및 로딩 설명에 채용되는 도면이다.
인메모리 가상 데스크탑 이미지 관리 엔진(9062)내의 메모리-디스크 저장 모듈부(9062a)는 가상 데스크탑 서버가 종료하기 전에 메인 메모리(9020b)에 있는 가상 데스크탑 이미지를 백업 스토리지(9026)에 저장한다. 즉, 메모리-디스크 저장 모듈부(9062a)는 메인 메모리(9020b)에 있는 가상 디스크용 영역 전체를 백업 스토리지(9026)에 단일 파일 형태로 복사한다. 이때, 메인 메모리상의 블록 i는 백업 파일의 동일한 위치인 블록 i로 저장된다.
도 34은 도 27에 도시된 메모리-디스크 저장 모듈부(9062a)의 동작 순서도이다.
처음에 백업 스토리지(9026)에 존재하는 이미지 백업 파일을 쓰기용으로 연다(S9050). 이후, 블록 인덱스 i를 0으로 초기화한다(S9052).그리고, 메인 메모리(9020b)의 블록 i에 해당하는 메인 메모리 주소를 계산한다(S9054).이후, 계산된 메인 메모리 주소에서 블록 크기만큼의 데이터를 이미지 백업 파일의 블록i 위치로 복사한다(S9056). 블록 i의 복사 과정은 메인 메모리(9020b)의 가상 디스크용 영역의 블록 단위 크기 동안 반복 수행한다(S9058, S9060). 메인 메모리의 모든 블록이 복사되면 이미지 백업 스토리지용 write buffer를 플러시(flush)하여 모든 쓰기가 이미지 백업 파일에 물리적으로 쓰기 완료되도록 한다(S9062). 이후, 이미지 백업 파일을 닫고(S9064), 저장 과정을 종료한다.
도 35은 도 27에 도시된 디스크-메모리 로딩 모듈부(9062b)의 동작 순서도이다.
처음에 메인 메모리(9020b)상에 가상 디스크용 영역을 할당받는다(S9070). 이후, 가상 디스크용 영역이 하드 디스크로 페이지 아웃(page-out)되지 않도록 본 영역(즉, 가상 디스크용 영역)을 핀다운 시킨다(S9072). 그리고, 백업 스토리지(9026)에 있는 이미지 백업 파일을 읽기용으로 연다(S9074). 블록 인덱스 i를 0으로 초기화한다(S9076).메인 메모리(9020b)의 블록 i에 해당하는 메인 메모리 주소를 계산한다(S9078). 이후, 백업 이미지 파일의 블록 i를 계산된 메인 메모리 주소로 블록 크기만큼 복사한다(S9080). 블록 i의 복사 과정은 이미지 백업 파일의 블록 단위 크기 동안 반복 수행한다(S9082, S9084). 이미지 백업 파일의 모든 블록이 복사되면, 메인 메모리용 write buffer를 플러시(flush)하여 모든 쓰기가 메인 메모리에 물리적으로 쓰기 완료되도록 한다(S9086). 이후, 이미지 백업 파일을 닫고(S9088), 로딩 과정을 종료한다.
이상에서와 같이 도면과 명세서에서 최적의 실시예가 개시되었다. 여기서 특정한 용어들이 사용되었으나, 이는 단지 본 발명을 설명하기 위한 목적에서 사용된 것이지 의미 한정이나 특허청구범위에 기재된 본 발명의 범위를 제한하기 위하여 사용된 것은 아니다. 그러므로, 본 기술 분야의 통상의 지식을 가진자라면 이로부터 다양한 변형 및 균등한 타 실시예가 가능하다는 점을 이해할 것이다. 따라서, 본 발명의 진정한 기술적 보호범위는 첨부된 특허청구범위의 기술적 사상에 의해 정해져야한다.
본 발명에 따르면, 가상 데스크탑 이미지를 스토리지 장치가 아닌 메인 메모리상에 저장하여 고속 가상 데스크탑 서비스를 제공하여 가상 디스크에 대한 가상 데스크탑의 읽기/쓰기 요구가 집중되어도 메인 메모리상에서 고속 처리가 가능함으로 전체 시스템의 성능을 향상시켜 줄 수 있다.
110 : 커넥션브로커
120 : 리소스풀
130 : 가상머신인프라스트럭쳐

Claims (8)

  1. 가상 데스크탑 서비스(Virtual Desktop Service)을 사용하는 사용자 단말과 가상 데스크탑 서비스를 제공하는 복수의 서버들 간에 사용되는 전달 프로토콜의 코디네이션 작업을 수행하는 커넥션 브로커;
    상기 가상 데스크탑 서비스를 위한 운영체제를 포함하는 소프트웨어 리소스를 제공하는 리소스 풀; 및
    하드웨어 리소스를 지원하고 상기 하드웨어 리소스에 상기 소프트웨어 리소스에 저장된 소프트웨어를 동적으로 할당하는 가상머신 인프라스트럭처;를 포함하는 인메모리 기반 가상 데스크탑 서비스를 위한 장치.
  2. 제 1항에 있어서, 상기 가상머신 인프라스트럭처는
    상기 가상 머신 구동을 지원하는 하이퍼바이저;를 포함하는 것을 특징으로 하는 인메모리 기반 가상 데스크탑 서비스를 위한 장치.
  3. 제 1항에 있어서, 가상데스크탑 서비스를 위한 장치는 서비스 구동을 위한 프로파일 관리장치를 포함하는 인메모리 기반 가상 데스크탑 서비스를 위한 장치.
  4. 제 1항에 있어서, 상기 가상머신 인프라스트럭처는
    가상 데스크탑 이미지가 저장된 메인 메모리를 포함하는 하드웨어; 및
    상기 하드웨어의 자원을 가상화하여 가상 데스크탑에게 제공하는 하이퍼바이저;를 포함하는 것을 특징으로 하는 인메모리 기반 가상 데스크탑 서비스를 위한 장치.
  5. 청구항 5에 있어서,
    상기 하이퍼바이저는,
    상기 가상 데스크탑에게 제공하는 인메모리 디스크 가상화 엔진을 포함하는 것을 특징으로 하는 인메모리 기반 가상 데스크탑 서비스를 위한 장치
  6. 커넥션 브로커가 가상 데스크탑 서비스(Virtual Desktop Service)를 위한 사용자 단말의 하드웨어에 적합한 가상 머신을 찾는 단계;
    상기 커넥션 브로커가 상기 적합한 가상 머신이 없는 경우 가상머신 인프라스트럭처에 해당 가상머신 생성을 요청하고, 상기 적합한 가상 머신이 있는 경우 상기 커넥션 브로커가 해당 가상 머신에 사용자 프로파일을 적용하고 가상 데스트탑을 생성하는 단계; 및
    상기 커넥션 브로커가 상기 생성된 가상 데스크탑을 상기 사용자 단말에 전송하기 위한 연결 정보를 가상 데스크탑의 전송 프로토콜을 사용하여 상기 가상 데스크탑을 상기 사용자 단말에 전송하는 단계;를 포함하는 인메모리 기반 가상 데스크탑 서비스 방법.
  7. 제 6항에 있어서, 가상 데스크탑 서비스 방법은
    상기 가상 데스크탑 서비스 구동을 위한 프로파일 관리하는 단계를 더 포함하는 것을 특징으로 하는 인메모리 기반 가상 데스크탑 서비스방법.
  8. 제 7항에 있어서, 상기 프로파일을 관리하는 단계는,
    사용자요청에 의해 복수 개의 운영서버들 중 가상 데스크탑을 구동할 어느 하나의 최적 운영서버를 할당하는 단계;를 더 포함하는 것을 특징으로 하는 인메모리 기반 가상 데스크탑 서비스방법.
KR1020150089625A 2015-06-24 2015-06-24 인메모리 기반 가상 데스크탑 서비스를 위한 장치 및 방법 KR101929048B1 (ko)

Priority Applications (2)

Application Number Priority Date Filing Date Title
KR1020150089625A KR101929048B1 (ko) 2015-06-24 2015-06-24 인메모리 기반 가상 데스크탑 서비스를 위한 장치 및 방법
US15/092,769 US10379891B2 (en) 2015-06-24 2016-04-07 Apparatus and method for in-memory-based virtual desktop service

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020150089625A KR101929048B1 (ko) 2015-06-24 2015-06-24 인메모리 기반 가상 데스크탑 서비스를 위한 장치 및 방법

Publications (2)

Publication Number Publication Date
KR20170000568A true KR20170000568A (ko) 2017-01-03
KR101929048B1 KR101929048B1 (ko) 2018-12-13

Family

ID=57602339

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020150089625A KR101929048B1 (ko) 2015-06-24 2015-06-24 인메모리 기반 가상 데스크탑 서비스를 위한 장치 및 방법

Country Status (2)

Country Link
US (1) US10379891B2 (ko)
KR (1) KR101929048B1 (ko)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101848356B1 (ko) * 2017-07-07 2018-05-28 (주)한위드정보기술 인메모리 기반 가상화 서비스 제공 시스템
KR20210027338A (ko) * 2019-02-28 2021-03-10 에스케이브로드밴드주식회사 특정 시점의 환경을 제공할 수 있는 가상 데스크톱 시스템 및 그 데이터 처리 방법
KR102442248B1 (ko) * 2022-03-18 2022-09-13 나무기술 주식회사 클라우드 인프라 기반으로 구축된 DaaS의 자원 관리 및 자원 사용량에 대한 예측 시스템

Families Citing this family (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101920474B1 (ko) * 2015-06-15 2018-11-20 한국전자통신연구원 인메모리 가상 데스크탑 시스템
US10567548B2 (en) * 2017-01-25 2020-02-18 Wipro Limited System and method for determining service prioritization in virtual desktop infrastructure
US10936331B2 (en) * 2017-02-23 2021-03-02 International Business Machines Corporation Running a kernel-dependent application in a container
US10880272B2 (en) * 2017-04-20 2020-12-29 Wyse Technology L.L.C. Secure software client
GB2565282B (en) * 2017-08-02 2021-12-22 Vnc Automotive Ltd Remote control of a computing device
US11042394B2 (en) 2017-10-13 2021-06-22 Electronics And Telecommunications Research Institute Method for processing input and output on multi kernel system and apparatus for the same
KR101925404B1 (ko) * 2017-11-20 2018-12-05 (주)한위드정보기술 인메모리 기반 이중화 지원 가상화 서비스 제공 시스템
US11113400B1 (en) * 2017-12-26 2021-09-07 Virtuozzo International Gmbh System and method for providing distributed compute platform on untrusted hardware
US10728343B2 (en) * 2018-02-06 2020-07-28 Citrix Systems, Inc. Computing system providing cloud-based user profile management for virtual sessions and related methods
US11444925B1 (en) 2019-04-10 2022-09-13 Ca, Inc. Secure access to a corporate application in an SSH session using a transparent SSH proxy
US20210117208A1 (en) * 2019-10-18 2021-04-22 Vmware, Inc. User profile migration to virtual desktop infrastructure
CN111008053A (zh) * 2019-10-25 2020-04-14 西安雷风电子科技有限公司 一种虚拟桌面的自动同步方法及装置
US10958539B1 (en) * 2019-12-02 2021-03-23 Cisco Technology, Inc. Network function virtualization compute element image upgrade
US11514100B2 (en) * 2020-12-17 2022-11-29 EMC IP Holding Company LLC Automatic detection and identification of gold image library files and directories
US11513904B2 (en) * 2020-12-17 2022-11-29 EMC IP Holding Company LLC Gold image library management system to reduce backup storage and bandwidth utilization

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20130007373A (ko) * 2011-07-01 2013-01-18 한국전자통신연구원 가상 데스크탑 서비스를 위한 방법 및 아키텍처
JP2014106898A (ja) * 2012-11-29 2014-06-09 Hitachi Systems Ltd 仮想デスクトップシステム及び仮想デスクトップのハングアップ回避方法
KR20140077656A (ko) * 2012-12-14 2014-06-24 한국전자통신연구원 가상 데스크탑 인프라 시스템 및 그의 데이터 처리 방법
US20150095597A1 (en) * 2013-09-30 2015-04-02 American Megatrends, Inc. High performance intelligent virtual desktop infrastructure using volatile memory arrays
KR20150042643A (ko) * 2013-10-11 2015-04-21 삼성전자주식회사 Vdi 환경에서 가상 서버와 접속을 위한 단말 장치 및 방법

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CA2713876C (en) 2008-02-26 2014-11-04 Vmware, Inc. Extending server-based desktop virtual machine architecture to client machines
KR100931518B1 (ko) 2008-04-22 2009-12-14 주식회사 안철수연구소 가상 데스크탑을 이용한 프로그램 보호 방법
KR101554554B1 (ko) 2013-11-29 2015-09-22 한국과학기술정보연구원 가상 머신 구동 시스템 및 방법
KR20150085309A (ko) 2014-01-15 2015-07-23 한국전자통신연구원 서버 가상 머신 제공 방법 및 시스템과 이를 지원하는 서버 장치
KR101609371B1 (ko) 2014-03-07 2016-04-05 주식회사 엔유정보통신 유무선통신 제로클라이언트를 지원하는 데스크톱 가상화 시스템
KR20150109692A (ko) 2014-03-20 2015-10-02 한국전자통신연구원 가상 머신 이미지 파일을 제공하는 방법 및 그 장치
US9619268B2 (en) * 2014-08-23 2017-04-11 Vmware, Inc. Rapid suspend/resume for virtual machines via resource sharing

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20130007373A (ko) * 2011-07-01 2013-01-18 한국전자통신연구원 가상 데스크탑 서비스를 위한 방법 및 아키텍처
JP2014106898A (ja) * 2012-11-29 2014-06-09 Hitachi Systems Ltd 仮想デスクトップシステム及び仮想デスクトップのハングアップ回避方法
KR20140077656A (ko) * 2012-12-14 2014-06-24 한국전자통신연구원 가상 데스크탑 인프라 시스템 및 그의 데이터 처리 방법
US20150095597A1 (en) * 2013-09-30 2015-04-02 American Megatrends, Inc. High performance intelligent virtual desktop infrastructure using volatile memory arrays
KR20150042643A (ko) * 2013-10-11 2015-04-21 삼성전자주식회사 Vdi 환경에서 가상 서버와 접속을 위한 단말 장치 및 방법

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101848356B1 (ko) * 2017-07-07 2018-05-28 (주)한위드정보기술 인메모리 기반 가상화 서비스 제공 시스템
KR20210027338A (ko) * 2019-02-28 2021-03-10 에스케이브로드밴드주식회사 특정 시점의 환경을 제공할 수 있는 가상 데스크톱 시스템 및 그 데이터 처리 방법
KR102442248B1 (ko) * 2022-03-18 2022-09-13 나무기술 주식회사 클라우드 인프라 기반으로 구축된 DaaS의 자원 관리 및 자원 사용량에 대한 예측 시스템

Also Published As

Publication number Publication date
KR101929048B1 (ko) 2018-12-13
US10379891B2 (en) 2019-08-13
US20160378535A1 (en) 2016-12-29

Similar Documents

Publication Publication Date Title
KR101929048B1 (ko) 인메모리 기반 가상 데스크탑 서비스를 위한 장치 및 방법
KR102328193B1 (ko) 가상 데스크탑 서비스를 위한 장치 및 방법
US10089130B2 (en) Virtual desktop service apparatus and method
US9489227B2 (en) Apparatus and method for virtual desktop service
US20190334765A1 (en) Apparatuses and methods for site configuration management
US9710297B2 (en) Dynamic allocation and assignment of virtual environment
KR101507919B1 (ko) 가상 데스크탑 서비스를 위한 방법 및 장치
US20200106669A1 (en) Computing node clusters supporting network segmentation
US9712605B2 (en) Method and system for providing server virtual machine for real-time virtual desktop service, and server device supporting the same
US11080041B1 (en) Operating system management for virtual workspaces
CN106104486B (zh) 用于向云中安全传输卷的方法和系统
US11159367B2 (en) Apparatuses and methods for zero touch computing node initialization
US20160371102A1 (en) System and method for supporting execution of application based on multi-platform using virtual platform service
KR102102169B1 (ko) 가상 데스크탑 서비스를 위한 장치 및 가상 데스크탑 서비스 방법
KR20150124001A (ko) 클라우드 기반 웹 호스팅 시스템
KR20130127629A (ko) 가상화 애플리케이션 제공 장치 및 그 방법
US11907743B2 (en) System and method for relocating customer virtual machine instances in a multi-tenant cloud service
US10979289B2 (en) Apparatuses and methods for remote computing node registration and authentication
US11212168B2 (en) Apparatuses and methods for remote computing node initialization using a configuration template and resource pools
US10747567B2 (en) Cluster check services for computing clusters
CN104780156A (zh) 安全云桌面系统及其usb访问控制方法
US20230359533A1 (en) User Triggered Virtual Machine Cloning for Recovery/Availability/Scaling
US10367883B2 (en) Computing resource management using dedicated leadership pool
Draganov Exploiting private and hybrid clouds for compute intensive web applications
Huawei Technologies Co., Ltd. Virtualization Technology

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right