KR20160012863A - 가상 머신을 실행하는 전자 장치 및 가상 머신을 실행하는 방법 - Google Patents

가상 머신을 실행하는 전자 장치 및 가상 머신을 실행하는 방법 Download PDF

Info

Publication number
KR20160012863A
KR20160012863A KR1020140132463A KR20140132463A KR20160012863A KR 20160012863 A KR20160012863 A KR 20160012863A KR 1020140132463 A KR1020140132463 A KR 1020140132463A KR 20140132463 A KR20140132463 A KR 20140132463A KR 20160012863 A KR20160012863 A KR 20160012863A
Authority
KR
South Korea
Prior art keywords
disk image
virtual machine
electronic device
base disk
base
Prior art date
Application number
KR1020140132463A
Other languages
English (en)
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 US14/807,408 priority Critical patent/US20160026492A1/en
Priority to PCT/KR2015/007740 priority patent/WO2016013906A1/en
Publication of KR20160012863A publication Critical patent/KR20160012863A/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering

Landscapes

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

Abstract

전자 장치에서 가상 머신을 실행하는 방법이 개시된다. 하나의 실시예에서, 가상 머신을 실행하는 방법은, 디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지의 위치를 획득하는 동작; 상기 획득된 위치에 근거하여, 상기 제 1 베이스 디스크 이미지를 참조(backing)하는 루트 디스크 이미지를 생성하는 동작; 및 상기 생성된 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작을 포함할 수 있다.

Description

가상 머신을 실행하는 전자 장치 및 가상 머신을 실행하는 방법{ELECTRONIC APPARATUS FOR EXECUTING VIRTUAL MACHINE AND METHOD FOR EXECUTING VIRTUAL MACHINE}
본 발명은 가상 머신을 실행하는 전자 장치 및 방법에 관한 것이다.
최근에 들어, 가상화 기술을 활용한 다중 서버의 도입이 활발하게 진행되고 있다. 가상화 기술은, 하나의 물리적인 장비를 마치 여러개의 장비처럼 사용하는 기술로, CPU, 메모리, 스토리지, 네트워크 등의 컴퓨팅 자원의 활용을 극대화하고, 대규모 데이터 센터의 관리를 위해 자원을 운영하고 관리하는 기술이다. 한편, 가상화 기술에서는, 가상 머신(VM:Virtual Machine)이 정의될 수 있다. 가상 머신은 실질적인 물리서버의 가상화(virtualization)이며, 물리적인 디스크에 적어도 하나의 가상 디스크를 포함할 수 있다. 가상 머신 모니터(VMM:Virtual Machine Monitor)를 실행하는 단일 호스트 컴퓨터가 복수의 호스트의 뷰 또는 추상화를 제공하여 호스트의 기반 하드웨어가 독립적으로 동작하는 하나 이상의 가상 머신처럼 보이게 하는 것을 가능하게 한다. 가상 머신은 운영체제(OS) 또는 소프트웨어 어플리케이션들을 실행하는 일체 완비된(self-contained) 플랫폼으로서 기능할 수 있다. 가상 머신은, 완비된 플랫폼에 대응하는 가상 디스크 이미지를 저장하고, 저장된 가상 디스크 이미지를 이용하여 특정 OS 또는 어플리케이션 포함 모드를 제공할 수 있다.
상술한 바와 같이, 전자 장치에서, 가상 머신을 실행하기 위하여서는 가상 디스크 이미지를 저장하여야 한다. 한편, 요구되는 가상 머신에 대응하는 가상 디스크 이미지가 저장되어 있지 않은 경우에는, 전자 장치는 해당 가상 디스크 이미지를 디스크 이미지 저장소로부터 다운로드하여야 한다. 하지만, 가상 디스크 이미지의 용량은 일반적으로 GB급이며, 이에 따라 다운로드에 요구되는 시간이 오래 걸리는 문제점이 존재하였다.
본 발명의 다양한 실시 예들은 전술한 문제점 또는 다른 문제점을 해결하기 위한 가상 머신을 실행하는 전자 장치 및 가상 머신을 실행하는 방법을 제공할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지의 위치를 획득하는 동작; 상기 획득된 위치에 근거하여, 상기 제 1 베이스 디스크 이미지를 참조(backing)하는 루트 디스크 이미지를 생성하는 동작; 및 상기 생성된 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작을 포함할 수 있다.
본 발명의 실시 예에 따르면, 가상 머신을 실행하는 전자 장치는, 제 1 베이스 디스크 이미지를 저장하는 디스크 이미지 저장소와 통신 연결을 형성하는 통신 인터페이스; 및 디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지의 위치를 획득하고, 상기 획득된 위치에 근거하여 상기 제 1 베이스 디스크 이미지를 참조(backing)하는 루트 디스크 이미지를 생성하며, 상기 생성된 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 프로세서를 포함할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 상기 전자 장치의 외부에 저장되는 제 1 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작; 상기 루트 디스크 이미지의 참조 대상을 상기 제 1 베이스 디스크 이미지로부터 상기 전자 장치의 내부에 저장되는 제 2 베이스 디스크 이미지로 변경하는 동작; 및 상기 제 2 베이스 디스크 이미지를 참조하는 상기 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작을 포함할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 상기 전자 장치의 외부에 저장되는 제 1 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작; 상기 제 1 베이스 디스크 이미지를 다운로드 하여, 상기 전자 장치의 내부에 제 2 베이스 디스크 이미지를 저장하는 동작; 및 상기 다운로드가 완료되면, 상기 루트 디스크 이미지와 상기 제 2 베이스 디스크 이미지를 머지(merge)하여 머지드 디스크 이미지(merged disk image)를 생성하고, 상기 생성된 머지드 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작을 포함할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치의 화면 구성 방법은, 제 1 환경에 근거한 제 1 화면을 표시하는 동작; 상기 제 1 환경으로부터 제 2 환경으로의 변경을 요청하는 환경 변경 명령을 획득하는 동작; 상기 제 2 환경에 대응하는 베이스 디스크 이미지의 위치를 획득하는 동작; 상기 베이스 디스크 이미지를 참조하는 루트 디스크 이미지를 생성하는 동작; 및 상기 루트 디스크 이미지에 근거하여 가상 머신을 실행함으로써, 상기 제 2 환경에 근거한 제 2 화면을 표시하는 동작을 포함할 수 있다.
본 발명의 실시 예에 따르면, 가상 머신을 실행하는 전자 장치는, 상기 전자 장치의 외부에 저장되는 제 1 베이스 디스크 이미지를 참조하는 통신 인터페이스; 및 상기 제 1 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 프로세서를 포함하고, 상기 프로세서는, 상기 루트 디스크 이미지의 참조 대상을 상기 제 1 베이스 디스크 이미지로부터 상기 전자 장치의 내부에 저장되는 제 2 베이스 디스크 이미지로 변경하고, 상기 제 2 베이스 디스크 이미지를 참조하는 상기 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행할 수 있다.
본 발명의 실시 예에 따르면, 가상 머신을 실행하는 전자 장치는, 상기 전자 장치의 외부에 저장되는 제 1 베이스 디스크 이미지를 참조하는 통신 인터페이스; 상기 제 1 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 프로세서; 및 상기 제 1 베이스 디스크 이미지를 다운로드 하여, 제 2 베이스 디스크 이미지를 저장하는 메모리를 포함하고, 상기 프로세서는, 상기 다운로드가 완료되면, 상기 제 2 베이스 디스크 이미지에 근거하여 상기 가상 머신을 실행할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치는, 제 1 환경에 근거한 제 1 화면을 표시하는 디스플레이; 상기 제 1 환경으로부터 제 2 환경으로의 변경을 요청하는 환경 변경 명령을 획득하는 입출력 인터페이스; 상기 제 2 환경에 대응하는 베이스 디스크 이미지의 위치를 획득하고, 상기 베이스 디스크 이미지를 참조하는 루트 디스크 이미지를 생성하고, 상기 루트 디스크 이미지에 근거하여 가상 머신을 실행함으로써, 상기 제 2 환경에 근거한 제 2 화면을 표시하도록 제어하는 프로세서를 포함할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지를 참조하여 가상 머신을 실행하는 동작; 및 상기 제 1 베이스 디스크 이미지를, 상기 참조와 병렬적으로 다운로드하는 동작을 포함할 수 있다.
본 발명의 실시 예에 따르면, 가상 머신을 실행하는 전자 장치는, 디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지를 참조하여 가상 머신을 실행하는 프로세서; 및 상기 제 1 베이스 디스크 이미지를, 상기 참조와 병렬적으로 다운로드하는 통신 인터페이스를 포함할 수 있다.
본 발명의 다양한 실시 예들에서는, 전자 장치가 외부에 저장된 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 가상 머신을 실행할 수 있다. 이에 따라, 전자 장치는, 전체 가상 디스크 이미지를 다운로드하지 않으면서도, 원격의 베이스 디스크 이미지를 참조함으로써 가상 머신을 실행할 수 있다. 이에 따라, 베이스 디스크 이미지의 다운로드에 소요되는 시간을 대기할 필요없이 가상 머신이 실행될 수 있다.
본 발명의 다양한 실시 예들에서는, 전자 장치가 루트 디스크 이미지에 근거하여 가상 머신을 실행하면서, 병렬적으로 베이스 디스크 이미지를 다운로드받을 수 있다. 다운로드가 종료되면, 전자 장치는 루트 디스크 이미지의 참조 대상을 원격의 베이스 디스크 이미지로부터 내부에 다운로드된 베이스 디스크 이미지로 변경할 수 있다. 전자 장치는, 다운로드된 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 가상 머신을 실행할 수 있다. 이에 따라, 안정적인 베이스 디스크 이미지 변경이 가능할 수 있다.
도 1a는 본 발명의 다양한 실시예에 따른 전자 장치 및 디스크 이미지 저장소의 블록도를 도시한다.
도 1b는 본 발명의 다양한 실시예에 따른 전자 장치 및 시스템의 블록도를 도시한다.
도 2는 본 발명의 다양한 실시예에 따른 가상 머신의 계층을 설명하기 위한 개념도를 도시한다.
도 3은 본 발명의 다양한 실시예에 따른 참조(backing) 과정을 설명하기 위한 개념도이다.
도 4는 본 발명의 다양한 실시예에 따른 가상 머신을 실행하는 방법의 흐름도를 도시한다.
도 5는 본 발명의 다양한 실시예에 따른 가상 머신 생성 방법을 설명하기 위한 개념도를 도시한다..
도 6은 본 발명의 다양한 실시예에 따른 가상 머신 실행 방법의 흐름도를 도시한다.
도 7a 내지 7c는 본 발명의 다양한 실시예에 따른 가상 머신 생성 방법을 설명하기 위한 개념도를 도시한다.
도 8은 본 발명의 다양한 실시예에 따른 백킹 파일의 변경 방법을 설명하는 흐름도를 도시한다.
도 9는 백킹 파일의 변경을 설명하기 위한 개념도를 도시한다.
도 10은 본 발명의 다양한 실시예에 의한 서버에서의 가상 머신 실행을 설명하기 위한 개념도를 도시한다.
도 11은 본 발명의 다양한 실시예에 따른 스트리밍 서비스 생성을 설명하는 개념도를 도시한다.
도 12는 본 발명의 다양한 실시예에 따른 단말 장치에서의 가상 머신의 실행을 설명하기 위한 개념도를 도시한다.
도 13a 내지 13e는 본 발명의 다양한 실시예에 따른 전자 장치의 화면 구성을 설명하는 개념도를 도시한다.
도 14는 본 발명의 다양한 실시예에 따른 전자 장치의 제어 방법을 설명하는 흐름도를 도시한다.
도 15는 본 발명의 다양한 실시예에 따른 가상 머신 실행 과정을 설명하기 위한 개념도이다.
도 16a 및 16b는 본 발명의 다양한 실시예에 따른 가상 머신 실행 과정을 설명하기 위한 흐름도를 도시한다.
도 17은 본 발명의 다양한 실시예에 따른 가상 머신 실행 과정을 설명하기 위한 개념도를 도시한다.
도 18은 본 발명의 다양한 실시예에 따른 가상 머신 실행 방법의 흐름도를 도시한다.
도 19는 본 발명의 다양한 실시예에 따른 전자 장치의 블록도이다.
이하, 본 개시의 다양한 실시예가 첨부된 도면을 참조하여 기재된다. 그러나, 이는 본 개시를 특정한 실시 형태에 대해 한정하려는 것이 아니며, 본 개시의 실시예의 다양한 변경(modification), 균등물(equivalent), 및/또는 대체물(alternative)을 포함하는 것으로 이해되어야 한다. 도면의 설명과 관련하여, 유사한 구성요소에 대해서는 유사한 참조 부호가 사용될 수 있다.
본 문서에서, “가진다,” “가질 수 있다,”“포함한다,” 또는 “포함할 수 있다” 등의 표현은 해당 특징(예: 수치, 기능, 동작, 또는 부품 등의 구성요소)의 존재를 가리키며, 추가적인 특징의 존재를 배제하지 않는다.
본 문서에서, “A 또는 B,”“A 또는/및 B 중 적어도 하나,”또는 “A 또는/및 B 중 하나 또는 그 이상”등의 표현은 함께 나열된 항목들의 모든 가능한 조합을 포함할 수 있다. 예를 들면, “A 또는 B,” “ A 및 B 중 적어도 하나,”또는 “ A 또는 B 중 적어도 하나”는,(1) 적어도 하나의 A를 포함,(2) 적어도 하나의 B를 포함, 또는(3) 적어도 하나의 A 및 적어도 하나의 B 모두를 포함하는 경우를 모두 지칭할 수 있다.
다양한 실시예에서 사용된 “제 1,”“제 2,”“첫째,”또는“둘째,”등의 표현들은 다양한 구성요소들을, 순서 및/또는 중요도에 상관없이 수식할 수 있고, 해당 구성요소들을 한정하지 않는다. 상기 표현들은 한 구성요소를 다른 구성요소와 구분하기 위해 사용될 수 있다. 예를 들면, 제 1 사용자 기기와 제 2 사용자 기기는, 순서 또는 중요도와 무관하게, 서로 다른 사용자 기기를 나타낼 수 있다. 예를 들면, 본 개시의 권리 범위를 벗어나지 않으면서 제 1 구성요소는 제 2 구성요소로 명명될 수 있고, 유사하게 제 2 구성요소도 제 1 구성요소로 바꾸어 명명될 수 있다.
어떤 구성요소(예: 제 1 구성요소)가 다른 구성요소(예: 제 2 구성요소)에 "(기능적으로 또는 통신적으로) 연결되어((operatively or communicatively) coupled with/to)" 있다거나 "접속되어(connected to)" 있다고 언급된 때에는, 상기 어떤 구성요소가 상기 다른 구성요소에 직접적으로 연결되거나, 다른 구성요소(예: 제 3 구성요소)를 통하여 연결될 수 있다고 이해되어야 할 것이다. 반면에, 어떤 구성요소(예: 제 1 구성요소)가 다른 구성요소(예: 제 2 구성요소)에 "직접 연결되어" 있다거나 "직접 접속되어" 있다고 언급된 때에는, 상기 어떤 구성요소와 상기 다른 구성요소 사이에 다른 구성요소(예: 제 3 구성요소)가 존재하지 않는 것으로 이해될 수 있다.
본 문서에서 사용된 표현 “~하도록 구성된(또는 설정된)(configured to)”은 상황에 따라, 예를 들면, “~에 적합한(suitable for),” “~하는 능력을 가지는(having the capacity to),” “~하도록 설계된(designed to),” “~하도록 변경된(adapted to),” “~하도록 만들어진(made to),”또는 “~를 할 수 있는(capable of)”과 바꾸어 사용될 수 있다. 용어 “~하도록 구성(또는 설정)된”은 하드웨어적으로 “특별히 설계된(specifically designed to)”것만을 반드시 의미하지 않을 수 있다. 대신, 어떤 상황에서는, “~하도록 구성된 장치”라는 표현은, 그 장치가 다른 장치 또는 부품들과 함께 “~할 수 있는” 것을 의미할 수 있다. 예를 들면, 문구 “A, B, 및 C를 수행하도록 구성(또는 설정)된 프로세서”는 해당 동작을 수행하기 위한 전용 프로세서(예: 임베디드 프로세서), 또는 메모리 장치에 저장된 하나 이상의 소프트웨어 프로그램들을 실행함으로써, 해당 동작들을 수행할 수 있는 범용 프로세서(generic-purpose processor)(예: CPU 또는 application processor)를 의미할 수 있다.
본 문서에서 사용된 용어들은 단지 특정한 실시예를 설명하기 위해 사용된 것으로, 다른 실시예의 범위를 한정하려는 의도가 아닐 수 있다. 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함할 수 있다. 기술적이거나 과학적인 용어를 포함해서 여기서 사용되는 모든 용어들은 본 개시의 기술 분야에서 통상의 지식을 가진 자에 의해 일반적으로 이해되는 것과 동일한 의미를 가질 수 있다. 일반적으로 사용되는 사전에 정의된 용어들은 관련 기술의 문맥 상 가지는 의미와 동일 또는 유사한 의미를 가지는 것으로 해석될 수 있으며, 본 문서에서 명백하게 정의되지 않는 한, 이상적이거나 과도하게 형식적인 의미로 해석되지 않는다. 경우에 따라서, 본 문서에서 정의된 용어일지라도 본 개시의 실시예들을 배제하도록 해석될 수 없다.
본 개시의 다양한 실시예들에 따른 전자 장치는, 예를 들면, 전자 장치는 스마트폰(smartphone), 태블릿 PC(tablet personal computer), 이동 전화기(mobile phone), 화상 전화기, 전자북 리더기(e-book reader), 데스크탑 PC(desktop personal computer), 랩탑 PC(laptop personal computer), 넷북 컴퓨터(netbook computer), 워크스테이션(workstation), 서버, PDA(personal digital assistant), PMP(portable multimedia player), MP3 플레이어, 모바일 의료기기, 카메라(camera), 또는 웨어러블 장치(wearable device)(예: 스마트 안경, 머리 착용형 장치(head-mounted-device(HMD)), 전자 의복, 전자 팔찌, 전자 목걸이, 전자 앱세서리(appcessory), 전자 문신, 스마트 미러, 또는 스마트 와치(smart watch))중 적어도 하나를 포함할 수 있다.
어떤 실시예들에서, 전자 장치는 스마트 가전 제품(smart home appliance)일 수 있다. 스마트 가전 제품은, 예를 들면, 텔레비전, DVD(digital video disk) 플레이어, 오디오, 냉장고, 에어컨, 청소기, 오븐, 전자레인지, 세탁기, 공기 청정기, 셋톱 박스(set-top box), 홈 오토매이션 컨트롤 패널(home automation control panel), 보안 컨트롤 패널(security control panel), TV 박스(예: 삼성 HomeSync™, 애플TV™, 또는 구글 TV™), 게임 콘솔(예: Xbox™, PlayStation™), 전자 사전, 전자 키, 캠코더(camcorder), 또는 전자 액자 중 적어도 하나를 포함할 수 있다.
다른 실시예에서, 전자 장치는, 각종 의료기기(예: 각종 휴대용 의료측정기기(혈당 측정기, 심박 측정기, 혈압 측정기, 또는 체온 측정기 등), MRA(magnetic resonance angiography), MRI(magnetic resonance imaging), CT(computed tomography), 촬영기, 또는 초음파기 등), 네비게이션(navigation) 장치, GPS 수신기(global positioning system receiver), EDR(event data recorder), FDR(flight data recorder), 자동차 인포테인먼트(infotainment) 장치, 선박용 전자 장비(예: 선박용 항법 장치, 자이로 콤파스 등), 항공 전자기기(avionics), 보안 기기, 차량용 헤드 유닛(head unit), 산업용 또는 가정용 로봇, 금융 기관의 ATM(automatic teller’s machine), 상점의 POS(point of sales), 또는 사물 인터넷 장치(internet of things)(예: 전구, 각종 센서, 전기 또는 가스 미터기, 스프링클러 장치, 화재경보기, 온도조절기(thermostat), 가로등, 토스터(toaster), 운동기구, 온수탱크, 히터, 보일러 등) 중 적어도 하나를 포함할 수 있다.
어떤 실시예에 따르면, 전자 장치는 가구(furniture) 또는 건물/구조물의 일부, 전자 보드(electronic board), 전자 사인 수신 장치(electronic signature receiving device), 프로젝터(projector), 또는 각종 계측 기기(예: 수도, 전기, 가스, 또는 전파 계측 기기 등) 중 적어도 하나를 포함할 수 있다. 다양한 실시예에서, 전자 장치는 전술한 다양한 장치들 중 하나 또는 그 이상의 조합일 수 있다. 어떤 실시예에 따른 전자 장치는 플렉서블 전자 장치일 수 있다. 또한, 본 개시의 실시예에 따른 전자 장치는 전술한 기기들에 한정되지 않으며, 기술 발전에 따른 새로운 전자 장치를 포함할 수 있다.
이하, 첨부 도면을 참조하여, 다양한 실시예에 따른 전자 장치가 설명된다. 본 문서에서, 사용자라는 용어는 전자 장치를 사용하는 사람 또는 전자 장치를 사용하는 장치(예: 인공지능 전자 장치)를 지칭할 수 있다.
도 1a는 본 발명의 다양한 실시예에 따른 전자 장치 및 디스크 이미지 저장소의 블록도를 도시한다.
도 1a에 도시된 바와 같이, 전자 장치(101)는 프로세서(120), 메모리(130) 및 통신 인터페이스(170)를 포함할 수 있다. 디스크 이미지 저장소(190)는 통신 인터페이스(191) 및 메모리(192)를 포함할 수 있다.
하나의 실시예에서, 프로세서(120)는 가상 머신을 실행할 수 있다. 예를 들어, 프로세서(120)는 전자 장치(101) 내의 적어도 하나의 하드웨어에 대한 자원 분배를 통하여, 적어도 하나의 하드웨어가 적어도 하나의 가상 머신에 의하여 동작하도록 제어할 수 있다. 프로세서(120)는 적어도 하나의 하드웨어 각각이 독립적으로 적어도 하나의 하드웨어를 이용하도록 자원 분배를 제어할 수 있다. 이에 따라, 가상 머신 각각은 서로에 대하여 독립적으로 동작할 수 있다.
가상 머신은 가상의 CPU 및 가상의 메모리를 포함할 수 있다. 아울러, 가상 머신은 디스크 이미지를 이용하여 실행될 수 있다. 가상 디스크 이미지는, 파일로서 DAS(direct Attached Storage) 또는 NAS(Network Attached Storage) 형식으로 붙은 로컬 디스크의 파일 시스템에 존재하는 하나의 파일일 수 있다.
하나의 실시예에서, 프로세서(120)는 메모리(130)에 저장된 디스크 이미지에 근거하여 가상 머신을 실행할 수 있다. 여기에서, 디스크 이미지는, 예를 들어 특정 OS(operating system) 및 적어도 하나의 어플리케이션을 포함하는 컴퓨터 파일일 수 있다. 디스크 이미지는, 상술한 특정 OS 및 적어도 하나의 어플리케이션을 섹터별(sector-by-sector) 카피에 근거하여 생성될 수 있다. 프로세서(120)는 가상 머신상의 어플리케이션 또는 OS에 의하여 생성되는 데이터 입출력을 디스크 이미지를 이용하여 처리할 수 있다.
하나의 실시예에서, 메모리(130)는 디스크 이미지를 저장할 수 있다.
하나의 실시예에서, 메모리(130)는 루트 디스크 이미지(root disk image)를 저장할 수 있다. 루트 디스크 이미지는 베이스 디스크 이미지(base disk image)를 참조(backing)하는 디스크 이미지일 수 있다. 프로세서(120)는 메모리(130)에 저장된 루트 디스크 이미지에 근거하여 가상 머신을 실행할 수 있다. 프로세서(120)는 가상 머신상의 어플리케이션 또는 OS에 의하여 생성되는 데이터 입출력을 루트 디스크 이미지를 이용하여 처리할 수 있다. 프로세서(120)가 가상 머신상의 어플리케이션 또는 OS에 의하여 생성되는 데이터 입출력을 루트 디스크 이미지를 이용하여 처리할 수 없는 경우에는, 프로세서(120)는 루트 디스크 이미지가 참조하는 베이스 디스크 이미지를 이용하여 데이터 입출력을 처리할 수 있다.
하나의 실시예에서, 통신 인터페이스(170)는 디스크 이미지 저장소(190)의 통신 인터페이스(191)와 통신 연결을 형성할 수 있다. 상술한 바와 같이, 프로세서(120)가 가상 머신상의 어플리케이션 또는 OS에 의하여 생성되는 데이터 입출력을 루트 디스크 이미지를 이용하여 처리할 수 없는 경우에는, 통신 인터페이스(170)는 처리되지 못한 데이터 입출력을 디스크 이미지 저장소의 통신 인터페이스(191)로 송신할 수 있다. 통신 인터페이스(170)는 통신 인터페이스(191)로부터 데이터 입출력에 대응하는 처리 결과를 수신하여 프로세서(120)로 전달할 수 있다. 처리 결과는 베이스 디스크 이미지에 근거하여 생성될 수 있다. 상술한 바와 같이, 프로세서(120)는 루트 디스크 이미지 또는 루트 디스크 이미지가 참조하는 베이스 디스크 이미지를 이용하여 가상 머신상의 어플리케이션 또는 OS에 의하여 생성되는 데이터 입출력을 처리할 수 있다.
하나의 실시예에서, 루트 디스크 이미지는 쓰기(write) 전용 디스크 이미지이며, 베이스 디스크 이미지는 읽기(read) 전용 디스크 이미지일 수 있다. 이러한 실시예에서, 쓰기(write) 데이터가 입력된 경우에는, 프로세서(120)는 루트 디스크 이미지를 이용하여 데이터 입출력을 처리할 수 있다. 한편, 읽기(read) 데이터가 입력된 경우에는, 프로세서(120)는 루트 디스크 이미지로 처리할 수 없고, 베이스 디스크 이미지를 이용하여 데이터 입출력을 처리할 수 있다.
한편, 다른 실시예에서는, 루트 디스크 이미지는, 쓰기/읽기가 모두 가능한 디스크 이미지일 수도 있다. 이러한 실시예에서, 읽기 데이터가 입력된 경우에는, 프로세서(120)는 우선적으로 루트 디스크 이미지를 이용하여 읽기 데이터를 처리가능한지를 판단할 수 있다. 만약, 루트 디스크 이미지에 해당 읽기 데이터가 없는 경우에는, 프로세서(120)는 베이스 디스크 이미지를 이용하여 해당 읽기 데이터를 처리할 수 있다.
하나의 실시예에서, 통신 인터페이스(170)는 디스크 이미지 저장소(190)로부터 베이스 디스크 이미지를 수신할 수 있다. 통신 인터페이스(170)는 상술한 데이터 입출력 또는 데이터 입출력에 대응하는 처리 결과의 송수신과 병렬적으로 디스크 이미지 저장소(190)로부터 베이스 디스크 이미지를 수신할 수 있다. 통신 인터페이스(170)는 수신된 베이스 디스크 이미지를 메모리(130)에 저장할 수 있다. 식별의 용이성을 위하여, 메모리(130) 내의 루트 디스크 이미지가 참조하는 디스크 이미지 저장소(190)의 메모리(192)에 저장되는 베이스 디스크 이미지를 제 1 베이스 디스크 이미지라 명명할 수 있다. 아울러, 통신 인터페이스(170)를 통하여 다운로드되어 메모리(130)에 저장되는 베이스 디스크 이미지를 제 2 베이스 디스크 이미지라 명명할 수 있다.
하나의 실시예에서, 프로세서(120)는 베이스 디스크 이미지의 다운로드가 완료되면, 루트 디스크 이미지가 제 2 베이스 디스크 이미지를 참조하도록 할 수 있다. 더욱 상세하게, 프로세서(120)는 데이터 입출력을 수행하는 오브젝트를 제 1 베이스 디스크 이미지에 대응하는 제 1 오브젝트로부터 제 2 베이스 디스크 이미지에 대응하는 제 2 오브젝트로 변경할 수 있다. 예를 들어, 프로세서(120)는, 제 1 오브젝트로부터의 데이터 입출력을 중단하고, 제 2 오브젝트로의 변경이 완료되면, 제 2 오브젝트로부터의 데이터 입출력을 개시할 수 있다.
또 다른 실시예에서, 프로세서(120)는 베이스 디스크 이미지의 다운로드가 완료되면, 프로세서(120)는 루트 디스크 이미지와 제 2 베이스 디스크 이미지를 머지(merge)한 머지드 디스크 이미지(merged disk image)에 근거하여 가상 머신을 실행할 수 있다. 더욱 상세하게, 프로세서(120)는 참조(backing) 과정을 이용하지 않고, 머지드 디스크 이미지를 직접 이용하여 가상 머신을 실행할 수 있다. 프로세서(120)는 메모리(130)에서 머지(merge) 과정 이후에, 머지 과정에 이용된 제 2 베이스 디스크 이미지를 삭제할 수도 있다.
하나의 실시예에서, 다운로드가 완료되면, 통신 인터페이스(170)는 디스크 이미지 저장소(190)와의 연결을 해제할 수 있다.
하나의 실시예에서, 프로세서(120)는, 제 1 베이스 디스크 이미지의 URL을 획득하여, 획득된 URL에 근거하여 제 1 베이스 디스크 이미지를 참조하도록 제어할 수 있다.
한편, 메모리(192)는 적어도 하나의 베이스 디스크 이미지를 저장할 수 있다.
통신 인터페이스(191)는, 전자 장치(101)로부터 제 1 베이스 디스크 이미지에 대한 다운로드 요청을 수신할 수 있다. 통신 인터페이스(191)는 메모리(192)에 저장된 제 1 베이스 디스크 이미지를 통신 인터페이스(170)로 송신할 수 있다.
하나의 실시예에서, 통신 인터페이스(191)는 전자 장치(101)에 저장된 루트 디스크 이미지의 참조(backing) 관련 데이터를 통신 인터페이스(170)로부터 수신할 수 있다. 통신 인터페이스(191)는 참조 관련 데이터에 대응하는 처리 결과를 통신 인터페이스(170)로 송신할 수 있다.
도 1b를 참조하여, 다양한 실시예에서의, 네트워크 환경(100) 내의 전자 장치(101)가 개시된다. 상기 전자 장치(101)는 버스(110), 프로세서(120), 메모리(130), 입출력 인터페이스(150), 디스플레이(160), 통신 인터페이스(170) 및 가상 머신 모듈(180)을 포함할 수 있다. 어떤 실시예에서는, 전자 장치(101)는, 상기 구성요소들 중 적어도 하나를 생략하거나 다른 구성 요소를 추가적으로 구비할 수 있다. 도 1b는 예를 들어, 전자 장치(101)가 단말 장치로 구현된 경우에 대한 것일 수 있다. 한편, 더욱 상세하게 후술할 것으로 전자 장치(101)는 단말 장치 이외에도 데이터 센터 또는 텔레커뮤니케이션 서버와 같은 서버 장치로 구현될 수도 있다.
상기 버스(110)는, 예를 들면, 상기 구성 요소들(120~180)을 서로 연결하고, 상기 구성요소들 간의 통신(예: 제어 메시지 및/또는 데이터)을 전달하는 회로를 포함할 수 있다.
상기 프로세서(120)는, 중앙처리장치(central processing unit(CPU)), 어플리케이션 프로세서(application processor(AP)), 또는 커뮤니케이션 프로세서(communication processor(CP)) 중 하나 또는 그 이상을 포함할 수 있다. 상기 프로세서(120)은, 예를 들면, 상기 전자 장치(101)의 적어도 하나의 다른 구성요소들의 제어 및/또는 통신에 관한 연산이나 데이터 처리를 실행할 수 있다. 상기 프로세서(120)는 제어부(controller)라고 칭하거나, 상기 제어부를 그 일부로서 포함할 수도 있다.
상기 메모리(130)는, 휘발성 및/또는 비휘발성 메모리를 포함할 수 있다. 상기 메모리(130)는, 예를 들면, 상기 전자 장치(101)의 적어도 하나의 다른 구성요소에 관계된 명령 또는 데이터를 저장할 수 있다. 한 실시예에 따르면, 상기 메모리(130)는 소프트웨어 및/또는 프로그램(140)을 저장할 수 있다. 상기 프로그램(140)은, 예를 들면, 커널(141), 미들웨어(143), 어플리케이션 프로그래밍 인터페이스(application programming interface(API))(145), 및/또는 어플리케이션 프로그램(147)(또는 “어플리케이션”) 등을 포함할 수 있다. 상기 커널(141), 미들웨어(143), 또는 API(145)의 적어도 일부는, 운영 시스템(operating system(OS))라 불릴 수 있다.
상기 커널(141)은, 예를 들면, 다른 프로그램들(예: 미들웨어(143), API(145), 또는 어플리케이션 프로그램(147))에 구현된 동작 또는 기능을 실행하는 데 사용되는 시스템 리소스들(예: 버스(110), 프로세서(120), 또는 메모리(130) 등)을 제어 또는 관리할 수 있다. 또한, 상기 커널(141)은 상기 미들웨어(143), 상기 API(145), 또는 상기 어플리케이션 프로그램(147)에서 상기 전자 장치(101)의 개별 구성요소에 접근함으로써, 시스템 리소스들을 제어 또는 관리할 수 있는 인터페이스를 제공할 수 있다.
상기 미들웨어(143)는, 예를 들면, 상기 API(145) 또는 상기 어플리케이션 프로그램(147)이 상기 커널(141)과 통신하여 데이터를 주고받을 수 있도록 중개 역할을 수행할 수 있다. 또한, 상기 미들웨어(143)는 상기 어플리케이션 프로그램(147)로부터 수신된 작업 요청들과 관련하여, 예를 들면, 상기 어플리케이션 프로그램(147) 중 적어도 하나의 어플리케이션에 상기 전자 장치(101)의 시스템 리소스(예: 버스(110), 프로세서(120), 또는 메모리(130) 등)를 사용할 수 있는 우선 순위를 배정하는 등의 방법을 이용하여 작업 요청에 대한 제어(예: 스케쥴링 또는 로드 밸런싱)을 수행할 수 있다.
상기 API(145)는, 예를 들면, 상기 어플리케이션(147)이 상기 커널(141) 또는 상기 미들웨어(143)에서 제공되는 기능을 제어하기 위한 인터페이스로, 예를 들면, 파일 제어, 창 제어, 화상 처리, 또는 문자 제어 등을 위한 적어도 하나의 인터페이스 또는 함수(예: 명령어)를 포함할 수 있다.
본 명세서에서, 어플리케이션은 어플리케이션 프로그램이라고 칭할 수도 있다.
상기 입출력 인터페이스(150)은, 예를 들면, 사용자 또는 다른 외부 기기로부터 입력된 명령 또는 데이터를 상기 전자 장치(101)의 다른 구성요소(들)에 전달할 수 있는 인터페이스의 역할을 할 수 있다. 또한, 상기 입출력 인터페이스(150)은 상기 전자 장치(101)의 다른 구성요소(들)로부터 수신된 명령 또는 데이터를 사용자 또는 다른 외부 기기로 출력할 수 있다.
상기 디스플레이(160)는, 예를 들면, 액정 디스플레이(LCD), 발광 다이오드(LED) 디스플레이, 유기 발광 다이오드(OLED) 디스플레이, 또는 마이크로 전자기계 시스템(microelectromechanical systems(MEMS)) 디스플레이, 또는 전자종이(electronic paper) 디스플레이를 포함할 수 있다. 상기 디스플레이(160)은, 예를 들면, 사용자에게 각종 콘텐츠(예: 텍스트, 이미지, 비디오, 아이콘, 또는 심볼 등)을 표시할 수 있다. 상기 디스플레이(160)는, 터치 스크린을 포함할 수 있으며, 예를 들면, 전자 펜 또는 사용자의 신체의 일부를 이용한 터치, 제스쳐, 근접, 또는 호버링 입력을 수신할 수 있다.
상기 통신 인터페이스(170)은, 예를 들면, 상기 전자 장치(101)와 외부 장치(예: 제 1 외부 전자 장치(102), 제 2 외부 디스크 이미지 저장소(104), 또는 서버(106)) 간의 통신을 설정할 수 있다. 예를 들면, 상기 통신 인터페이스(170)은 무선 통신 또는 유선 통신을 통해서 네트워크(162)에 연결되어 상기 외부 장치(예: 제 2 외부 디스크 이미지 저장소(104) 또는 서버(106))와 통신할 수 있다.
상기 무선 통신은, 예를 들면, 셀룰러 통신 프로토콜로서, 예를 들면, LTE, LTE-A, CDMA, WCDMA, UMTS, WiBro, 또는 GSM 등 중 적어도 하나를 사용할 수 있다. 상기 유선 통신은, 예를 들면, USB(universal serial bus), HDMI(high definition multimedia interface), RS-232(recommended standard 232), 또는 POTS(plain old telephone service) 등 중 적어도 하나를 포함할 수 있다. 상기 네트워크 162는 통신 네트워크(telecommunications network), 예를 들면, 컴퓨터 네트워크(computer network)(예: LAN 또는 WAN), 인터넷, 또는 전화 망(telephone network) 중 적어도 하나를 포함할 수 있다.
상기 제 1 및 제 2 외부 전자 장치(102, 104) 각각은 상기 전자 장치(101)와 동일한 또는 다른 종류의 장치일 수 있다. 한 실시예에 따르면, 상기 서버(106)는 하나 또는 그 이상의 서버들의 그룹을 포함할 수 있다. 다양한 실시예에 따르면, 상기 전자 장치(101)에서 실행되는 동작들의 전부 또는 일부는 다른 하나 또는 복수의 전자 장치(예: 전자 장치(102, 104), 또는 서버(106))에서 실행될 수 있다. 한 실시예에 따르면, 상기 전자 장치(101)가 어떤 기능이나 서비스를 자동으로 또는 요청에 의하여 수행해야 할 경우에, 상기 전자 장치(101)는 상기 기능 또는 상기 서비스를 자체적으로 실행시키는 대신에 또는 추가적으로, 그와 연관된 적어도 일부 기능을 다른 장치(예: 전자 장치(102, 104), 또는 서버(106))에게 요청할 수 있다. 상기 다른 전자 장치(예: 전자 장치(102, 104), 또는 서버(106))는 상기 요청된 기능 또는 추가 기능을 실행하고, 그 결과를 상기 전자 장치(101)로 전달할 수 있다. 상기 전자 장치(101)는 수신된 결과를 그대로 또는 추가적으로 처리하여 상기 요청된 기능이나 서비스를 제공할 수 있다. 이를 위하여, 예를 들면, 클라우드 컴퓨팅, 분산 컴퓨팅, 또는 클라이언트-서버 컴퓨팅 기술이 이용될 수 있다.
한 실시예에 따르면, 상기 가상 머신 모듈(180)은 상기 전자 장치(101)에서 구현되는 동작(또는, 기능)들 중 적어도 하나의 동작을 수행함으로써, 상기 전자 장치(101)의 구동을 지원할 수 있다. 예를 들면, 상기 서버(106)는 상기 전자 장치(101)에 구현된 가상 머신 모듈(180)을 지원할 수 있는 가상 머신 서버 모듈(미도시)을 포함할 수 있다. 예컨대, 상기 가상 머신 서버 모듈(미도시)은 가상 머신 모듈(180)의 적어도 하나의 구성 요소를 포함하여, 가상 머신 모듈(180)이 수행하는 동작들 중 적어도 하나의 동작을 수행(예: 대행)할 수 있다.
상기 가상 머신 모듈(180)은 다른 구성요소들(예: 상기 프로세서(120), 상기 메모리(130), 상기 입출력 인터페이스(150), 상기 통신 인터페이스(170) 등의 적어도 하나)로부터 획득된 정보 중 적어도 일부를 처리하고, 이를 다양한 방법으로 이용할 수 있다. 예를 들면, 상기 가상 머신 모듈(180)은 상기 프로세서(120)를 이용하여 또는 이와는 독립적으로, 상기 전자 장치(101)가 다른 전자 장치(예: 전자 장치(102, 104) 또는 서버(106))와 연동하도록 상기 전자 장치(101)의 적어도 일부 기능을 제어할 수 있다. 상기 가상 머신 모듈(180)은 상기 프로세서(120) 또는 상기 통신 인터페이스(170)에 통합될 수 있다. 한 실시예에 따르면, 가상 머신 모듈(180)의 적어도 하나의 구성은 상기 서버(106)에 포함될 수 있으며, 상기 서버(106)로부터 가상 머신 모듈(180)에서 구현되는 적어도 하나의 동작을 지원받을 수 있다.
도 2는 본 발명의 다양한 실시예에 따른 가상 머신의 계층을 설명하기 위한 개념도를 도시한다.
도 2는, 예를 들어 전자 장치(101)의 데이터 처리 계층을 나타낼 수 있다. 하드웨어 계층(210) 상에는 하이퍼바이저(hypervisor) 계층(220)이 정의될 수 있다. 구현에 따라서, 하이퍼바이저는, 가상 머신 모니터(VMM:virtual machine monitor)로 명명될 수도 있다. 하이퍼바이저는, 가상 머신을 생성하고 실행하는 펌웨어 또는 소프트웨어를 지칭할 수 있다.
하이퍼바이저 계층(220) 상에는 적어도 하나의 가상 머신(230,240)이 실행될 수 있다. 제 1 가상 머신(230)은 제 1 운영 체제 계층(231) 및 제 1 어플리케이션 계층(232)을 포함할 수 있다. 제 2 가상 머신(240)은 제 2 운영 체제 계층(241) 및 제 2 어플리케이션 계층(242)을 포함할 수 있다. 여기에서, 제 1 운영 체제 계층(231) 및 제 2 운영 체제 계층(241)은 서로에 대하여 독립적일 수 있다.
하이퍼바이저 계층(220)은 하드 웨어 계층(210)의 자원을 제 1 가상 머신(230) 및 제 2 가상 머신(240)에게 분배할 수 있다. 하이퍼바이저 계층(220)은 제 1 가상 머신(230)으로부터의 데이터 입출력에 대한 하드 웨어 계층(210)의 자원 분배 및 제 2 가상 머신(240)으로부터의 데이터 입출력에 대한 하드 웨어 계층(210)의 자원 분배를 수행할 수 있다. 하이퍼바이저 계층(220)은 제 1 가상 머신(230) 및 제 2 가상 머신(240)이 서로에 대하여 독립적으로 동작할 수 있도록, 자원 분배를 수행할 수 있다.
하이퍼바이저 계층(220)은 디스크 이미지(250)를 이용하여 제 1 가상 머신(230) 및 제 2 가상 머신(240)으로부터의 데이터 입출력을 처리할 수 있다. 한편, 도 2에서는 제 1 가상 머신(230) 및 제 2 가상 머신(240)이 동일한 디스크 이미지(250)에 대응되는 것과 같이 도시되어 있지만, 이는 단순히 예시적인 것으로, 각각의 가상 머신에 대응하는 상이한 디스크 이미지가 존재할 수도 있다.
도 3은 본 발명의 다양한 실시예에 따른 참조(backing) 과정을 설명하기 위한 개념도이다.
도 3에 도시된 바와 같이, 제 1 가상 머신(331) 및 제 2 가상 머신(332)은 각각 제 1 루트 디스크 이미지(321) 및 제 2 루트 디스크 이미지(322)를 이용하여 실행될 수 있다.
하나의 실시예에서, 루트 디스크 이미지는 쓰기(write) 전용 디스크 이미지일 수 있다. 예를 들어, 제 1 가상 머신(331)으로부터 제 1 쓰기 데이터가 출력된 경우, 하이퍼바이저는 루트 디스크 이미지에 제 1 쓰기 데이터가 저장되도록 제어할 수 있다. 다른 실시예에서, 루트 디스크 이미지는, 읽기/쓰기가 모두 가능한 디스크 이미지일 수도 있다.
제 1 루트 디스크 이미지(321)는 베이스 디스크 이미지(310)를 참조할 수 있다. 예를 들어, 베이스 디스크 이미지(310)는 읽기 전용 디스크 이미지일 수 있다. 읽기 데이터가 입력되면, 하이퍼바이저는 베이스 디스크 이미지(310)를 이용하여 읽기 데이터를 처리할 수 있다. 한편, 루트 디스크 이미지가 읽기/쓰기가 모두 가능한 디스크 이미지인 경우에는, 하이퍼바이저는 우선 루트 디스크 이미지를 이용하여 입력된 읽기 데이터를 처리할 수 있는지를 판단할 수 있다. 처리가 불가능한 경우에는, 하이퍼바이저는 읽기 데이터를 베이스 디스크 이미지(310)를 이용하여 처리할 수 있다.
한편, 도 3의 실시예에서, 제 1 루트 디스크 이미지(321) 및 제 2 루트 디스크 이미지(322)가 모두 하나의 베이스 디스크 이미지(310)를 참조하는 것과 같이 도시되어 있지만, 이는 단순히 예시적인 것이다. 다른 실시예에서는, 제 1 루트 디스크 이미지(321) 및 제 2 루트 디스크 이미지(322)가 서로 상이한 베이스 디스크 이미지를 참조할 수도 있다.
한편, 베이스 디스크 이미지(310)는 제 1 루트 디스크 이미지(321) 및 제 2 루트 디스크 이미지(322)와 동일한 하드웨어에 저장될 수 있다. 또 다른 실시예에서는, 베이스 디스크 이미지(310)가 제 1 루트 디스크 이미지(321) 및 제 2 루트 디스크 이미지(322) 저장된 하드웨어와 별개의 원격에 배치된 하드웨어에 저장되어, 네트워크를 통하여 참조 과정이 수행될 수도 있다.
도 4는 본 발명의 다양한 실시예에 따른 가상 머신을 실행하는 방법의 흐름도를 도시한다. 도 4의 실시예는 도 5를 참조하여 더욱 상세하게 설명하도록 한다. 도 5는 본 발명의 다양한 실시예에 따른 가상 머신 생성 방법을 설명하기 위한 개념도를 도시한다.
410 동작에서, 전자 장치(101)는 원격의 디스크 이미지 저장소(190)에 저장된 제 1 베이스 디스크 이미지(510)의 위치를 획득할 수 있다. 하나의 실시예에서, 전자 장치(101)는 디스크 이미지 저장소(190)에 저장된 제 1 베이스 디스크 이미지(510)의 URL을 획득할 수 있다.
420 동작에서, 전자 장치(101)는 외부 전자 장치에 저장된 베이스 디스크 이미지를 참조하는 루트 디스크 이미지(520)를 생성할 수 있다.
430 동작에서, 전자 장치(101)는 생성된 루트 디스크 이미지(520)를 이용하여 가상 머신(530)을 실행할 수 있다. 하나의 실시예에서, 전자 장치(101)가 생성한 루트 디스크 이미지(520)는 쓰기 전용 디스크 이미지일 수 있으며, 외부 전자 장치에 저장된 제 1 베이스 디스크 이미지(510)는 읽기 전용 디스크 이미지일 수 있다. 전자 장치(101)는 가상 머신(530)으로부터 입력되는 쓰기 데이터를 루트 디스크 이미지(520)를 이용(540)하여 처리할 수 있다. 예를 들어, 전자 장치(101)는 가상 머신(530)으부터 입력되는 쓰기 데이터를 메모리(130)에 저장할 수 있다. 또는, 전자 장치(101)는 가상 머신(530)으로부터 입력되는 읽기 데이터를 제 1 베이스 디스크 이미지(510)를 이용(550)하여 처리할 수 있다. 예를 들어, 전자 장치(101)는 루트 디스크 이미지의 참조 정보에 근거하여, 통신 인터페이스(170,191)를 통하여 베이스 디스크 이미지로부터 읽기 데이터를 읽어올 수 있다.
또 다른 실시예에서, 루트 디스크 이미지(520)는 읽기 및 쓰기가 모두 가능한 디스크 이미지일 수도 있다. 전자 장치(101)는 가상 머신(530)으로부터 입력되는 읽기 데이터를 루트 디스크 이미지(520)를 이용하여 처리할 수 있다. 한편, 루트 디스크 이미지(520)로 읽기 데이터를 처리할 수 없으면, 전자 장치(101)는 제 1 베이스 디스크 이미지(510)를 이용하여 읽기 데이터를 처리할 수 있다.
도 6은 본 발명의 다양한 실시예에 따른 가상 머신 실행 방법의 흐름도를 도시한다. 도 6의 실시예는 도 7a 내지 7c를 참조하여 더욱 상세하게 설명하도록 한다. 도 7a 내지 7c는 본 발명의 다양한 실시예에 따른 가상 머신 생성 방법을 설명하기 위한 개념도를 도시한다.
610 동작에서, 전자 장치(101)는 가상 머신 생성 명령을 획득할 수 있다.
620 동작에서, 전자 장치(101)는 가상 머신 생성 명령에 대응하는 베이스 디스크 이미지를 저장하는 디스크 이미지 저장소로 통신 연결을 형성할 수 있다.
630 동작에서, 전자 장치(101)는 도 7a에서와 같이 제 1 베이스 디스크 이미지(510)를 참조하는 루트 디스크 이미지(520)를 생성할 수 있다. 640 동작에서, 전자 장치(101)는 루트 디스크 이미지(520)에 근거하여 가상 머신(530)을 실행할 수 있다.
650 동작에서, 전자 장치(101)는 제 1 베이스 디스크 이미지(510)를 다운로드(570)할 수 있다. 전자 장치(101)는 630 동작 및 640 동작의 가상 머신 실행 동작과 병렬적으로 제 1 베이스 디스크 이미지(510)를 다운로드(570)할 수 있다. 전자 장치(101)는 다운로드(570) 결과를 제 2 베이스 디스크 이미지(560)로 메모리(130)에 저장할 수 있다.
660 동작에서, 전자 장치(101)는 제 1 베이스 디스크 이미지(510)의 다운로드(570)가 완료되는지 여부를 판단할 수 있다. 다운로드(570)가 완료되지 않은 경우에는, 제 1 베이스 디스크 이미지(510)를 참조하는 루트 디스크 이미지(520)에 근거하여 가상 머신 실행을 유지할 수 있다.
670 동작에서, 다운로드(570)가 완료된 경우에는, 루트 디스크 이미지(520)가 참조하는 베이스 디스크 이미지를 제 1 베이스 디스크 이미지(510)로부터 다운로드가 완료된 제 2 베이스 디스크 이미지(561)로 변경할 수 있다. 도 7b에서와 같이, 루트 디스크 이미지(520)는, 전자 장치(101)의 메모리(130)에 저장된 다운로드가 완료된 제 2 베이스 디스크 이미지(561)를 참조(580)할 수 있다.
680 동작에서, 전자 장치(101)는 디스크 이미지 저장소(190)와 형성된 통신 연결을 해제할 수 있다. 도 7b에서와 같이, 통신 인터페이스(170,191) 사이의 통신 연결이 해제될 수도 있다.
한편, 또 다른 실시예에서, 다운로드(570)가 완료된 경우에는, 전자 장치(101)는 다운로드가 완료된 제 2 베이스 디스크 이미지(561)와 루트 디스크 이미지(520)를 머지(merge)하여, 머지드 디스크 이미지를 생성할 수 있다. 전자 장치(101)는 머지드 디스크 이미지에 근거하여 가상 머신을 실행할 수도 있다. 한편, 전자 장치(101)는 머지드 디스크 이미지를 생성한 이후에, 제 2 베이스 디스크 이미지(561)를 삭제할 수 있다.
도 7c는 참조 대상의 변경을 설명하기 위한 개념도이다. 도 7c에 도시된 바와 같이, 베이스 디스크 이미지의 다운로드 이전에는, 전자 장치(101) 내에 저장된 루트 디스크 이미지(520)는 원격의 디스크 이미지 저장소(190)에 저장된 제 1 베이스 디스크 이미지(510)를 네트워크(162)를 통하여 참조할 수 있다. 전자 장치(101) 내에 저장된 루트 디스크 이미지(520)는 파일 형식으로 존재할 수 있다. 예를 들어, 루트 디스크 이미지(520)의 위치는 file://<local storage>/disk.img로 기술될 수 있다. 여기에서, <local storage>는 전자 장치(101) 내부의 메모리(130)를 의미할 수 있다. 루트 디스크 이미지(520)는 읽기/쓰기가 가능한 파일(예를 들어, disk.img)일 수 있으며, 또 다른 실시예에서는 쓰기 전용 파일일 수도 있다. 제 1 베이스 디스크 이미지(520)는 예를 들어 읽기 전용 파일(예를 들어, base.img)일 수 있다. 예를 들어, QCOW2 포맷의 루트 디스크 이미지에서는 읽기 전용의 제 1 베이스 디스크 이미지(510)를 참조 파일(backing file)이라고 명명할 수 있다. 제 1 베이스 디스크 이미지(510)의 위치는 예를 들어, nfs://<remote storage>/base.img로 기술될 수 있다.
베이스 디스크 이미지의 다운로드가 완료되면, 전자 장치(101) 내에 저장된 루트 디스크 이미지(520)는 전자 장치(101) 내에 저장된 다운로드 완료된 제 2 베이스 디스크 이미지(561)를 참조할 수 있다. 제 2 베이스 디스크 이미지(561)읽기 전용 파일(예를 들어, new_base.img)일 수 있다. 한편, 다른 실시예에서, 제 2 베이스 디스크 이미지(561)는 읽기/쓰기가 가능한 파일일 수 있다. 제 2 베이스 디스크 이미지(561)의 저장 위치는 예를 들어, file://<local storage>/new_base.img일 수 있다. 한편, 도 7c에 도시된 바와 같이, 제 2 베이스 디스크 이미지(561)는 전자 장치(101)의 내부에 저장되어 있기 때문에, 네트워크(162)의 개입없이 참조가 가능하다.
가상 디스크 기술자(515, 516)는 가상디스크의 정보를 담고 있는 객체로 베이스 디스크가 존재할 경우 베이스 디스크의 위치와 베이스 디스크와 관련된 동작(open/close/read/write 등) 및 상태를 제어한다. 하이퍼바이저(220)에 의해서 베이스 이미지가 교체가 되면 해당 루트디스크 이미지의 가상디스크 기술자(515, 565)의 내용이 변경된다. 도 9의 제1 객체에 의해서 백킹 파일의 위치가 변경될 경우, 가상디스크 기술자(515)는 가상디스크 기술자(565)로 변경되며 내부의 정보가 변경된다.
도 8은 본 발명의 다양한 실시예에 따른 백킹 파일의 변경 방법을 설명하는 흐름도를 도시한다. 도 8의 실시예는 도 9를 참조하여 더욱 상세하게 설명하도록 한다. 도 9는 백킹 파일의 변경을 설명하기 위한 개념도를 도시한다.
810 동작에서, 하이퍼바이저(220)는 기존 백킹 파일(910)의 위치를 파악할 수 있다. 백킹 파일은 루트 디스크 이미지가 참조하는 파일일 수 있다. 한편, 하이퍼바이저(220)가 수행한다는 것은, 전자 장치(101) 또는 전자 장치(101)의 프로세서(120)가 수행한다는 것과 동일할 수 있음을 당업자는 용이하게 이해할 수 있을 것이다. 한편, 도 9에 도시된 바와 같이, 하이퍼바이저(220)는 제 1 객체(object)(931) 및 제 2 객체(932)를 제어할 수 있다. 여기에서, 제 1 객체(931)는 기존 백킹 파일(910)의 데이터 입출력을 수행하고, 제 2 객체(932)는 신규 백킹 파일(920)의 데이터 입출력을 수행할 수 있다.
820 동작에서, 하이퍼바이저(220)는 신규 백킹 파일(920)을 시작할 수 있다.
830 동작에서, 하이퍼바이저(220)는 기존 백킹 파일(910)로의 데이터 입출력을 중단할 수 있다. 하이퍼바이저(220)는 제 1 객체(931)의 동작을 중단할 수 있다.
840 동작에서, 하이퍼바이저(220)는 기존 백킹 파일(910)에 대응하는 제 1 객체(931)를 신규 백킹 파일(920)에 대응하는 제 2 객체(932)로 변경할 수 있다.
850 동작에서, 하이퍼바이저(220)는 신규 백킹 파일(920)로의 데이터 입출력을 제 2 객체(932)를 통하여 수행할 수 있다.
도 10은 본 발명의 다양한 실시예에 의한 서버에서의 가상 머신 실행을 설명하기 위한 개념도를 도시한다.
도 10에 도시된 바와 같이, 디스크 이미지 저장소(1020)는 클라우드 관리 시스템(cloud management system)(1010)에 포함될 수 있다. 클라우드 관리 시스템(1010)은 클라우드 관리 계층(cloud management layer)에서 정의될 수 있다. 디스크 이미지 저장소(1020)은 적어도 하나의 베이스 디스크 이미지(1021 내지 1025)를 포함할 수 있다. 베이스 디스크 이미지(1021 내지 1025) 각각은 OS 및 어플리케이션을 포함하는 완비된 파일일 수 있으며, 예를 들어 방화벽, 캐시(cache) 서버, 라우터에 대응하는 파일일 수 있다. 클라우드 관리 시스템(cloud management system)(1010)은 통신 인프라를 포함할 수 있으며, 이에 따라 하위 단의 다른 엔티티, 예를 들어 데이터 센터(data center)(1030) 또는 텔레커뮤니케이션 인프라(Teclo infra)(1040)와 디스크 이미지 저장소(1020)의 통신 연결을 형성할 수 있다. 클라우드 관리 시스템(cloud management system)(1010)은 가상 머신을 생성할 하이퍼바이저를 선택하고, 특정 가상 디스크 이미지를 하이퍼바이저로 전달할 수 있다. 한편, 본 발명의 실시예에서, 클라우드 관리 시스템은, 하이퍼바이저로부터의 참조에 따른 데이터 입출력을 처리 및 전달할 수 있음은 상세하게 설명하였으므로, 여기에서의 더 이상의 설명은 생략하도록 한다.
클라우드 제어 계층 하단에는 가상 머신을 활용한 서비스 계층 및 가상화 계층(vitualization layer)이 정의될 수 있다. 데이터 센터(data center)(1030)에는 데이터 센터 서버가 가상화되어, 데이터 센터 하드웨어(1071), 데이터 센터 하이퍼바이저(1072), 데이터 센터 가상 머신(1073 내지 1075)가 정의될 수 있다. 텔레커뮤니케이션 인프라(Teclo infra)(1040)에는 텔레커뮤니케이션 서버가 가상화되어, 텔레커뮤니케이션 인프라 하드웨어(1051,1061), 텔레커뮤니케이션 인프라 하이퍼바이저(1052,1062), 텔레커뮤니케이션 인프라 가상 머신(1053,1054,1063,1064)가 정의될 수 있다. 예를 들어, 데이터 센터 하이퍼바이저(1072)는 디스크 이미지와 가상 CPU, 가상 메모리, 가상 네트워크를 조합하여 데이터 센터 가상 머신(1073 내지 1075)을 동작시킬 수 있다. 가상 머신(1053)은 방화벽(1041)과 관련될 수 있으며, 가상 머신(1054)는 캐시 서버(1042)와 관련될 수 있으며, 가상 머신(1063)은 라우터(1043)과 관련될 수 있으며, 가상 머신(1064)는 미디어 서버(1044)와 관련될 수 있으며, 가상 머신(1073,1074,1075)은 웹서버 및 DB 서버(1031,1032,1033)과 관련될 수 있다. 예를 들어, 데이터 센터 하이퍼바이저(1072)는 디스크 이미지와 가상 CPU, 가상 메모리, 가상 네트워크를 조합하여 데이터 센터 가상 머신(1073 내지 1075)을 동작시킬 수 있다.
가상화 계층 하단에는 물리 인프라(physical infrastructure)가 정의될 수 있다. 물리 인프라에서는, 디스크 이미지 저장소의 하드웨어(1080) 및 전자 장치(1090,1091)가 포함될 수 있다. 아울러, 물리 인프라는, 데이터 송수신을 위한 인터넷(1081), 라우터(1082,1083,1084,1085,1087), AP(access point)(1088,1089) 및 백본(back bone) 네트워크(1092)를 포함할 수 있다. 전자 장치(1090,1091)는 디스크 이미지 저장소의 하드웨어(1080)로부터, 인터넷(1081), 라우터(1082,1083,1084,1085,1087), AP(access point)(1088,1089) 및 백본(back bone) 네트워크(1092) 중 적어도 하나를 통하여 디스크 이미지를 다운로드할 수 있다. 또는 전자 장치(1090,1091)는 라우터(1082,1083,1084,1085,1087), AP(access point)(1088,1089) 및 백본(back bone) 네트워크(1092) 중 적어도 하나를 통하여 디스크 이미지 저장소의 하드웨어(1080)에 저장된 디스크 이미지를 참조할 수도 있다. 전자 장치(1090,1091)는 텔레커뮤니케이션 서버 또는 데이터 센터일 수 있다.
도 11은 본 발명의 다양한 실시예에 따른 스트리밍 서비스 생성을 설명하는 개념도를 도시한다.
도 11에 도시된 바와 같이, 디스크 이미지 저장소(1130)는 클라우드 관리 시스템(cloud management system)(1120)에 포함될 수 있다. 디스크 이미지 저장소(1130)는 적어도 하나의 디스크 이미지(1131 내지 1135)가 저장될 수 있다. 특히, 디스크 이미지 저장소(1130)는 스트리밍 서비스 관련 디스크 이미지(1133)를 저장할 수 있다.
클라우드 관리 시스템(1110)은 클라우드 관리 계층(cloud management layer)에서 정의될 수 있다. 클라우드 관리 시스템에는, 적어도 하나의 클라우드 서버(1041 내지 1044)가 포함될 수 있다.
도 11의 실시예는, 사용자(1110)(또는 관리자)가 스트리밍 서비스 서버를 기지국 서버(ENB)에서 가상화하는 시나리오에 대한 것일 수 있다. 기지국 서버(ENB)는, 예를 들어 전자 장치와 무선 통신을 수행하기 위한 서버일 수 있다.
사용자(1110)는 디스크 이미지 저장소(1130) 중 가상화 대상 디스크 이미지, 예를 들어 스트리밍 서비스 관련 디스크 이미지(1133)를 선택(1115)할 수 있다. 스트리밍 서비스 관련 디스크 이미지(1133)는, 예를 들어 제 1 OS 및 스트리밍 서비스 어플리케이션을 포함할 수 있다. 제 1 OS는 스트리밍 서비스 어플리케이션을 구동할 수 있는 OS일 수 있다.
스트리밍 서비스 관련 디스크 이미지(1133)가 선택되면, 사용자(1110)는 추가적으로 스트리밍 서비스 가상 머신이 설치될 하이퍼바이저(1162)를 선택(1175)할 수 있다. 사용자(1110)는 스트리밍 서비스 가상 머신 생성 명령(1185)를 송신할 수 있다.
하이퍼바이저(1162)는 스트리밍 서비스 가상 머신(1163)을 생성 및 실행하고, 하드웨어(1161) 자원을 스트리밍 서비스 가상 머신(1163)에 분배할 수 있다. 하이퍼바이저(1162)는 스트리밍 서비스 관련 디스크 이미지(1133)를 참조하는 루트 디스크 이미지를 생성하여, 생성된 루트 디스크 이미지에 근거하여 스트리밍 서비스 가상 머신(1163)을 실행될 수 있다.
스트리밍 서비스 가상 머신(1163)을 실행함으로써, 기지국 서버(ENB)는 스트리밍 서비스를 제공할 수 있다. 아울러, 하이퍼바이저(1162)는 스트리밍 서비스 관련 디스크 이미지(1133)를 병렬적으로 다운로드할 수 있으며, 다운로드가 완료되면 루트 디스크 이미지의 참조 대상을 다운로드된 디스크 이미지로 변경할 수 있다.
도 12는 본 발명의 다양한 실시예에 따른 단말 장치에서의 가상 머신의 실행을 설명하기 위한 개념도를 도시한다.
도 12에 도시된 바와 같이, 디스크 이미지 저장소(1220)는 클라우드 관리 시스템(cloud management system)(1210)에 포함될 수 있다. 디스크 이미지 저장소(1220)는 적어도 하나의 디스크 이미지(1221 내지 1225)가 저장될 수 있다. 특히, 디스크 이미지 저장소(1130)는 제 2 OS 관련 디스크 이미지(1225)를 저장할 수 있다.
단말 장치에는 하이퍼바이저(220)가 정의될 수 있다. 하이퍼바이저(220)의 상단에는 클라우드 관리 시스템 모듈(cloud management system module)(1201)이 정의될 수 있다. 즉, 단말 장치는, 클라우드 관리 시스템(1210)의 제어를 받지 않으면서, 내부에서 정의된 클라우드 관리 시스템 모듈(1201)을 통하여 가상 머신을 실행할 수 있다.
하나의 실시예에서, 클라우드 관리 시스템 모듈(1201)은 저장소 연결 모듈(1202), 다운로드 모듈(1203) 및 하이퍼바이저 연결 인터페이스(1204)를 포함할 수 있다. 클라우드 관리 시스템 모듈(1201)은 가상화 소프트웨어(1253) 상에서 동작할 수 있다.
저장소 연결 모듈(1202)은, 예를 들어 NFS 프로토콜을 통하여 원격의 디스크 이미지 저장소와 통신 연결을 형성할 수 있다. 저장소 연결 모듈(1202)은 예를 들어 단말 장치에서 생성된 루트 디스크 이미지가 참조하는 베이스 디스크 이미지에 대한 데이터 입출력을 수행할 수 있다.
다운로드 모듈(1203)은 원격의 디스크 이미지 저장소로부터의 베이스 디스크 이미지의 다운로드를 수행할 수 있다.
하이퍼바이저 연결 인터페이스(1204)는 관리 시스템 모듈(1201) 및 하이퍼바이저(220) 사이의 데이터 입출력을 수행할 수 있다.
단말 장치는 제 1 OS(1251)에 근거하여 실행되는 것을 상정하도록 한다. 한편, 사용자는 제 1 OS(1251)로부터 제 2 OS(1252)로의 변경을 원할 수 있다. 사용자는 제 2 OS 관련 디스크 이미지(1225)를 선택할 수 있다.
하이퍼바이저(220)는, 루트 디스크 이미지를 생성하며, 저장소 연결 모듈(1202)을 통하여 제 2 OS 관련 디스크 이미지(1225)를 참조하도록 제어할 수 있다. 하이퍼바이저(220)는, 다운로드 모듈(1230)을 통하여 베이스 디스크 이미지를 다운로드하도록 제어할 수 있다. 하이퍼바이저(220)는 다운로드가 완료되면, 루트 디스크 이미지의 참조 대상을 원격의 디스크 이미지 저장소의 베이스 디스크 이미지로부터 다운로드된 베이스 디스크 이미지로 변경할 수 있다.
도 13a 내지 13e는 본 발명의 다양한 실시예에 따른 전자 장치의 화면 구성을 설명하는 개념도를 도시한다. 도 13a 내지 13e는 도 14를 참조하여 더욱 상세하게 설명하도록 한다. 도 14는 본 발명의 다양한 실시예에 따른 전자 장치의 제어 방법을 설명하는 흐름도를 도시한다.
1410 동작에서, 전자 장치(101)는 OS 변경 명령 또는 모드 변경 명령을 획득할 수 있다. 예를 들어, 도 13a에서와 같이, 전자 장치(101)는 제 1 OS(A)에 근거한 화면(1300)을 표시할 수 있다. 제 1 OS에 근거한 화면(1300)은, 예를 들어 메뉴 화면으로, 적어도 하나의 실행 가능한 어플리케이션 아이콘(1301 내지 1305)을 포함할 수 있다. 도 13b에서와 같이, 전자 장치(101)는 제 1 OS(A)로부터 제 2 OS(B)로의 OS 변경 명령을 획득할 수 있다. 예를 들어, 전자 장치(101)는 OS 변경 명령을 문의하는 그래픽 사용자 인터페이스(1310)를 표시하고, 선택을 획득함으로써 OS 변경 명령을 획득할 수 있다. 한편, OS 및 모드를 통칭하여 환경이라고 명명할 수도 있다.
1420 동작에서, 전자 장치(101)는 대응 베이스 디스크 이미지의 위치를 획득할 수 있다. 예를 들어, 전자 장치(101)는 제 2 OS(B)에 대응하는 베이스 디스크 이미지의 위치를 획득할 수 있다. 여기에서, 제 2 OS(B)에 대응하는 베이스 디스크 이미지는 원격의 디스크 이미지 저장소에 저장될 수 있다. 하나의 실시예에서, 전자 장치(101)는 베이스 디스크 이미지의 URL을 획득할 수 있다.
1430 동작에서, 전자 장치(101)는 획득된 위치에 근거하여, 베이스 디스크 이미지를 참조하는 루트 디스크 이미지를 생성할 수 있다. 하나의 실시예에서, 루트 디스크 이미지는, 쓰기 전용 디스크 이미지일 수도 있다.
1440 동작에서, 전자 장치(101)는 루트 디스크 이미지에 근거하여 가상 머신을 시작할 수 있다. 14450 동작에서, 전자 장치(101)는 대응 화면을 표시할 수 있다. 예를 들어, 도 13c에서와 같이, 전자 장치(101)는 제 2 OS(B)에 대응하는 대응 화면(1320)을 포함할 수 있다. 대응 화면(1320)은 제 2 OS(B)에서 동작하는 적어도 하나의 어플리케이션 아이콘(1321 내지 1323)을 포함할 수 있다. 적어도 하나의 어플리케이션 아이콘(1321 내지 1323)은 베이스 디스크 이미지에 함께 포함될 수 있다.
상술한 바에 따라서, 전자 장치(101)는 제 1 OS(A)로부터 제 2 OB(B)로 OS를 변경하여 동작할 수 있다. 전자 장치(101)는 제 2 OS(B)에 대응하는 디스크 이미지 전체를 다운로드하지 않아도, 루트 디스크 이미지가 원격 참조하는 방식으로 가상 머신을 실행할 수 있어 신속한 OS 변경 실행을 수행할 수 있다. 특히, 전자 장치(101)가 스마트폰과 같은 단말 장치인 경우에는, 전체 베이스 디스크 이미지의 다운로드가 어려울 수 있으므로, 상술한 OS 변경 방법이 더욱 강인(robust)한 효과를 창출할 수 있다.
또 다른 실시예에서, 전자 장치(101)는 도 13d에서와 같이 모드 변경 명령을 획득할 수 있다. 예를 들어, 전자 장치(101)는 모드 변경 명령을 문의하는 그래픽 사용자 인터페이스(1330)를 표시하고, 선택을 획득함으로써 모드 변경 명령을 획득할 수 있다. 여기에서, 모드는 특정 OS에서 실행가능한 어플리케이션 집합을 의미할 수 있다. 예를 들어, 도 13a는 제 1 OS(A)에서의 제 1 모드에 대응하는 화면(1300)일 수 있다. 제 1 모드는 제 1 어플리케이션 아이콘(1301) 내지 제 5 어플리케이션 아이콘(1305)을 포함할 수 있다. 한편, 도 13e에서와 같이, 제 2 모드(C)는 제 1 OS(A)에서 실행가능한 제 1 어플리케이션 아이콘(1342) 및 제 2 어플리케이션 아이콘(1342)을 포함할 수 있다. 모드는, 예를 들어 사용 목적에 근거하여 기설정될 수 있다. 하나의 실시예에서, 제 1 모드는 일반 이용 목적에 근거하여 제 1 어플리케이션 아이콘(1301) 내지 제 5 어플리케이션 아이콘(1305)이 설정될 수 있다. 아울러, 제 2 모드는 사무 이용 목적에 근거하여 제 1 어플리케이션 아이콘(1301) 및 제 2 어플리케이션 아이콘(1302)이 설정될 수 있다. 한편, 제 2 모드는 제 1 모드에서 저장되지 않은 다른 어플리케이션 아이콘을 포함할 수 있음 또한 당업자는 용이하게 이해할 수 있을 것이다.
도 15는 본 발명의 다양한 실시예에 따른 가상 머신 실행 과정을 설명하기 위한 개념도이다. 도 15의 실시예는, 전자 장치(101)가 단말 장치인 경우를 상정하도록 하며, 설명의 편의성을 위하여 제 1 전자 장치(101)로 명명할 수 있다. 도 15의 실시예는 도 16a 및 16b를 참조하여 더욱 상세하게 설명하도록 한다. 도 16a 및 16b는 본 발명의 다양한 실시예에 따른 가상 머신 실행 과정을 설명하기 위한 흐름도를 도시한다.
도 15에 도시된 바와 같이, 제 1 전자 장치(101)는 다른 단말 장치인 제 2 전자 장치(1510)와 클라우드 관리 시스템(1500)을 통하여 연결될 수 있다. 클라우드 관리 시스템(1500)은 적어도 하나의 서버를 포함할 수 있다.
도 16a를 참조하면, 1601 동작에서, 제 1 전자 장치(101)는 제 1 OS를 제공할 수 있다. 예를 들어, 제 1 전자 장치(101)는 제 1 OS에 근거한 어플리케이션 실행 환경을 제공할 수 있다.
1603 동작에서, 제 2 전자 장치(1510)는 제 2 OS에 대응하는 제 2 디스크 이미지를 생성할 수 있다. 제 2 디스크 이미지는, 제 2 OS 및 제 2 OS에서 실행가능한 적어도 하나의 어플리케이션을 포함할 수 있다. 제 2 전자 장치(1510)는, 외부로부터의 생성 명령에 근거하여 제 2 디스크 이미지를 생성하거나, 또는 기설정된 이벤트가 검출되면 제 2 디스크 이미지를 생성할 수 있다.
1605 동작에서, 제 2 전자 장치(1510)는 생성된 제 2 디스크 이미지를 클라우드 관리 시스템(1500)에 포함된 서버(1501)로 송신할 수 있다.
1607 동작에서, 서버(1501)는 제 2 전자 장치(1510)로부터 수신한 제 2 디스크 이미지를 저장할 수 있다.
1609 동작에서, 제 1 전자 장치(101)는 루트 디스크 이미지를 생성할 수 있으며, 루트 디스크 이미지가 서버(1501)에 저장된 제 2 디스크 이미지를 참조하도록 제어할 수 있다.
1611 동작에서, 제 1 전자 장치(101)는 루트 디스크 이미지에 근거하여 가상 머신을 시작 및 실행할 수 있다. 1613 동작에서, 제 1 전자 장치(101)는 제 2 OS를 제공할 수 있으며, 이에 따라 제 2 전자 장치(1510)에서 실행되던 어플리케이션을 실행할 수 있다.
도 16b를 참조하면, 1621 동작에서, 제 1 전자 장치(101)는 제 1 모드를 제공할 수 있다. 예를 들어, 제 1 전자 장치(101)는 제 1 모드로, 제 1 OS에서 실행 가능한 제 1 어플리케이션을 제공할 수 있다.
1623 동작에서, 제 2 전자 장치(1510)는 제 2 모드에 대응하는 제 2 디스크 이미지를 생성할 수 있다. 제 2 디스크 이미지는, 제 1 OS 및 제 1 OS에서 실행가능한 제 2 어플리케이션을 포함할 수 있다. 제 2 전자 장치(1510)는, 외부로부터의 생성 명령에 근거하여 제 2 디스크 이미지를 생성하거나, 또는 기설정된 이벤트가 검출되면 제 2 디스크 이미지를 생성할 수 있다.
1625 동작에서, 제 2 전자 장치(1510)는 생성된 제 2 디스크 이미지를 클라우드 관리 시스템(1500)에 포함된 서버(1501)로 송신할 수 있다.
1627 동작에서, 서버(1501)는 제 2 전자 장치(1510)로부터 수신한 제 2 디스크 이미지를 저장할 수 있다.
1629 동작에서, 제 1 전자 장치(101)는 루트 디스크 이미지를 생성할 수 있으며, 루트 디스크 이미지가 서버(1501)에 저장된 제 2 디스크 이미지를 참조하도록 제어할 수 있다.
1631 동작에서, 제 1 전자 장치(101)는 루트 디스크 이미지에 근거하여 가상 머신을 시작 및 실행할 수 있다. 1633 동작에서, 제 1 전자 장치(101)는 제 1 OS에서 실행가능한 제 2 어플리케이션을 제공할 수 있으며, 이에 따라 제 2 전자 장치(1510)에서 실행되던 제 2 어플리케이션을 실행할 수 있다.
도 17은 본 발명의 다양한 실시예에 따른 가상 머신 실행 과정을 설명하기 위한 개념도를 도시한다. 도 17은 오픈스택(openstack) 시스템에서의 가상 머신 실행 방법을 설명한다.
도 17에 도시된 바와 같이, 가상 머신 실행 방법은 오픈스택(1701) 시스템에서 수행될 수 있다. 오픈스택(1701)은 오픈 소스 클라우딩 컴퓨팅 플랫폼일 수 있다.
전술한 베이스 디스크 이미지(1710)는, 예를 들어 NFS 스토어(Network File System)와 같은 글랜스(glance)에 저장될 수 있다. 베이스 디스크 이미지(1710)는 네트워크(1704)를 통하여 libvirt 베이스 디스크 이미지 저장소(1705)로 다운로드되어 저장될 수 있다. 다운로드되는 베이스 디스크 이미지(1706)는, 예를 들어 베이스 디스크 이미지(1710)와 동일한 내용의 템플릿(template) 파일이 된다. 디플로이 모델(1702)에 근거하여, libvirt는 오픈 소스 API로 KVM, XEN, Vmware 등의 다양한 가상화 플랫폼 관리를 위한 관리 툴을 제공할 수 있다. 한편, libvirt 임시 디스크 저장소(1708)에는 루트 디스크 이미지(1709)가 소정의 볼륨으로 생성될 수 있으며, 글랜스(1703) 내의 베이스 디스크 이미지(1710)를 참조할 수 있다. 글랜스(1703)을 이용하여 만들어진 루트 디스크 이미지(1709)를 통해서 가상머신이 실행되며, 베이스 디스크 이미지(1706)를 다운로드한 템플릿 이미지(1706)이 다운로드가 완료되면 libvirt API를 통해서 베이스 이미지(1710)이 템플릿 이미지(1706)으로 변경될 수 있다.
도 18은 본 발명의 다양한 실시예에 따른 가상 머신 실행 방법의 흐름도를 도시한다.
1810 동작에서, 전자 장치(101)는 이미지 캐시를 확인할 수 있다. 더욱 상세하게, 전자 장치(101)는 전자 장치(101) 내부에 가상 머신을 실행할 수 있는 특정 디스크 이미지가 존재하는지를 판단할 수 있다.
1820 동작에서, 특정 디스크 이미지가 존재하는 것으로 판단되면, 전자 장치(101)는 특정 디스크 이미지에 근거하여 가상 머신을 생성하여 실행할 수 있다.
1830 동작에서, 특정 디스크 이미지가 존재하지 않는 것으로 판단되면, 전자 장치(101)는 글랜스(1703)로부터 해당 베이스 디스크 이미지의 URL을 획득할 수 있다.
1840 동작에서, 전자 장치(101)는 글랜스(1703)로부터 베이스 디스크 이미지를 다운로드받을 수 있다.
1850 동작에서, 전자 장치(101)는 글랜스(1703)에 NFS 마운트(mount)를 수행할 수 있다. 더욱 상세하게, 전자 장치(101)는 글랜스(1703)로 NFS와 같은 프로토콜을 이용하여 통신 연결을 형성할 수 있다.
1860 동작에서, 전자 장치(101)는 NFS 마운트된 베이스 디스크 이미지에 근거하여 루트 디스크 이미지 및 가상 머신의 실행을 위한 볼륨을 설정할 수 있다.
1870 동작에서, 전자 장치(101)는 설정된 볼륨에 가상 머신을 생성할 수 있으며, 예를 들어 루트 디스크 이미지에 근거하여 가상 머신을 생성하여 실행할 수 있다.
1880 동작에서, 전자 장치(101)는 다운로드가 완료되는지를 판단할 수 있다. 다운로드가 완료되면, 1890 동작에서, 전자 장치(101)는 설정된 볼륨에 다운로드된 템플릿 형태의 베이스 디스크 이미지를 교체할 수 있다. 더욱 상세하게, 전자 장치(101)는 루트 디스크 이미지의 참조 대상을 다운로드된 템플릿 형태의 베이스 디스크 이미지로 변경할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지의 위치를 획득하는 동작; 상기 획득된 위치에 근거하여, 상기 제 1 베이스 디스크 이미지를 참조(backing)하는 루트 디스크 이미지를 생성하는 동작; 및 상기 생성된 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작을 포함할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 상기 디스크 이미지 저장소로부터 상기 제 1 베이스 디스크 이미지를 다운로드하여, 상기 전자 장치에 제 2 베이스 디스크 이미지를 저장하는 동작을 더 포함할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 상기 다운로드가 완료되면, 상기 루트 디스크 이미지가 상기 제 2 베이스 디스크 이미지를 참조하도록 하는 동작을 더 포함할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은,상기 루트 디스크 이미지가 상기 제 2 베이스 디스크 이미지를 참조하도록 하는 동작은, 데이터 입출력을 수행하는 오브젝트를 상기 제 1 베이스 디스크 이미지에 대응하는 제 1 오브젝트로부터 상기 제 2 베이스 디스크 이미지에 대응하는 제 2 오브젝트로 변경하는 동작을 포함할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 상기 제 1 오브젝트로부터의 데이터 입출력을 중단하는 동작; 및 상기 제 2 오브젝트로의 변경이 완료되면, 상기 제 2 오브젝트로부터의 데이터 입출력을 개시하는 동작을 더 포함할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 상기 다운로드가 완료되면, 상기 루트 디스크 이미지와 상기 제 2 베이스 디스크 이미지를 머지(merge)하여 머지드 디스크 이미지(merged disk image)를 생성하고, 상기 생성된 머지드 디스크 이미지에 근거하여 가상 머신을 실행하는 동작을 더 포함할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 상기 제 2 베이스 디스크 이미지를 삭제하는 동작을 더 포함할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 상기 다운로드가 완료되면, 상기 디스크 이미지 저장소와의 연결을 해제하는 동작을 더 포함할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 상기 디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지의 위치를 획득하는 동작은, 상기 제 1 베이스 디스크 이미지의 URL을 획득하는 동작을 포함할 수 있다.
본 발명의 실시 예에 따르면, 가상 머신을 실행하는 전자 장치는, 제 1 베이스 디스크 이미지를 저장하는 디스크 이미지 저장소와 통신 연결을 형성하는 통신 인터페이스; 및 디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지의 위치를 획득하고, 상기 획득된 위치에 근거하여 상기 제 1 베이스 디스크 이미지를 참조(backing)하는 루트 디스크 이미지를 생성하며, 상기 생성된 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 프로세서를 포함할 수 있다.
본 발명의 실시 예에 따르면, 가상 머신을 실행하는 전자 장치는, 메모리를 더 포함하며, 상기 통신 인터페이스는, 상기 디스크 이미지 저장소로부터 상기 제 1 베이스 디스크 이미지를 다운로드하며, 상기 메모리는 제 2 베이스 디스크 이미지를 저장할 수 있다.
본 발명의 실시 예에 따르면, 상기 프로세서는, 상기 다운로드가 완료되면, 상기 루트 디스크 이미지가 상기 제 2 베이스 디스크 이미지를 참조하도록 할 수 있다.
본 발명의 실시 예에 따르면, 상기 프로세서는, 데이터 입출력을 수행하는 오브젝트를 상기 제 1 베이스 디스크 이미지에 대응하는 제 1 오브젝트로부터 상기 제 2 베이스 디스크 이미지에 대응하는 제 2 오브젝트로 변경할 수 있다.
본 발명의 실시 예에 따르면, 상기 프로세서는, 상기 제 1 오브젝트로부터의 데이터 입출력을 중단하고, 상기 제 2 오브젝트로의 변경이 완료되면, 상기 제 2 오브젝트로부터의 데이터 입출력을 개시할 수 있다.
본 발명의 실시 예에 따르면, 상기 다운로드가 완료되면, 상기 프로세서는 상기 루트 디스크 이미지와 상기 제 2 베이스 디스크 이미지를 머지(merge)하여 머지드 디스크 이미지(merged disk image)를 생성하고, 상기 생성된 머지드 디스크 이미지에 근거하여 상기 가상 머신을 실행할 수 있다.
본 발명의 실시 예에 따르면, 상기 프로세서는 제 2 베이스 디스크 이미지를 삭제할 수 있다.
본 발명의 실시 예에 따르면, 상기 다운로드가 완료되면, 상기 통신 인터페이스는 상기 디스크 이미지 저장소와의 연결을 해제할 수 있다.
본 발명의 실시 예에 따르면, 상기 프로세서는, 상기 제 1 베이스 디스크 이미지의 URL을 획득하여, 상기 획득된 URL에 근거하여 상기 제 1 베이스 디스크 이미지를 참조하도록 제어할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 상기 전자 장치의 외부에 저장되는 제 1 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작; 상기 루트 디스크 이미지의 참조 대상을 상기 제 1 베이스 디스크 이미지로부터 상기 전자 장치의 내부에 저장되는 제 2 베이스 디스크 이미지로 변경하는 동작; 및 상기 제 2 베이스 디스크 이미지를 참조하는 상기 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작을 포함할 수 있다.
본 발명의 실시 예에 따르면, 상기 참조 대상을 변경하는 동작은, 데이터 입출력을 수행하는 오브젝트를 상기 제 1 베이스 디스크 이미지에 대응하는 제 1 오브젝트로부터 상기 제 2 베이스 디스크 이미지에 대응하는 제 2 오브젝트로 변경하는 동작을 포함할 수 있다.
본 발명의 실시 예에 따르면, 가상 머신을 실행하는 전자 장치는, 상기 전자 장치의 외부에 저장되는 제 1 베이스 디스크 이미지를 참조하는 통신 인터페이스; 및 상기 제 1 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 프로세서를 포함하고, 상기 프로세서는, 상기 루트 디스크 이미지의 참조 대상을 상기 제 1 베이스 디스크 이미지로부터 상기 전자 장치의 내부에 저장되는 제 2 베이스 디스크 이미지로 변경하고, 상기 제 2 베이스 디스크 이미지를 참조하는 상기 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행할 수 있다.
본 발명의 실시 예에 따르면, 상기 프로세서는, 데이터 입출력을 수행하는 오브젝트를 상기 제 1 베이스 디스크 이미지에 대응하는 제 1 오브젝트로부터 상기 제 2 베이스 디스크 이미지에 대응하는 제 2 오브젝트로 변경할 수 있다.
본 발명의 실시 예에 따르면, 전자 장치에서 가상 머신을 실행하는 방법은, 상기 전자 장치의 외부에 저장되는 제 1 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작; 상기 제 1 베이스 디스크 이미지를 다운로드 하여, 상기 전자 장치의 내부에 제 2 베이스 디스크 이미지를 저장하는 동작; 및 상기 다운로드가 완료되면, 상기 루트 디스크 이미지와 상기 제 2 베이스 디스크 이미지를 머지(merge)하여 머지드 디스크 이미지(merged disk image)를 생성하고, 상기 생성된 머지드 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작을 포함할 수 있다.
본 발명의 실시 예에 따르면, 상기 루트 디스크 이미지는 쓰기 전용 디스크 이미지일 수 있다.
본 발명의 실시 예에 따르면, 가상 머신을 실행하는 전자 장치는, 상기 전자 장치의 외부에 저장되는 제 1 베이스 디스크 이미지를 참조하는 통신 인터페이스; 상기 제 1 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 프로세서; 및 상기 제 1 베이스 디스크 이미지를 다운로드 하여, 제 2 베이스 디스크 이미지를 저장하는 메모리를 포함하고, 상기 프로세서는, 상기 다운로드가 완료되면, 상기 루트 디스크 이미지와 상기 제 2 베이스 디스크 이미지를 머지(merge)하여 머지드 디스크 이미지(merged disk image)를 생성하고, 상기 생성된 머지드 디스크 이미지에 근거하여 상기 가상 머신을 실행할 수 있다.
본 발명의 실시 예에 따르면, 상기 루트 디스크 이미지는 쓰기 전용 디스크 이미지일 수 있다.
본 발명의 실시 예에 따르면, 전자 장치의 화면 구성 방법은, 제 1 환경에 근거한 제 1 화면을 표시하는 동작; 상기 제 1 환경으로부터 제 2 환경으로의 변경을 요청하는 환경 변경 명령을 획득하는 동작; 상기 제 2 환경에 대응하는 베이스 디스크 이미지의 위치를 획득하는 동작; 상기 베이스 디스크 이미지를 참조하는 루트 디스크 이미지를 생성하는 동작; 및 상기 루트 디스크 이미지에 근거하여 가상 머신을 실행함으로써, 상기 제 2 환경에 근거한 제 2 화면을 표시하는 동작을 포함할 수 있다.
본 발명의 실시 예에 따르면, 상기 제 1 환경은 제 1 OS(operating system) 또는 제 1 모드에 대한 것이며, 상기 제 2 환경은, 제 2 OS(operating system) 또는 제 2 모드에 대한 것일 수 있다.
본 발명의 실시 예에 따르면, 전자 장치는, 제 1 환경에 근거한 제 1 화면을 표시하는 디스플레이; 상기 제 1 환경으로부터 제 2 환경으로의 변경을 요청하는 환경 변경 명령을 획득하는 입출력 인터페이스; 상기 제 2 환경에 대응하는 베이스 디스크 이미지의 위치를 획득하고, 상기 베이스 디스크 이미지를 참조하는 루트 디스크 이미지를 생성하고, 상기 루트 디스크 이미지에 근거하여 가상 머신을 실행함으로써, 상기 제 2 환경에 근거한 제 2 화면을 표시하도록 제어하는 프로세서를 포함할 수 있다.
본 발명의 실시 예에 따르면, 상기 제 1 환경은 제 1 OS(operating system) 또는 제 1 모드에 대한 것이며, 상기 제 2 환경은, 제 2 OS(operating system) 또는 제 2 모드에 대한 것일 수 있다.
도 19는 본 발명의 다양한 실시예에 따른 전자 장치(1901)의 블록도(1900)이다. 도 19는 특히 전자 장치(1901)가 단말 장치로 구현되는 경우의 블록도일 수 있다.
상기 전자 장치(1901)는, 예를 들면, 전자 장치(101)의 전체 또는 일부를 포함할 수 있다. 상기 전자 장치(1901)는 하나 이상의 어플리케이션 프로세서(AP: application processor)(1910), 통신 모듈(1920), SIM(subscriber identification module) 카드(1924), 메모리(1930), 센서 모듈(1940), 입력 장치(1950), 디스플레이(1960), 인터페이스(1970), 오디오 모듈(1980), 카메라 모듈(1991), 전력 관리 모듈(1995), 배터리(1996), 인디케이터(1997), 및 모터(1998)를 포함할 수 있다.
상기 AP(1910)는, 예를 들면, 운영 체제 또는 응용 프로그램을 구동하여 상기 AP(1910)에 연결된 다수의 하드웨어 또는 소프트웨어 구성요소들을 제어할 수 있고, 각종 데이터 처리 및 연산을 수행할 수 있다. 상기 AP(1910)는, 예를 들면, SoC(system on chip) 로 구현될 수 있다. 한 실시예에 따르면, 상기 AP(1910)는 GPU(graphic processing unit) 및/또는 이미지 신호 프로세서(image signal processor)를 더 포함할 수 있다. 상기 AP(1910)는 예를 들어, 셀룰러 모듈을 포함할 수도 있다. 상기 AP(1910)는 다른 구성요소들(예: 비휘발성 메모리) 중 적어도 하나로부터 수신된 명령 또는 데이터를 휘발성 메모리에 로드(load)하여 처리하고, 다양한 데이터를 비휘발성 메모리에 저장(store)할 수 있다.
상기 통신 모듈(1920)은, 도 1b의 상기 통신 인터페이스(170)와 동일 또는 유사한 구성을 가질 수 있다. 상기 통신 모듈(1920)은, 예를 들면, 셀룰러 모듈(1921), WIFI 모듈(1923), BT 모듈(1925), GPS 모듈(1927), NFC 모듈(1928) 및 RF(radio frequency) 모듈(1929)를 포함할 수 있다.
상기 셀룰러 모듈(1921)은, 예를 들면, 통신망을 통해서 음성 통화, 영상 통화, 문자 서비스, 또는 인터넷 서비스 등을 제공할 수 있다. 한 실시예에 따르면, 상기 셀룰러 모듈(1921)은 가입자 식별 모듈(예: SIM 카드(1924))을 이용하여 통신 네트워크 내에서 전자 장치(1901)의 구별 및 인증을 수행할 수 있다. 한 실시예에 따르면, 상기 셀룰러 모듈(1921)은 상기 AP(1910)가 제공할 수 있는 기능 중 적어도 일부 기능을 수행할 수 있다. 한 실시예에 따르면, 상기 셀룰러 모듈(1921)은 커뮤니케이션 프로세서(CP: communication processor)를 포함할 수 있다.
상기 WIFI 모듈(1923), 상기 BT 모듈(1925), 상기 GPS 모듈(1927) 또는 상기 NFC 모듈(1928) 각각은, 예를 들면, 해당하는 모듈을 통해서 송수신되는 데이터를 처리하기 위한 프로세서를 포함할 수 있다. 어떤 실시예에 따르면, 셀룰러 모듈(1921), WIFI 모듈(1923), BT 모듈(1925), GPS 모듈(1927) 또는 NFC 모듈(1928) 중 적어도 일부(예: 두 개 이상)는 하나의 integrated chip(IC) 또는 IC 패키지 내에 포함될 수 있다.
상기 RF 모듈(1929)는, 예를 들면, 통신 신호(예: RF 신호)를 송수신할 수 있다. 상기 RF 모듈(1929)는, 예를 들면, 트랜시버(transceiver), PAM(power amp module), 주파수 필터(frequency filter), LNA(low noise amplifier), 또는 안테나 등을 포함할 수 있다. 다른 실시예에 따르면, 셀룰러 모듈(1921), WIFI 모듈(1923), BT 모듈(1925), GPS 모듈(1927) 또는 NFC 모듈(1928) 중 적어도 하나는 별개의 RF 모듈을 통하여 RF 신호를 송수신할 수 있다.
상기 SIM 카드(1924)는, 예를 들면, 가입자 식별 모듈을 포함하는 카드 및/또는 내장 SIM(embedded SIM)을 포함할 수 있으며, 고유한 식별 정보(예: ICCID(integrated circuit card identifier)) 또는 가입자 정보(예: IMSI(international mobile subscriber identity))를 포함할 수 있다.
상기 메모리(1930)(예: 메모리(130))는, 예를 들면, 내장 메모리(1932) 또는 외장 메모리(1934)를 포함할 수 있다. 상기 내장 메모리(1932)는, 예를 들면, 휘발성 메모리(예: DRAM(dynamic RAM), SRAM(static RAM), 또는 SDRAM(synchronous dynamic RAM) 등), 비휘발성 메모리(non-volatile Memory)(예: OTPROM(one time programmable ROM), PROM(programmable ROM), EPROM(erasable and programmable ROM), EEPROM(electrically erasable and programmable ROM), mask ROM, flash ROM, 플래시 메모리(예: NAND flash 또는 NOR flash 등), 하드 드라이브, 또는 솔리드 스테이트 드라이브(solid state drive(SSD)) 중 적어도 하나를 포함할 수 있다.
상기 외장 메모리(1934)는 flash drive, 예를 들면, CF(compact flash), SD(secure digital), Micro-SD(micro secure digital), Mini-SD(mini secure digital), xD(extreme digital), 또는 메모리 스틱(memory stick) 등을 더 포함할 수 있다. 상기 외장 메모리(1934)는 다양한 인터페이스를 통하여 상기 전자 장치(1901)와 기능적으로 및/또는 물리적으로 연결될 수 있다.
상기 센서 모듈(1940)은, 예를 들면, 물리량을 계측하거나 전자 장치(1901)의 작동 상태를 감지하여, 계측 또는 감지된 정보를 전기 신호로 변환할 수 있다. 상기 센서 모듈(1940)은, 예를 들면, 제스처 센서(1940A), 자이로 센서(1940B), 기압 센서(1940C), 마그네틱 센서(1940D), 가속도 센서(1940E), 그립 센서(1940F), 근접 센서(1940G), color 센서(1940H)(예: RGB(red, green, blue) 센서), 생체 센서(1940I), 온/습도 센서(1940J), 조도 센서(1940K), 또는 UV(ultra violet) 센서(1940M) 중의 적어도 하나를 포함할 수 있다. 추가적으로 또는 대체적으로, 상기 센서 모듈(1940)은, 예를 들면, 후각 센서(E-nose sensor), EMG 센서(electromyography sensor), EEG 센서(electroencephalogram sensor), ECG 센서(electrocardiogram sensor), IR(infrared) 센서, 홍채 센서 및/또는 지문 센서를 포함할 수 있다. 상기 센서 모듈(1940)은 그 안에 속한 적어도 하나 이상의 센서들을 제어하기 위한 제어 회로를 더 포함할 수 있다. 어떤 실시예에서는, 전자 장치(1901)는 AP(1910)의 일부로서 또는 별도로, 센서 모듈(1940)을 제어하도록 구성된 프로세서를 더 포함하여, 상기 AP(1910)가 슬립(sleep) 상태에 있는 동안, 센서 모듈(1940)을 제어할 수 있다.
상기 입력 장치(1950)은, 예를 들면, 터치 패널(touch panel)(1952), (디지털) 펜 센서(pen sensor)(1954), 키(key)(1956), 또는 초음파(ultrasonic) 입력 장치(1958)를 포함할 수 있다. 상기 터치 패널(1952)은, 예를 들면, 정전식, 감압식, 적외선 방식, 또는 초음파 방식 중 적어도 하나의 방식을 사용할 수 있다. 또한, 상기 터치 패널(1952)은 제어 회로를 더 포함할 수도 있다. 상기 터치 패널(1952)은 택타일 레이어(tactile layer)를 더 포함하여, 사용자에게 촉각 반응을 제공할 수 있다.
상기(디지털) 펜 센서(1954)는, 예를 들면, 터치 패널의 일부이거나, 별도의 인식용 쉬트(sheet)를 포함할 수 있다. 상기 키(1956)는, 예를 들면, 물리적인 버튼, 광학식 키, 또는 키패드를 포함할 수 있다. 상기 초음파 입력 장치(1958)는 초음파 신호를 발생하는 입력 도구를 통해, 전자 장치(1901)에서 마이크(예: 마이크(1988))로 음파를 감지하여 데이터를 확인할 수 있다.
상기 디스플레이(1960)(예: 디스플레이(160))은 패널(1962), 홀로그램 장치(1964), 또는 프로젝터(1966)을 포함할 수 있다. 상기 패널(1962)은, 도 1b의 디스플레이(160)과 동일 또는 유사한 구성을 포함할 수 있다. 상기 패널(1962)은, 예를 들면, 유연하게(flexible), 투명하게(transparent), 또는 착용할 수 있게(wearable) 구현될 수 있다. 상기 패널(1962)은 상기 터치 패널(1952)과 하나의 모듈로 구성될 수도 있다. 상기 홀로그램 장치(1964)은 빛의 간섭을 이용하여 입체 영상을 허공에 보여줄 수 있다. 상기 프로젝터(1966)는 스크린에 빛을 투사하여 영상을 표시할 수 있다. 상기 스크린은, 예를 들면, 상기 전자 장치(1901)의 내부 또는 외부에 위치할 수 있다. 한 실시예에 따르면, 상기 디스플레이(1960)은 상기 패널(1962), 상기 홀로그램 장치(1964), 또는 프로젝터(1966)를 제어하기 위한 제어 회로를 더 포함할 수 있다.
상기 인터페이스(1970)는, 예를 들면, HDMI(high-definition multimedia interface)(1972), USB(universal serial bus)(1974), 광 인터페이스(optical interface)(1976), 또는 D-sub(D-subminiature)(1978)를 포함할 수 있다. 상기 인터페이스(1970)는, 예를 들면, 통신 인터페이스(170)에 포함될 수 있다. 추가적으로 또는 대체적으로, 상기 인터페이스(1970)는, 예를 들면, MHL(mobile high-definition link) 인터페이스, SD(secure digital) 카드/MMC(multi-media card) 인터페이스, 또는 IrDA(infrared data association) 규격 인터페이스를 포함할 수 있다.
상기 오디오 모듈(1980)은, 예를 들면, 소리(sound)와 전기 신호를 쌍방향으로 변환시킬 수 있다. 상기 오디오 모듈(1980)의 적어도 일부 구성요소는, 예를 들면, 도 1b 에 도시된 입출력 인터페이스(140)에 포함될 수 있다. 상기 오디오 모듈(1980)은, 예를 들면, 스피커(1982), 리시버(1984), 이어폰(1986), 또는 마이크(1988) 등을 통해 입력 또는 출력되는 소리 정보를 처리할 수 있다.
상기 카메라 모듈(1991)은, 예를 들면, 정지 영상 및 동영상을 촬영할 수 있는 장치로서, 한 실시예에 따르면, 하나 이상의 이미지 센서(예: 전면 센서 또는 후면 센서), 렌즈, ISP(image signal processor), 또는 플래쉬(flash)(예: LED 또는 xenon lamp)를 포함할 수 있다.
상기 전력 관리 모듈(1995)은, 예를 들면, 상기 전자 장치(1901)의 전력을 관리할 수 있다. 한 실시예에 따르면, 상기 전력 관리 모듈(1995)은 PMIC(power management integrated circuit), 충전 IC(charger integrated circuit), 또는 배터리 또는 연료 게이지(battery or fuel gauge)를 포함할 수 있다. 상기 PMIC는, 유선 및/또는 무선 충전 방식을 가질 수 있다. 무선 충전 방식은, 예를 들면, 자기공명 방식, 자기유도 방식 또는 전자기파 방식 등을 포함하며, 무선 충전을 위한 부가적인 회로, 예를 들면, 코일 루프, 공진 회로, 또는 정류기 등을 더 포함할 수 있다. 상기 배터리 게이지는, 예를 들면, 상기 배터리(1996)의 잔량, 충전 중 전압, 전류, 또는 온도를 측정할 수 있다. 상기 배터리(1996)는, 예를 들면, 충전식 전지(rechargeable battery) 및/또는 태양 전지(solar battery)를 포함할 수 있다.
상기 인디케이터(1997)는 상기 전자 장치(1901) 혹은 그 일부(예: AP(1910))의 특정 상태, 예를 들면, 부팅 상태, 메시지 상태 또는 충전 상태 등을 표시할 수 있다. 상기 모터(1998)는 전기적 신호를 기계적 진동으로 변환할 수 있고, 진동(vibration), 또는 햅틱(haptic) 효과 등을 발생시킬 수 있다. 도시되지는 않았으나, 상기 전자 장치(1901)는 모바일 TV 지원을 위한 처리 장치(예: GPU)를 포함할 수 있다. 상기 모바일 TV 지원을 위한 처리 장치는, 예를 들면, DMB(digital multimedia broadcasting), DVB(digital video broadcasting), 또는 미디어 플로우(media flow) 등의 규격에 따른 미디어 데이터를 처리할 수 있다.
상기 전자 장치의 전술한 구성요소들 각각은 하나 또는 그 이상의 부품(component)으로 구성될 수 있으며, 해당 구성 요소의 명칭은 전자 장치의 종류에 따라서 달라질 수 있다. 다양한 실시예에서, 전자 장치는 전술한 구성요소 중 적어도 하나를 포함하여 구성될 수 있으며, 일부 구성요소가 생략되거나 또는 추가적인 다른 구성요소를 더 포함할 수 있다. 또한, 다양한 실시예에 따른 전자 장치의 구성 요소들 중 일부가 결합되어 하나의 개체(entity)로 구성됨으로써, 결합되기 이전의 해당 구성 요소들의 기능을 동일하게 수행할 수 있다.
본 문서에서 사용된 용어 “모듈”은, 예를 들면, 하드웨어, 소프트웨어 또는 펌웨어(firmware) 중 하나 또는 둘 이상의 조합을 포함하는 단위(unit)를 의미할 수 있다. “모듈”은, 예를 들면, 유닛(unit), 로직(logic), 논리 블록(logical block), 부품(component), 또는 회로(circuit) 등의 용어와 바꾸어 사용(interchangeably use)될 수 있다. “모듈”은, 일체로 구성된 부품의 최소 단위 또는 그 일부가 될 수 있다. “모듈”은 하나 또는 그 이상의 기능을 수행하는 최소 단위 또는 그 일부가 될 수도 있다. “모듈”은 기계적으로 또는 전자적으로 구현될 수 있다. 예를 들면,“모듈”은, 알려졌거나 앞으로 개발될, 어떤 동작들을 수행하는 ASIC(application-specific integrated circuit) 칩, FPGAs(field-programmable gate arrays) 또는 프로그램 가능 논리 장치(programmable-logic device) 중 적어도 하나를 포함할 수 있다.
다양한 실시예에 따른 장치(예: 모듈들 또는 그 기능들) 또는 방법(예: 동작들)의 적어도 일부는, 예컨대, 프로그램 모듈의 형태로 컴퓨터로 읽을 수 있는 저장매체(computer-readable storage media)에 저장된 명령어로 구현될 수 있다. 상기 명령어는, 프로세서(예: 프로세서(120))에 의해 실행될 경우, 상기 하나 이상의 프로세서가 상기 명령어에 해당하는 기능을 수행할 수 있다. 컴퓨터로 읽을 수 있는 저장매체는, 예를 들면, 상기 메모리(130)가 될 수 있다.
상기 컴퓨터로 판독 가능한 기록 매체는, 하드디스크, 플로피디스크, 마그네틱 매체(magnetic media)(예: 자기테이프), 광기록 매체(optical media)(예: CD-ROM(compact disc read only memory), DVD(digital versatile disc), 자기-광 매체(magneto-optical media)(예: 플롭티컬 디스크(floptical disk)), 하드웨어 장치(예: ROM(read only memory), RAM(random access memory), 또는 플래시 메모리 등) 등을 포함할 수 있다. 또한, 프로그램 명령에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함할 수 있다. 상술한 하드웨어 장치는 다양한 실시예의 동작을 수행하기 위해 하나 이상의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지다.
다양한 실시예에 따른 모듈 또는 프로그램 모듈은 전술한 구성요소들 중 적어도 하나 이상을 포함하거나, 일부가 생략되거나, 또는 추가적인 다른 구성요소를 더 포함할 수 있다. 다양한 실시예에 따른 모듈, 프로그램 모듈 또는 다른 구성요소에 의해 수행되는 동작들은 순차적, 병렬적, 반복적 또는 휴리스틱(heuristic)한 방법으로 실행될 수 있다. 또한, 일부 동작은 다른 순서로 실행되거나, 생략되거나, 또는 다른 동작이 추가될 수 있다.
본 발명의 다양한 실시예에 따르면, 명령들을 저장하고 있는 저장 매체에 있어서, 상기 명령들은 적어도 하나의 프로세서에 의하여 실행될 때에 상기 적어도 하나의 프로세서로 하여금 적어도 하나의 동작을 수행하도록 설정된 것으로서, 상기 적어도 하나의 동작은, 디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지의 위치를 획득하는 동작; 상기 획득된 위치에 근거하여, 상기 제 1 베이스 디스크 이미지를 참조(backing)하는 루트 디스크 이미지를 생성하는 동작; 및 상기 생성된 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작을 포함할 수 있다.
그리고 본 문서에 개시된 실시예는 개시된, 기술 내용의 설명 및 이해를 위해 제시된 것이며, 본 개시의 범위를 한정하는 것은 아니다. 따라서, 본 개시의 범위는, 본 개시의 기술적 사상에 근거한 모든 변경 또는 다양한 다른 실시예를 포함하는 것으로 해석되어야 한다.

Claims (32)

  1. 전자 장치에서 가상 머신을 실행하는 방법에 있어서,
    디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지의 위치를 획득하는 동작;
    상기 획득된 위치에 근거하여, 상기 제 1 베이스 디스크 이미지를 참조(backing)하는 루트 디스크 이미지를 생성하는 동작; 및
    상기 생성된 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작
    을 포함하는 가상 머신을 실행하는 방법.
  2. 제 1 항에 있어서,
    상기 디스크 이미지 저장소로부터 상기 제 1 베이스 디스크 이미지를 다운로드하여, 상기 전자 장치에 제 2 베이스 디스크 이미지를 저장하는 동작
    을 더 포함하는 가상 머신을 실행하는 방법.
  3. 제 2 항에 있어서,
    상기 다운로드가 완료되면, 상기 루트 디스크 이미지가 상기 제 2 베이스 디스크 이미지를 참조하도록 하는 동작
    을 더 포함하는 가상 머신을 실행하는 방법.
  4. 제 3 항에 있어서,
    상기 루트 디스크 이미지가 상기 제 2 베이스 디스크 이미지를 참조하도록 하는 동작은, 데이터 입출력을 수행하는 오브젝트를 상기 제 1 베이스 디스크 이미지에 대응하는 제 1 오브젝트로부터 상기 제 2 베이스 디스크 이미지에 대응하는 제 2 오브젝트로 변경하는 동작
    을 포함하는 가상 머신을 실행하는 방법.
  5. 제 4 항에 있어서,
    상기 제 1 오브젝트로부터의 데이터 입출력을 중단하는 동작; 및
    상기 제 2 오브젝트로의 변경이 완료되면, 상기 제 2 오브젝트로부터의 데이터 입출력을 개시하는 동작
    을 더 포함하는 가상 머신을 실행하는 방법.
  6. 제 2 항에 있어서,
    상기 다운로드가 완료되면, 상기 루트 디스크 이미지와 상기 제 2 베이스 디스크 이미지를 머지(merge)하여 머지드 디스크 이미지(merged disk image)를 생성하고, 상기 생성된 머지드 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작
    을 더 포함하는 가상 머신을 실행하는 방법.
  7. 제 6 항에 있어서,
    상기 제 2 베이스 디스크 이미지를 삭제하는 동작
    을 더 포함하는 가상 머신을 실행하는 방법.
  8. 제 2 항에 있어서,
    상기 다운로드가 완료되면, 상기 디스크 이미지 저장소와의 연결을 해제하는 동작
    을 더 포함하는 가상 머신을 실행하는 방법.
  9. 제 1 항에 있어서,
    상기 디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지의 위치를 획득하는 동작은, 상기 제 1 베이스 디스크 이미지의 URL을 획득하는 동작을 포함하는 가상 머신을 실행하는 방법.
  10. 가상 머신을 실행하는 전자 장치에 있어서,
    제 1 베이스 디스크 이미지를 저장하는 디스크 이미지 저장소와 통신 연결을 형성하는 통신 인터페이스; 및
    디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지의 위치를 획득하고, 상기 획득된 위치에 근거하여 상기 제 1 베이스 디스크 이미지를 참조(backing)하는 루트 디스크 이미지를 생성하며, 상기 생성된 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 프로세서
    를 포함하는 전자 장치.
  11. 제 10 항에 있어서,
    메모리
    를 더 포함하며,
    상기 통신 인터페이스는, 상기 디스크 이미지 저장소로부터 상기 제 1 베이스 디스크 이미지를 다운로드하며, 상기 메모리는 제 2 베이스 디스크 이미지를 저장하는 전자 장치.
  12. 제 11 항에 있어서,
    상기 프로세서는, 상기 다운로드가 완료되면, 상기 루트 디스크 이미지가 상기 제 2 베이스 디스크 이미지를 참조하도록 하는 전자 장치.
  13. 제 12 항에 있어서,
    상기 프로세서는, 데이터 입출력을 수행하는 오브젝트를 상기 제 1 베이스 디스크 이미지에 대응하는 제 1 오브젝트로부터 상기 제 2 베이스 디스크 이미지에 대응하는 제 2 오브젝트로 변경하는 전자 장치.
  14. 제 13 항에 있어서,
    상기 프로세서는, 상기 제 1 오브젝트로부터의 데이터 입출력을 중단하고, 상기 제 2 오브젝트로의 변경이 완료되면, 상기 제 2 오브젝트로부터의 데이터 입출력을 개시하는 전자 장치.
  15. 제 11 항에 있어서,
    상기 다운로드가 완료되면, 상기 프로세서는 상기 루트 디스크 이미지와 상기 제 2 베이스 디스크 이미지를 머지(merge)하여 머지드 디스크 이미지(merged disk image)를 생성하고, 상기 생성된 머지드 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 전자 장치.
  16. 제 15 항에 있어서,
    상기 프로세서는 제 2 베이스 디스크 이미지를 삭제하는 전자 장치.
  17. 제 11 항에 있어서,
    상기 다운로드가 완료되면, 상기 통신 인터페이스는 상기 디스크 이미지 저장소와의 연결을 해제하는 전자 장치.
  18. 제 10 항에 있어서,
    상기 프로세서는, 상기 제 1 베이스 디스크 이미지의 URL을 획득하여, 상기 획득된 URL에 근거하여 상기 제 1 베이스 디스크 이미지를 참조하도록 제어하는 전자 장치.
  19. 전자 장치에서 가상 머신을 실행하는 방법에 있어서,
    상기 전자 장치의 외부에 저장되는 제 1 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작;
    상기 루트 디스크 이미지의 참조 대상을 상기 제 1 베이스 디스크 이미지로부터 상기 전자 장치의 내부에 저장되는 제 2 베이스 디스크 이미지로 변경하는 동작; 및
    상기 제 2 베이스 디스크 이미지를 참조하는 상기 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작
    을 포함하는 가상 머신을 실행하는 방법.
  20. 제 19 항에 있어서,
    상기 참조 대상을 변경하는 동작은, 데이터 입출력을 수행하는 오브젝트를 상기 제 1 베이스 디스크 이미지에 대응하는 제 1 오브젝트로부터 상기 제 2 베이스 디스크 이미지에 대응하는 제 2 오브젝트로 변경하는 동작
    을 포함하는 가상 머신을 실행하는 방법.
  21. 가상 머신을 실행하는 전자 장치에 있어서,
    상기 전자 장치의 외부에 저장되는 제 1 베이스 디스크 이미지를 참조하는 통신 인터페이스; 및
    상기 제 1 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 프로세서
    를 포함하고,
    상기 프로세서는, 상기 루트 디스크 이미지의 참조 대상을 상기 제 1 베이스 디스크 이미지로부터 상기 전자 장치의 내부에 저장되는 제 2 베이스 디스크 이미지로 변경하고, 상기 제 2 베이스 디스크 이미지를 참조하는 상기 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 전자 장치.
  22. 제 21 항에 있어서,
    상기 프로세서는, 데이터 입출력을 수행하는 오브젝트를 상기 제 1 베이스 디스크 이미지에 대응하는 제 1 오브젝트로부터 상기 제 2 베이스 디스크 이미지에 대응하는 제 2 오브젝트로 변경하는 전자 장치.
  23. 전자 장치에서 가상 머신을 실행하는 방법에 있어서,
    상기 전자 장치의 외부에 저장되는 제 1 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작;
    상기 제 1 베이스 디스크 이미지를 다운로드 하여, 상기 전자 장치의 내부에 제 2 베이스 디스크 이미지를 저장하는 동작;
    상기 다운로드가 완료되면, 상기 루트 디스크 이미지와 상기 제 2 베이스 디스크 이미지를 머지(merge)하여 머지드 디스크 이미지(merged disk image)를 생성하는 동작; 및
    상기 생성된 머지드 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 동작
    을 포함하는 가상 머신을 실행하는 방법.
  24. 제 23 항에 있어서,
    상기 루트 디스크 이미지는 쓰기 전용 디스크 이미지인 가상 머신을 실행하는 방법.
  25. 가상 머신을 실행하는 전자 장치에 있어서,
    상기 전자 장치의 외부에 저장되는 제 1 베이스 디스크 이미지를 참조하는 통신 인터페이스;
    상기 제 1 베이스 디스크 이미지를 참조하는 루트 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 프로세서; 및
    상기 제 1 베이스 디스크 이미지를 다운로드 하여, 제 2 베이스 디스크 이미지를 저장하는 메모리;
    를 포함하고,
    상기 프로세서는, 상기 다운로드가 완료되면, 상기 루트 디스크 이미지와 상기 제 2 베이스 디스크 이미지를 머지(merge)하여 머지드 디스크 이미지(merged disk image)를 생성하고, 상기 생성된 머지드 디스크 이미지에 근거하여 상기 가상 머신을 실행하는 전자 장치.
  26. 제 25 항에 있어서,
    상기 루트 디스크 이미지는 쓰기 전용 디스크 이미지인 전자 장치.
  27. 전자 장치의 화면 구성 방법에 있어서,
    제 1 환경에 근거한 제 1 화면을 표시하는 동작;
    상기 제 1 환경으로부터 제 2 환경으로의 변경을 요청하는 환경 변경 명령을 획득하는 동작;
    상기 제 2 환경에 대응하는 베이스 디스크 이미지의 위치를 획득하는 동작;
    상기 베이스 디스크 이미지를 참조하는 루트 디스크 이미지를 생성하는 동작; 및
    상기 루트 디스크 이미지에 근거하여 가상 머신을 실행함으로써, 상기 제 2 환경에 근거한 제 2 화면을 표시하는 동작
    을 포함하는 화면 구성 방법.
  28. 제 27 항에 있어서,
    상기 제 1 환경은 제 1 OS(operating system) 또는 제 1 모드에 대한 것이며, 상기 제 2 환경은, 제 2 OS(operating system) 또는 제 2 모드에 대한 것인 화면 구성 방법.
  29. 제 1 환경에 근거한 제 1 화면을 표시하는 디스플레이;
    상기 제 1 환경으로부터 제 2 환경으로의 변경을 요청하는 환경 변경 명령을 획득하는 입출력 인터페이스;
    상기 제 2 환경에 대응하는 베이스 디스크 이미지의 위치를 획득하고, 상기 베이스 디스크 이미지를 참조하는 루트 디스크 이미지를 생성하고, 상기 루트 디스크 이미지에 근거하여 가상 머신을 실행함으로써, 상기 제 2 환경에 근거한 제 2 화면을 표시하도록 제어하는 프로세서
    를 포함하는 전자 장치.
  30. 제 29 항에 있어서,
    상기 제 1 환경은 제 1 OS(operating system) 또는 제 1 모드에 대한 것이며, 상기 제 2 환경은, 제 2 OS(operating system) 또는 제 2 모드에 대한 것인 전자 장치.
  31. 전자 장치에서 가상 머신을 실행하는 방법에 있어서,
    디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지를 참조하여 가상 머신을 실행하는 동작; 및
    상기 제 1 베이스 디스크 이미지를, 상기 참조와 병렬적으로 다운로드하는 동작
    을 포함하는 가상 머신을 실행하는 방법.
  32. 가상 머신을 실행하는 전자 장치에 있어서,
    디스크 이미지 저장소에 저장된 제 1 베이스 디스크 이미지를 참조하여 가상 머신을 실행하는 프로세서; 및
    상기 제 1 베이스 디스크 이미지를, 상기 참조와 병렬적으로 다운로드하는 통신 인터페이스
    를 포함하는 전자 장치.
KR1020140132463A 2014-07-24 2014-10-01 가상 머신을 실행하는 전자 장치 및 가상 머신을 실행하는 방법 KR20160012863A (ko)

Priority Applications (2)

Application Number Priority Date Filing Date Title
US14/807,408 US20160026492A1 (en) 2014-07-24 2015-07-23 Electronic apparatus for executing virtual machine and method for executing virtual machine
PCT/KR2015/007740 WO2016013906A1 (en) 2014-07-24 2015-07-24 Electronic apparatus for executing virtual machine and method for executing virtual machine

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US201462028593P 2014-07-24 2014-07-24
US62/028,593 2014-07-24

Publications (1)

Publication Number Publication Date
KR20160012863A true KR20160012863A (ko) 2016-02-03

Family

ID=55355809

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020140132463A KR20160012863A (ko) 2014-07-24 2014-10-01 가상 머신을 실행하는 전자 장치 및 가상 머신을 실행하는 방법

Country Status (1)

Country Link
KR (1) KR20160012863A (ko)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20180087278A (ko) * 2016-12-28 2018-08-01 핑안 테크놀로지 (션젼) 컴퍼니 리미티드 가상 머신의 신속한 복원 방법, 장치 및 시스템
KR102313826B1 (ko) * 2021-06-03 2021-10-19 주식회사 이스트림 저장 미디어를 이용한 it 시스템 서비스 제공 방법

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20180087278A (ko) * 2016-12-28 2018-08-01 핑안 테크놀로지 (션젼) 컴퍼니 리미티드 가상 머신의 신속한 복원 방법, 장치 및 시스템
KR102313826B1 (ko) * 2021-06-03 2021-10-19 주식회사 이스트림 저장 미디어를 이용한 it 시스템 서비스 제공 방법

Similar Documents

Publication Publication Date Title
US11442580B2 (en) Screen configuration method, electronic device, and storage medium
US20180107353A1 (en) Electronic device and method for playing multimedia content by electronic device
US10318328B2 (en) Method for managing operating system and electronic device supporting the same
US10416843B2 (en) Electronic device and method of controlling object in electronic device
EP3121700B1 (en) Electronic device and method for managing objects in recommended folders
US10254883B2 (en) Electronic device for sensing pressure of input and method for operating the electronic device
US20160142703A1 (en) Display method and electronic device
US11093049B2 (en) Electronic device and method for controlling display in electronic device
US20160026492A1 (en) Electronic apparatus for executing virtual machine and method for executing virtual machine
US20170046123A1 (en) Device for providing sound user interface and method thereof
KR20160100760A (ko) 어플리케이션을 설치하는 전자 장치 및 그 제어 방법
KR102586628B1 (ko) 전자 장치 및 전자 장치의 메모리 관리 방법
US10466856B2 (en) Electronic device having two displays and a method for executing a different application on each display of the electronic device based on simultaneous inputs into a plurality of application icons
US20190212858A1 (en) Flexible device and operation method of flexible device
US20160098082A1 (en) Electronic device and method of controlling display of electronic device
US20180129409A1 (en) Method for controlling execution of application on electronic device using touchscreen and electronic device for the same
EP2993901A1 (en) Method for displaying images and electronic device thereof
KR20160125783A (ko) 컨텐츠를 표시하기 위한 방법 및 전자 장치
US10582156B2 (en) Electronic device for performing video call and computer-readable recording medium
US20170017373A1 (en) Electronic device and method for controlling the same
KR102320149B1 (ko) 어플리케이션을 실행하는 전자 장치 및 그 제어 방법
US10334173B2 (en) Electronic device and method for editing image in electronic device
KR20160012863A (ko) 가상 머신을 실행하는 전자 장치 및 가상 머신을 실행하는 방법
KR20160068531A (ko) 어플리케이션 제어 방법 및 전자 장치
US20160253072A1 (en) Method and apparatus for displaying function execution screens

Legal Events

Date Code Title Description
WITN Withdrawal due to no request for examination