KR101587994B1 - 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템 - Google Patents

하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템 Download PDF

Info

Publication number
KR101587994B1
KR101587994B1 KR1020150090726A KR20150090726A KR101587994B1 KR 101587994 B1 KR101587994 B1 KR 101587994B1 KR 1020150090726 A KR1020150090726 A KR 1020150090726A KR 20150090726 A KR20150090726 A KR 20150090726A KR 101587994 B1 KR101587994 B1 KR 101587994B1
Authority
KR
South Korea
Prior art keywords
client terminal
boot
cloud server
auxiliary storage
external auxiliary
Prior art date
Application number
KR1020150090726A
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 KR1020150090726A priority Critical patent/KR101587994B1/ko
Application granted granted Critical
Publication of KR101587994B1 publication Critical patent/KR101587994B1/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
    • 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/4401Bootstrapping
    • G06F9/4406Loading of operating system
    • 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/4401Bootstrapping
    • G06F9/4416Network booting; Remote initial program loading [RIPL]

Landscapes

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

Abstract

하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템이 개시된다. 이 시스템은 운영체제 이미지를 포함하는 복수의 이미지 파일을 저장하는 클라우드 서버, 및 접속된 외부 보조 저장 장치에 저장된 부팅 루틴으로 초기 부팅하고, 외부 보조 저장 장치에 저장된 원격 부팅을 위한 환경 설정 정보를 이용하여 클라우드 서버로 접속하여 해당 이미지 파일을 획득하며, 획득된 이미지 파일에 포함된 OS 이미지를 실행하는 클라이언트 단말을 포함한다.

Description

하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템{Cloud computing service system with virtual hard disk}
본 발명은 클라우드 컴퓨팅 서비스 시스템에 관한 것으로, 특히 컴퓨터의 운영체제를 클라우드 환경에서 클라이언트 단말에 제공하는 클라우드 컴퓨팅 서비스 시스템에 관한 것이다.
최근 초고속 정보통신망의 확산으로 네트워크 환경이 고속화됨에 따라 사용자들은 대용량의 데이터를 클라우드 서비스를 제공하는 서버에 저장하거나 내려받아 사용하는 것이 일반적인 상황이다. 종래 기술에 의한 클라우드 시스템은 데스크톱 가상화(Desktop Virtualization) 방식으로 클라이언트에게 서비스를 제공할 때 네트워크에 상당한 부하를 주며, 이로 인해 다수의 사용자가 대용량의 서비스, 예를 들어 동영상 교육, 인터넷 방송 청취 등을 실시간으로 이용하는 것이 불가능한 상황이다.
이에 반해, 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템은 서버에 저장된 운영체제만 클라이언트에게 제공하고, 클라이언트는 CPU, 메모리, 그래픽카드를 내장한 클라이언트 단말을 활용하여 네트워크의 부하를 줄여준다. 하드디스크 가상화(Virtual Hard Disk, VHD)에 대해 살펴보면, 사용자의 PC를 가상화하여 원격 서버에 보관하고 이와 호환 가능한 PC를 이용하여 인터넷을 통해 운영체제를 전송받아 시간과 장소에 구애받지 않고 동일한 작업환경으로 이동형 컴퓨팅이 가능한 솔루션이라 할 수 있다.
그런데 종래의 하드디스크 가상화 방식은 서버에 저장된 운영체제를 일방적으로 클라이언트 단말에 제공하기 때문에, 클라이언트 단말의 환경에 따른 다양한 운영체제를 클라이언트 단말에서 사용할 수 있는 문제가 발생하였다. 이로 인해, 동일한 네트워크 대역(LAN 환경)과 동일한 하드웨어(컴퓨터 사양)를 가진 컴퓨터를 대상으로만 서비스가 가능했다. 즉, 도 1에서 PXE(Preboot eXecution Environment) 클라이언트의 DHCP(Dynamic Host Configuration Protocol) discovery가 로컬 네트워크에서만 broadcasting 되므로, 라우터를 넘어서 존재하는 DHCP 서버를 이용하여 서비스하는 것이 불가능하였다.
종래 하드디스크 가상화 방식의 부팅 프로세스는 PXE를 구현한 네트워크 부트 펌웨어가 랜카드를 초기화하고 네트워크 스택을 로드한다. 그 다음, iSCSI boot initiator를 실행하고 서버의 iSCSI target에 로그온한 후 시스템에 부팅 디스크 이미지를 마운트한다. iSCSI boot initiator는 윈도(Window)의 iSCSI Initiator에게 iBFT(iSCSI Boot Firmware Table) 정보를 넘겨주고, 이에 따라 나머지 부팅 과정이 진행된다. 이때, 서버에서 디스크 이미지 전체를 로컬 시스템에 전부 내려받는 것이 아니라 가상 디스크를 마운트하기 위한 정보와 부팅에 필요한 최소한의 파일만 읽어오고 나머지는 네트워크에서 읽기/쓰기를 하며 사용한다. 참고로, 윈도에 포함된 iSCSI Initiator는 서버에서 특정 디스크 이미지에 연결해서 운영체제에서 마치 로컬 시스템에 하드디스크가 있는 것과 동일하게 사용할 수 있도록 하는 서비스이다.
도 1을 살펴보면, PXE 클라이언트는 로컬 네트워크에 존재하는 DHCP 서버를 탐색하기 위해 DHCP discovery를 브로드캐스팅한다(S10). DHCP 서버는 DHCP discovery에 대한 응답으로, PXE 클라이언트에 할당할 IP 주소와 서브넷 마스크를 PXE 클라이언트로 전달한다(S20). 또한, DHCP 서버는 TFTP(Trivial File Transfer Protocol) 서버의 주소와 NBP(Network Bootstrap Program) name을 PXE 클라이언트로 전달하는데(S20), TFTP 서버의 주소와 NBP name은 PXE 클라이언트에서 IP 주소와 서브넷 마스크 설정 후 전달될 수 있다. PXE 클라이언트는 TFTP 서버로부터 전달받은 TFTP 서버의 주소를 이용하여 TFTP 서버에 접속하고 NBP name을 TFTP 서버에 제공하며, TFTP 서버는 부팅 이미지인 NBP 이미지를 클라이언트 단말로 전달한다(S30). PXE 클라이언트는 부팅 이미지를 이용하여 부팅을 개시하고 PXE 서버에 접속하여 로그인, 연결 설정, 및 OS 이미지 파일을 내려받아 실행하는 과정을 수행한다(S40).
이상과 같은 종래의 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템은 네트워크에 접속하는 PXE 클라이언트에 TFTP 관련 정보를 제공하기 위한 DHCP 서버와, 클라이언트 단말의 부팅 파일을 제공하기 위한 TFTP 서버를 설치해야 한다. 이로 인해, 종래의 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템은 클라이언트 단말이 광대역 통신망(Wide Area Network, WAN)에서 능동적으로 클라우드 서버에 원격 접속 및 원격 부팅하는 서비스가 불가능했다. 즉, 동일한 라우터에 연결된 컴퓨터들로 구성되는 로컬 네트워크 내에서만 가능하고, 그 라우터를 넘어서는 글로벌 네트워크에 있는 컴퓨터들은 서비스가 불가능했다.
본 발명은 클라이언트 단말의 환경에 따른 다양한 운영체제를 클라이언트 단말에서 사용할 있도록 하는 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템을 제공하는 것을 목적으로 한다.
또한, 본 발명은 광역 네트워크 환경에서도 서비스 가능한 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템을 제공하는 것을 또다른 목적으로 한다.
또한, 본 발명은 클라이언트 단말별로 이미지 파일을 달리 제공함으로써 서비스의 내용을 구별하거나 제한하는 것을 또다른 목적으로 한다.
일 양상에 따른 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템은 운영체제 이미지를 포함하는 복수의 이미지 파일을 저장하는 클라우드 서버, 및 접속된 외부 보조 저장 장치에 저장된 부팅 루틴으로 초기 부팅하고, 외부 보조 저장 장치에 저장된 원격 부팅을 위한 환경 설정 정보를 이용하여 클라우드 서버로 접속하여 해당 이미지 파일을 획득하며, 획득된 이미지 파일에 포함된 OS 이미지를 실행하는 클라이언트 단말을 포함한다.
일 양상에 따르면, 이미지 파일은 하나 이상의 응용 프로그램 및 데이터를 더 포함한다.
일 양상에 따르면, 클라우드 서버는 클라이언트별로 맞춤형 이미지 파일을 관리한다.
일 양상에 따르면, 클라우드 서버에 저장된 이미지 파일은 클라이언트별로 운영체제, 응용 프로그램 및 데이터 중 적어도 하나가 상이하다.
일 양상에 따르면, 클라우드 서버는 클라이언트 단말의 접속 날짜와 시간을 고려하여 해당 이미지 파일을 제공한다.
일 양상에 따르면, 클라이언트 단말은 획득한 이미지 파일을 변경할 경우에 그 변경 내용이 반영된 이미지 파일을 클라우드 서버에 저장한다.
일 양상에 따르면, 클라이언트 단말에 접속된 상태에서 클라이언트 단말의 부팅을 위한 부팅 모듈을 포함하는 외부 보조 저장 장치를 더 포함한다.
일 양상에 따르면, 외부 보조 저장 장치는 클라이언트 단말에 USB(Universal Serial Bus) 접속된다.
일 양상에 따르면, 부팅 모듈은 클라이언트 단말의 원격 부팅이 불가할 경우에 외부 보조 저장 장치에 저장된 비상용 운영체제로 클라이언트 단말의 부팅을 유도한다.
일 양상에 따르면, 부팅 모듈은 외부 보조 저장 장치가 클라이언트 단말에 접속시 최초로 실행되어 초기 부팅 루틴을 처리하는 초기부팅 처리부, 및 초기부팅 처리부의 리디렉션(redirection)에 의해 클라이언트 단말의 원격 부팅을 위한 환경을 설정하는 원격부팅 처리부를 포함한다.
일 양상에 따르면, 초기부팅 처리부는 외부 보조 저장 장치의 시리얼번호와 그 장치의 시스템 고유 사용자 식별자(Unique User Identifiers)를 체크하여 인증된 경우에만 초기 부팅 루틴을 처리한다.
일 양상에 따르면, 초기부팅 처리부는 초기 부팅 루틴 처리 후 원격 부팅 처리부로 부팅을 리디렉션하되, 비상시 클라이언트 단말의 로컬 부팅을 위해 외부 보조 저장 장치에 저장된 비상용 운영체제를 선택한다.
일 양상에 따르면, 원격 부팅을 위한 환경 설정 정보는 클라우드 서버의 주소와 클라우드 서버로의 접속 인증을 위한 사용자 계정 정보를 포함한다.
일 양상에 따르면, 원격부팅 처리부는 클라이언트 단말과 클라우드 서버 간의 네트워크 장애가 발생한 경우, 로컬 부팅을 위해 외부 보조 저장 장치에 저장된 비상용 운영체제를 선택한다.
일 양상에 따르면, 원격부팅 처리부는 원격 부팅 완료 후 클라이언트 단말과 클라우드 서버 간의 네트워크 장애가 발생한 경우, 클라우드 서버에 기록하는 캐쉬 및 데이터 값을 외부 보조 저장 장치에 임시로 기록한다.
본 발명에 따른 일반적인 PXE 응용에서 LAN에 국한되는 제약사항을 극복하고 WAN으로 공간을 확대함과 동시에 사전 설정을 최소화하여 이동성을 극대화할 수 있다.
본 발명의 하드디스크 가상화 방식의 클라우드 컴퓨팅 시스템은 클라이언트의 환경에 적합한 운영체제를 클라이언트 컴퓨터에서 선택할 수 있고, 각 클라이언트는 별도의 상용소프트웨어(예, 한글, 오피스, 포토샵 등)및 그룹웨어(ERP) 등을 설치하고, OS의 업데이트 등 자신의 환경과 용도에 맞게 OS를 포함하는 설치될 프로그램의 이미지를 변경하여 클라우드 서비스 서버에 저장하고, 언제 어디서든 클라이언트가 직접 자신의 이미지를 직접 선택하여 사용할 수 있는 능동적인 클라우드 시스템 환경을 제공할 수 있다.
또한, 별도의 부팅 장치를 이용하여 서버에 접속하는 클라이언트의 구분이 가능하기 때문에, 서버에서 배포하는 OS 이미지를 선택 없이 받아서 사용하는 수동적 클라이언트와 서버에 보관중인 OS 이미지를 자신의 상황에 맞게 선택하고 이를 변경하여 언제 어디서든 사용할 수 있는 능동적 사용자로 구분할 수 있다. 즉, 기존 방식과 호환 가능하며, 기존 방식에 추가로 적용이 가능하다.
도 1은 종래 하드디스크 가상화 방식의 부팅 프로세스를 도면이다.
도 2는 일 실시예에 따른 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템의 블록도이다.
도 3은 클라우드 서버에 저장된 클라이언트 맞춤형 이미지 파일을 예시한 도면이다.
도 4는 일 실시예에 따른 부팅 모듈의 동작을 나타낸 도면이다.
도 5는 일 실시예에 따른 부팅 프로세스를 나타낸 도면이다.
전술한, 그리고 추가적인 본 발명의 양상들은 첨부된 도면을 참조하여 설명되는 바람직한 실시예들을 통하여 더욱 명백해질 것이다. 이하에서는 본 발명을 이러한 실시예를 통해 당업자가 용이하게 이해하고 재현할 수 있도록 상세히 설명하기로 한다.
도 2는 일 실시예에 따른 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템의 블록도이다. 클라우드 서버(100)는 클라이언트 단말(300)에 제공할 이미지 파일을 저장하고 관리하는 서버로서, iSCSI 이미지 서버일 수 있다. 잘 알려진 바와 같이, iSCSI(Internet Small Computer Systems Interface)는 PXE 환경에서 사용되는 IP기반 네트워크상에서 디스크 데이터를 전송하는 프로토콜이다. 일 실시예에 있어서, 클라우드 서버(100)는 메인 서버와 백업용 서브 서버로 이중화될 수 있다. 클라우드 서버(100)는 클라이언트 단말(300)을 원격 부팅시키기 위한 운영체제(Operating System, OS) 이미지를 포함하는 복수의 이미지 파일을 저장하고 관리한다. 이미지 파일들에 속한 OS 이미지들은 상이할 수 있다. 이는 클라이언트 단말(300)의 자원 환경에 따라 적용 가능한 운영체제가 다르기 때문이다. 이미지 파일은 운영체제 외에 마이크로소프트 오피스(Microsoft Office), 어도비 포트샵(Adobe Photoshop) 등의 응용 프로그램을 더 포함할 수 있다. 그리고 클라우드 서버(100)는 클라우드 스토리지(200)에 사용자가 작업한 문서 등의 사용자 데이터를 저장하고 관리할 수 있으며, 클라우드 스토리지(200)를 통해 클라이언트별 저장공간을 지원할 수 있다.
일 실시예에 있어서, 클라우드 서버(100)는 클라이언트별로 맞춤형 이미지 파일을 관리한다. 도 3에 도시된 바와 같이, 클라우드 서버(100)는 클라이언트별로 서로 다른 이미지 파일을 관리할 수 있다. 그리고 원격 부팅을 위해 접속한 클라이언트 단말(300)을 식별하여 해당되는 이미지 파일을 제공한다. 즉, 클라이언트별로 맞춤형 이미지 파일을 제공하는 것이다. 클라이언트별 맞춤형 이미지 파일은 운영 체제와 응용 프로그램 중 적어도 하나가 상이할 수 있다. 그리고 클라우드 서버(100)는 클라이언트 단말(300)의 식별자(Identification, ID)로 식별하거나, 클라이언트(사용자) 인증시 사용되는 사용자 ID로 식별할 수도 있다. 나아가, 클라우드 서버(100)는 클라이언트 단말(300)의 접속 날짜와 접속 시간을 고려하여 맞춤형 이미지 파일을 제공할 수 있다. 예를 들어, 학교나 학원을 위한 클라우드 컴퓨팅 서비스 시스템을 구현할 경우, 클라우드 서버(100)는 수업시간에 따라 아래 표 1에 예시된 바와 같이 맞춤형 패키지를 제공할 수 있다. 따라서, 클라이언트 단말(300) 입장에서는 수업시간에 맞춰 리부트 함으로써 수업시간에 맞는 이미지 파일을 내려받을 수 있다.
Figure 112015061817946-pat00001
다른 실시예에 있어서, 클라우드 서버(100)는 클라이언트별로 맞춤형 이미지 파일을 관리하지는 않고 클라이언트 단말(300)의 원격 부팅을 위한 접속시 클라이언트 단말(300)의 자원 환경을 파악하여 맞춤형 이미지 파일을 제공할 수 있다. 여기서 클라이언트 단말(300)의 자원 환경은 CPU, 그래픽 카드, 메모리 등의 구체 사양(specification) 정보를 의미할 수 있다. 클라이언트 단말(300)은 원격 부팅을 위한 접속시 클라우드 서버(100)에 자신의 자원 정보를 제공하며, 이에 클라우드 서버(100)는 클라이언트 단말(300)의 자원 정보에 근거하여 맞춤형 이미지 파일을 제공할 수 있다. 혹은 클라우드 서버(100)는 사용자가 직접 선택하는 이미지 파일을 제공할 수도 있다. 또한, 클라우드 서버(100)는 클라이언트 단말(300)의 접속 날짜와 접속 시간을 고려하여 표 1과 같은 맞춤형 이미지 파일을 제공할 수도 있다.
클라이언트 단말(300)은 하드디스크 없는(Diskless) 단말로서, 원격 부팅을 위해 필요한 네트워크 인터페이스 카드 및 네트워크 드라이버를 포함한다. 기존과 달리, 클라이언트 단말(300)은 원격 부팅을 위해 로컬 네트워크 내에 존재하는 DHCP 서버로부터 TFTP 서버의 주소를 획득하고, 역시 동일 로컬 네트워크 내에 존재하는 TFTP 서버에 접속하여 NBP를 획득하는 절차를 수행하지 않는다. 대신에, 클라이언트 단말(300)은 외부 보조 저장 장치(400)를 이용하여 원격 부팅을 수행한다. 클라이언트 단말(300)은 접속된 외부 보조 저장 장치(400)에 저장된 부팅 루틴을 이용하여 초기 부팅하고, 초기 부팅이 완료되면 외부 보조 저장 장치(400)에 저장된 원격 부팅을 위한 환경 설정 정보를 이용하여 클라우드 서버(100)로 접속하여 해당 이미지 파일을 획득하며, 획득된 이미지 파일에 포함된 OS 이미지를 이용하여 원격 부팅한다.
외부 보조 저장 장치(400)는 클라이언트 단말(300)과 통신할 수 있는 장치이다. 외부 보조 저장 장치(400)는 클라이언트 단말(300)에 접속하기 위한 단말 접속부(410)와 부팅 모듈을 저장한 저장부(420)를 포함한다. 외부 보조 저장 장치(400)는 단말 접속부(410)를 통해 또는 무선으로 클라이언트 단말(300)에 접속할 수 있다. 일 실시예에 있어서, 외부 보조 저장 장치(400)는 클라이언트 단말(300)에 USB(Universal Serial Bus) 접속될 수 있다. 다른 실시예에 있어서, 외부 보조 저장 장치(400)는 클라이언트 단말(300)에 와이파이(wireless Fidelity, Wi-Fi) 접속될 수 있다.
외부 보조 저장 장치(400)의 저장부(420)에는 부팅 모듈(430)이 저장된다. 부팅 모듈(430)은 클라이언트 단말(300)에 접속된 상태에서 클라이언트 단말(300)의 전원이 온 되면 클라이언트 단말(300)을 원격 부팅시키기 위한 부팅 처리를 수행한다. 만일 원격 부팅이 불가한 비상시의 경우, 예를 들어 네트워크가 단절되어 클라이언트 단말(300)이 클라우드 서버(100)로의 네트워크 연결이 불가한 경우, 부팅 모듈(430)은 외부 보조 저장 장치(400)에 저장된 비상용 운영체제로 클라이언트 단말(300)의 부팅을 유도한다.
부팅 모듈(430)은 초기부팅 처리부(431)와 원격부팅 처리부(432)를 포함한다. 초기부팅 처리부(431)는 초기 부팅 루틴을 수행하는 부트로더이며, GRUB일 수 있다. 그리고 원격부팅 처리부(432)는 iPXE+ 일 수 있다. 초기부팅 처리부(431)는 부트로더로서의 기본 기능, 즉 초기 부팅 루틴을 처리한다. 이 처리 과정에는 iPXE+ 관련 기능을 실행시키는 과정이 포함될 수 있다. 초기부팅 처리부(431)는 초기 부팅 루틴 처리 후 원격부팅 처리부(432)로 부팅을 리디렉션(redirection) 한다. 초기 부팅 루틴 처리 전에, 초기부팅 처리부(431)는 외부 보조 저장 장치(400)를 인증할 수 있다. 일 실시예에 있어서, 초기부팅 처리부(431)는 시리얼번호와 장치 시스템의 고유 사용자 식별자(Unique User Identifiers, UUDI)를 체크하여 복제와 같은 비정상적인 사용을 방지한다. 또한, 초기부팅 처리부(431)는 네트워트 단절 등의 비상시에 원격 부팅 대신에 로컬 부팅을 위해 원격부팅 처리부(432)로의 redirection 대신에 외부 보조 저장 장치(400)에 저장된 비상용 운영체제(440)를 선택할 수 있다. 비상용 운영체제(440)는 최소화된 운영체제인 윈도 PE(Preinstallation Environment)일 수 있다.
원격부팅 처리부(432)는 diskless 부팅의 핵심 기능을 제공한다. 첫째로, 원격부팅 처리부(432)는 원격부팅에 관련된 환경설정을 한다. 원격 부팅을 위한 환경 설정 정보에는 클라우드 서버(100)의 주소, IP 설정 방식, 클라우드 서버(100)로의 접속 인증을 위한 사용자 계정 정보 등이 포함된다. 둘째로, 네트워크 관련 초기화 후에 클라이언트 단말(300)이 클라우드 서버(100)로의 연결시 장애가 있을 경우에 외부 보조 저장 장치(400)에 저장된 비상용 운영체제(440)를 선택하여 비상용 운영체제(440)로 부팅을 유도한다. 셋째, 설정된 사용자 계정으로 로그인하여 클라우드 서버(100)에서 인증한다. 넷째, 복수의 운영체제 선택 메뉴를 제공한다. 이에 사용자는 어느 하나의 운영체제를 선택하여 원격 부팅할 수 있다. 다섯째, 클라우드 서버(100)에 저장된 이미지의 데이터를 계속 사용할지 아니면 초기화한 후 사용할지 선택 메뉴를 제공한다. 이에 사용자는 선택을 통해 이미지의 데이터를 초기화하여 사용하거나 계속 사용할 수 있다. 나아가, 원격부팅 처리부(432)는 원격 부팅 완료 후 클라이언트 단말(300)과 클라우드 서버(100) 간에 네트워크 장애가 발생한 경우, 클라우드 서버(100)에 기록하는 캐쉬 및 데이터 값을 외부 보조 저장 장치(400)에 임시로 기록하여 일정시간 컴퓨팅이 가능하도록 할 수 있다.
도 4는 일 실시예에 따른 부팅 모듈의 동작을 나타낸 도면이다. GRUB은 GRUB는 다양한 환경에 멀티부트 기능을 제공하는 오픈소스 부트로더이며, PXE는 시스템 관리 목적으로 인텔에 의해 확립된 네트워크 부팅 표준이다. iPXE는 PXE에 오픈소스 기반의 부가 기능을 더해 확장된 개념이며, iPXE+는 iPXE에 Inprontive의 솔루션이 추가 수정된 확장 버전이다. GRUB와 iPXE는 부팅된 윈도 운영체제 환경에서 보이지 않는 숨겨진 영역이다. 그리고 윈도 PE는 윈도 OS의 설치 및 복구 등에 사용될 수 있도록 한 최소화된 윈도 운영체제이다. GRUB은 부트로더의 역할을 하며, iPXE+로 부팅의 동적 리디렉션을 담당한다. 비상시에는 윈도 PE로 로컬 부팅을 할 수 있는 멀티부트 기능을 가진다. iPXE+는 원격 부팅을 위해 iPXE.lkrn을 이용하여 iSCSI Image Server로 접속한다. iPXE+ 역시 윈도 PE로 로컬 부팅을 할 수 있는 멀티 부트 기능을 가진다. 윈도 PE는 클라우드 서버(100)와의 데이터 동기화를 위해, 네트워크 복구시 데이터를 iSCSI Image Server로 전달한다.
도 5는 일 실시예에 따른 부팅 프로세스를 나타낸 도면이다. 클라이언트 단말(300)은 DHCP Discovery를 broadcasting한다(S100). DHCP 서버(500)는 DHCP discovery에 대한 응답으로, 클라이언트 단말(300)에 할당할 IP 주소와 서브넷 마스크를 클라이언트 단말(300)로 전달한다(S200). 클라이언트 단말(300)은 외부 보조 저장 장치(400)에 저장된 초기 부팅 루틴으로 부팅하며, 원격 부팅을 위한 환경설정 정보도 외부 보조 저장 장치(400)에서 획득한다(S300). 클라이언트 단말(300)은 획득한 원격 부팅용 환경설정 정보를 이용하여 클라우드 서버(100)에 접속하고 OS 이미지를 획득하고 실행하여 풀 부팅을 수행한다(S400).
이제까지 본 발명에 대하여 그 바람직한 실시예들을 중심으로 살펴보았다. 본 발명이 속하는 기술 분야에서 통상의 지식을 가진 자는 본 발명이 본 발명의 본질적인 특성에서 벗어나지 않는 범위에서 변형된 형태로 구현될 수 있음을 이해할 수 있을 것이다. 그러므로 개시된 실시예들은 한정적인 관점이 아니라 설명적인 관점에서 고려되어야 한다. 본 발명의 범위는 전술한 설명이 아니라 특허청구범위에 나타나 있으며, 그와 동등한 범위 내에 있는 모든 차이점은 본 발명에 포함된 것으로 해석되어야 할 것이다.
100 : 클라우드 서버 200 : 클라우드 스토리지
300 : 클라이언트 단말 400 : 외부 보조 저장 장치
410 : 단말 접속부 420 : 저장부
430 : 부팅 모듈 431 : 초기부팅 처리부
432 : 원격부팅 처리부 440 : 비상용 운영체제

Claims (15)

  1. 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템에 있어서,
    운영체제(Operating System, OS) 이미지를 포함하는 복수의 이미지 파일을 저장하는 클라우드 서버;
    클라우드 서버로부터 획득된 이미지 파일에 포함된 OS 이미지를 실행하는 클라이언트 단말; 및
    클라이언트 단말에 접속되는 외부 보조 저장 장치;를 포함하되,
    클라이언트 단말은 접속된 외부 보조 저장 장치에 저장된 부팅 루틴으로 초기 부팅하고, 외부 보조 저장 장치에 저장된 원격 부팅을 위한 환경 설정 정보를 이용하여 클라우드 서버로 접속하여 해당 이미지 파일을 획득하며,
    외부 보조 저장 장치는 외부 보조 저장 장치가 클라이언트 단말에 접속시 최초로 실행되어 초기 부팅 루틴을 처리하는 초기부팅 처리부, 및 초기부팅 처리부의 리디렉션(redirection)에 의해 클라이언트 단말의 원격 부팅을 위한 환경을 설정하는 원격부팅 처리부를 포함하는 부팅 모듈을 포함하는 클라우드 컴퓨팅 서비스 시스템.
  2. 제 1 항에 있어서,
    이미지 파일은 하나 이상의 응용 프로그램 및 데이터를 더 포함하는 클라우드 컴퓨팅 서비스 시스템.
  3. 제 2 항에 있어서,
    클라우드 서버는 클라이언트별로 맞춤형 이미지 파일을 관리하는 클라우드 컴퓨팅 서비스 시스템.
  4. 제 3 항에 있어서,
    클라우드 서버에 저장된 이미지 파일은 클라이언트별로 운영체제, 응용 프로그램 및 데이터 중 적어도 하나가 상이한 클라우드 컴퓨팅 서비스 시스템.
  5. 제 3 항에 있어서,
    클라우드 서버는 클라이언트 단말의 접속 날짜와 시간을 고려하여 해당 이미지 파일을 제공하는 클라우드 컴퓨팅 서비스 시스템.
  6. 제 1 항에 있어서,
    클라이언트 단말은 획득한 이미지 파일을 변경할 경우에 그 변경 내용이 반영된 이미지 파일을 클라우드 서버에 저장하는 클라우드 컴퓨팅 서비스 시스템.
  7. 삭제
  8. 제 1 항에 있어서,
    외부 보조 저장 장치는 클라이언트 단말에 USB(Universal Serial Bus) 접속되는 클라우드 컴퓨팅 서비스 시스템.
  9. 제 1 항에 있어서,
    부팅 모듈은 클라이언트 단말의 원격 부팅이 불가할 경우에 외부 보조 저장 장치에 저장된 비상용 운영체제로 클라이언트 단말의 부팅을 유도하는 클라우드 컴퓨팅 서비스 시스템.
  10. 삭제
  11. 제 1 항에 있어서,
    초기부팅 처리부는 외부 보조 저장 장치의 시리얼번호와 그 장치의 시스템 고유 사용자 식별자(Unique User Identifiers)를 체크하여 인증된 경우에만 초기 부팅 루틴을 처리하는 클라우드 컴퓨팅 서비스 시스템.
  12. 제 1 항에 있어서,
    초기부팅 처리부는 초기 부팅 루틴 처리 후 원격 부팅 처리부로 부팅을 리디렉션하되, 비상시 클라이언트 단말의 로컬 부팅을 위해 외부 보조 저장 장치에 저장된 비상용 운영체제를 선택하는 클라우드 컴퓨팅 서비스 시스템.
  13. 제 1 항에 있어서,
    원격 부팅을 위한 환경 설정 정보는 클라우드 서버의 주소와 클라우드 서버로의 접속 인증을 위한 사용자 계정 정보를 포함하는 클라우드 컴퓨팅 서비스 시스템.
  14. 제 1 항에 있어서,
    원격부팅 처리부는 클라이언트 단말과 클라우드 서버 간의 네트워크 장애가 발생한 경우, 로컬 부팅을 위해 외부 보조 저장 장치에 저장된 비상용 운영체제를 선택하는 클라우드 컴퓨팅 서비스 시스템.
  15. 제 1 항에 있어서,
    원격부팅 처리부는 원격 부팅 완료 후 클라이언트 단말과 클라우드 서버 간의 네트워크 장애가 발생한 경우, 클라우드 서버에 기록하는 캐쉬 및 데이터 값을 외부 보조 저장 장치에 임시로 기록하는 클라우드 컴퓨팅 서비스 시스템.
KR1020150090726A 2015-06-25 2015-06-25 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템 KR101587994B1 (ko)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020150090726A KR101587994B1 (ko) 2015-06-25 2015-06-25 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020150090726A KR101587994B1 (ko) 2015-06-25 2015-06-25 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템

Publications (1)

Publication Number Publication Date
KR101587994B1 true KR101587994B1 (ko) 2016-01-25

Family

ID=55306986

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020150090726A KR101587994B1 (ko) 2015-06-25 2015-06-25 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템

Country Status (1)

Country Link
KR (1) KR101587994B1 (ko)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101715019B1 (ko) * 2016-11-24 2017-03-10 주식회사 올피아 영상저장장치의 클라우드 가상 디바이스 처리시스템
KR101961861B1 (ko) * 2017-10-17 2019-03-25 (주)유미테크 서버 검증 및 관리 시스템
KR20190065650A (ko) * 2017-12-04 2019-06-12 오피커피주식회사 공용 컴퓨터의 운영체계 초기화 방법 및 이를 적용한 컴퓨팅 시스템
KR20210056642A (ko) * 2019-11-11 2021-05-20 한국전자기술연구원 클라우드 환경 이중화 스토리지를 위한 어플라이언스 적용 방법
CN113204399A (zh) * 2021-04-16 2021-08-03 广州朗国电子科技有限公司 一种云桌面智能终端管理方法、电子设备和存储介质
KR20210100353A (ko) * 2020-02-06 2021-08-17 주식회사 티오이십일콤즈 클라우드 기반 사용자 단말 및 그를 이용한 클라우드 컴퓨팅 시스템
CN113632064A (zh) * 2020-03-04 2021-11-09 茨特里克斯系统公司 具有读高速缓存的供应服务(pvs)云流送
JP2022526056A (ja) * 2020-03-04 2022-05-23 シトリックス・システムズ・インコーポレイテッド プロビジョニングサービス(pvs)クラウド、読み取りキャッシュを使用したストリーミング

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100735875B1 (ko) * 2006-05-02 2007-07-06 김희철 라이브 부팅매체를 이용한 서버 원격접속과 다중 오에스사용 시스템 및 그 방법
KR101088673B1 (ko) * 2010-07-13 2011-12-01 인하대학교 산학협력단 클라이언트 단말 운영 시스템 및 방법

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100735875B1 (ko) * 2006-05-02 2007-07-06 김희철 라이브 부팅매체를 이용한 서버 원격접속과 다중 오에스사용 시스템 및 그 방법
KR101088673B1 (ko) * 2010-07-13 2011-12-01 인하대학교 산학협력단 클라이언트 단말 운영 시스템 및 방법

Cited By (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101715019B1 (ko) * 2016-11-24 2017-03-10 주식회사 올피아 영상저장장치의 클라우드 가상 디바이스 처리시스템
KR101961861B1 (ko) * 2017-10-17 2019-03-25 (주)유미테크 서버 검증 및 관리 시스템
KR20190065650A (ko) * 2017-12-04 2019-06-12 오피커피주식회사 공용 컴퓨터의 운영체계 초기화 방법 및 이를 적용한 컴퓨팅 시스템
KR102108891B1 (ko) 2017-12-04 2020-06-15 오피커피주식회사 공용 컴퓨터의 운영체계 초기화 방법 및 이를 적용한 컴퓨팅 시스템
KR20210056642A (ko) * 2019-11-11 2021-05-20 한국전자기술연구원 클라우드 환경 이중화 스토리지를 위한 어플라이언스 적용 방법
KR102260658B1 (ko) * 2019-11-11 2021-06-04 한국전자기술연구원 클라우드 환경 이중화 스토리지를 위한 어플라이언스 적용 방법
KR20210100353A (ko) * 2020-02-06 2021-08-17 주식회사 티오이십일콤즈 클라우드 기반 사용자 단말 및 그를 이용한 클라우드 컴퓨팅 시스템
KR102310946B1 (ko) 2020-02-06 2021-10-12 주식회사 티오이십일콤즈 클라우드 기반 사용자 단말 및 그를 이용한 클라우드 컴퓨팅 시스템
CN113632064A (zh) * 2020-03-04 2021-11-09 茨特里克斯系统公司 具有读高速缓存的供应服务(pvs)云流送
JP2022526056A (ja) * 2020-03-04 2022-05-23 シトリックス・システムズ・インコーポレイテッド プロビジョニングサービス(pvs)クラウド、読み取りキャッシュを使用したストリーミング
CN113204399A (zh) * 2021-04-16 2021-08-03 广州朗国电子科技有限公司 一种云桌面智能终端管理方法、电子设备和存储介质

Similar Documents

Publication Publication Date Title
KR101587994B1 (ko) 하드디스크 가상화 방식의 클라우드 컴퓨팅 서비스 시스템
US8943506B2 (en) Client-side virtualization architecture using differential bi-directional synchronization and closed computing
US7802084B2 (en) System and method for management and installation of operating system images for computers
US10958633B2 (en) Method and system for securely transmitting volumes into cloud
US20180123968A1 (en) Method and system for securely transmitting volumes into cloud
KR102102168B1 (ko) 가상 데스크탑 서비스 장치 및 방법
US11030025B2 (en) Managing inter-process communications in a containerized application environment
US7363514B1 (en) Storage area network(SAN) booting method
US10146556B2 (en) System and method to perform an OS boot using service location protocol and launching OS using a dynamic update of network boot order without a reboot
US8332490B2 (en) Method, apparatus and program product for provisioning a computer system
US20070118609A1 (en) Distributed computing architecture and associated method of providing a portable user environment
US11418566B2 (en) Adding and removing virtual disks remotely to a streaming machine
US20140122860A1 (en) Cloud system and boot deployment method for the cloud system
US11159367B2 (en) Apparatuses and methods for zero touch computing node initialization
US20140047526A1 (en) Electronic device and method for providing cloud computing services
WO2004025486A2 (en) Use of off-motherboard resources in a computer system
US20120005321A1 (en) Router and remote boot method using the router
US20120131179A1 (en) Method and system for remote os installation capable of monitoring an installation procedure
US10979289B2 (en) Apparatuses and methods for remote computing node registration and authentication
US20130238673A1 (en) Information processing apparatus, image file creation method, and storage medium
US11360806B2 (en) Application attachment based on user application preferences
US20210152420A1 (en) Apparatuses and methods for remote computing node initialization using a configuration template and resource pools
JP4498956B2 (ja) ネットワークブートシステム、単位記憶ユニットのマウント方法およびプログラム
KR102018605B1 (ko) 다중 사용자용 데스크탑 컴퓨터 시스템
CN107659621B (zh) 一种raid控制卡配置方法及装置

Legal Events

Date Code Title Description
E701 Decision to grant or registration of patent right
GRNT Written decision to grant