KR102084031B1 - 복수 서버의 로컬 저장소를 통합 관리하는 방법 및 그 장치 - Google Patents
복수 서버의 로컬 저장소를 통합 관리하는 방법 및 그 장치 Download PDFInfo
- Publication number
- KR102084031B1 KR102084031B1 KR1020190096329A KR20190096329A KR102084031B1 KR 102084031 B1 KR102084031 B1 KR 102084031B1 KR 1020190096329 A KR1020190096329 A KR 1020190096329A KR 20190096329 A KR20190096329 A KR 20190096329A KR 102084031 B1 KR102084031 B1 KR 102084031B1
- Authority
- KR
- South Korea
- Prior art keywords
- virtual machine
- server
- local storage
- server group
- data
- Prior art date
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/27—Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/21—Design, administration or maintenance of databases
- G06F16/214—Database migration support
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/23—Updating
- G06F16/2365—Ensuring data consistency and integrity
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L49/00—Packet switching elements
- H04L49/70—Virtual switches
Landscapes
- Engineering & Computer Science (AREA)
- Databases & Information Systems (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computing Systems (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
복수 서버의 로컬 저장소를 통합 관리하는 방법 및 그 장치가 개시된다. 관리가상머신은 각 로컬저장소를 포함하는 적어도 둘 이상의 서버로 구성되는 서버그룹의 자원정보를 파악하고, 일반가상머신의 데이터쓰기요청을 수신하면 상기 서버그룹의 각 로컬저장소에 데이터를 중복 저장한다.
Description
본 발명의 실시 예는 서버의 로컬 저장소를 이용하여 데이터를 저장하는 방법 및 그 장치에 관한 것으로, 보다 상세하게는 가상머신(VM, Virtual Machine)의 데이터를 저장하기 위해 복수의 서버 로컬 저장소를 통합 관리하는 방법 및 그 장치에 관한 것이다.
적어도 하나 이상의 서버를 위한 중앙집중형의 스토리지 시스템이 존재한다. 서버는 통신망으로 연결된 스토리지 시스템에 접속하여 데이터를 쓰거나 읽는다. 그러나 서버에 복수 개의 가상머신이 구현되고 각 가상머신이 중앙집중의 스토리지 시스템에 접속하여 데이터를 쓰거나 읽고자 할 경우에 병목현상이 발생할 수 있다. 또한 서버를 확장할 경우에 그에 따라 중앙집중형 스토리지의 용량 확장을 위한 별도의 작업이 필요하며, 스토리지 시스템의 장애 등으로 인한 가상머신의 영향을 최소화기 위한 복잡한 관리 모듈이 필요하다.
본 발명의 실시 예가 이루고자 하는 기술적 과제는, 시스템의 확장성을 높이고 가상머신의 마이그레이션(migration)을 신속하고 용이하게 수행할 수 있도록 복수 서버의 로컬 저장소를 통합 관리하는 방법 및 그 장치를 제공하는 데 있다.
상기의 기술적 과제를 달성하기 위한, 본 발명의 실시 예에 따른 통합관리장치의 일 예는, 로컬저장소를 포함하는 적어도 둘 이상의 서버; 상기 적어도 둘 이상의 서버와 연결된 물리스위치; 상기 서버에 위치한 적어도 하나 이상의 일반가상머신; 및 상기 적어도 둘 이상의 서버 중 어느 하나에 위치하고, 상기 적어도 둘 이상의 서버의 로컬저장소의 자원정보를 기초로 전체 로컬저장소에 대한 데이터 입출력을 제어하는 관리가상머신;을 포함하고, 상기 관리가상머신은 상기 일반가상머신의 데이터쓰기요청을 수신하면, 상기 적어도 둘 이상의 서버의 각 로컬저장소에 상기 데이터쓰기요청에 해당하는 데이터를 중복 저장한다.
상기의 기술적 과제를 달성하기 위한, 본 발명의 실시 예에 따른 통합관리방법의 일 예는, 적어도 둘 이상의 서버 중 어느 하나에 위치한 관리가상머신이 수행하는 통합관리방법에 있어서, 각 로컬저장소를 포함하는 적어도 둘 이상의 서버로 구성되는 서버그룹의 자원정보를 파악하는 단계; 및 일반가상머신의 데이터쓰기요청을 수신하면 상기 서버그룹의 각 로컬저장소에 데이터를 중복 저장하는 단계;을 포함하고, 상기 관리가상머신의 가상머신 메타정보는 상기 서버그룹의 각 로컬저장소에 중복저장되며, 상기 관리가상머신은 각 로컬저장소에 저장된 가상머신 메타정보를 이용하여 상기 서버그룹 내 서버 사이에서 마이그레이션된다.
본 발명의 실시 예에 따르면, 가상머신의 데이터를 중앙집중형의 스토리지 시스템이 아닌 서버의 로컬 저장소에 저장 관리하여 데이터 쓰기/읽기를 신속하게 할 수 있으며, 데이터가 저장되는 공간의 크기를 용이하게 확장할 수 있다. 또한, 복수 개의 서버를 포함하는 서버그룹 내에 데이터를 중복 저장하여 서버 사이의 가상머신 마이그레이션을 신속하고 용이하게 수행할 수 있으며, 서버의 점검이나 장애 발생의 경우에도 가상머신의 끊김없는 서비스 제공이 가능하다. 또 다른 실시 예로, 복수 개의 물리포트를 통해 로컬 저장소에 대한 데이터 읽기/쓰기 또는 각 가상머신 사이의 통신, 가상머신 마이그레이션 등을 병목현상 없이 신속하게 수행할 수 있다.
도 1은 본 발명의 실시 예에 따른 통합관리시스템의 개략적인 구조의 일 예를 도시한 도면,
도 2는 본 발명의 실시 예에 따른 서버의 구성의 일 예를 도시한 도면,
도 3은 본 발명의 실시 예에 따른 물리포트의 일 예를 도시한 도면,
도 4는 본 발명의 실시 예에 따른 가상네트워크의 일 예를 도시한 도면,
도 5는 본 발명의 실시 예에 따른 로컬 저장소 통합 관리 방법의 일 예를 도시한 도면,
도 6은 본 발명의 실시 예에 따른 복수의 서버그룹 사이의 데이터 밸런싱의 일 예를 도시한 도면,
도 7은 본 발명의 실시 예에 따른 로컬저장소에 저장되는 데이터의 예를 도시한 도면,
도 8은 본 발명의 실시 예에 따른 서버그룹 내 가상머신 마이그레이션의 일 예를 도시한 도면,
도 9는 본 발명의 실시 예에 따른 새로운 서버그룹 추가로 인한 서버그룹 간 가상머신 마이그레이션의 일 예를 도시한 도면,
도 10은 본 발명의 실시 예에 따른 서버그룹의 장애 또는 점검으로 인한 서버그룹 간 가상머신 마이그레이션의 일 예를 도시한 도면, 그리고,
도 11은 본 발명의 실시 예에 따른 로컬 저장소 통합 관리 방법의 일 예를 도시한 흐름도이다.
도 2는 본 발명의 실시 예에 따른 서버의 구성의 일 예를 도시한 도면,
도 3은 본 발명의 실시 예에 따른 물리포트의 일 예를 도시한 도면,
도 4는 본 발명의 실시 예에 따른 가상네트워크의 일 예를 도시한 도면,
도 5는 본 발명의 실시 예에 따른 로컬 저장소 통합 관리 방법의 일 예를 도시한 도면,
도 6은 본 발명의 실시 예에 따른 복수의 서버그룹 사이의 데이터 밸런싱의 일 예를 도시한 도면,
도 7은 본 발명의 실시 예에 따른 로컬저장소에 저장되는 데이터의 예를 도시한 도면,
도 8은 본 발명의 실시 예에 따른 서버그룹 내 가상머신 마이그레이션의 일 예를 도시한 도면,
도 9는 본 발명의 실시 예에 따른 새로운 서버그룹 추가로 인한 서버그룹 간 가상머신 마이그레이션의 일 예를 도시한 도면,
도 10은 본 발명의 실시 예에 따른 서버그룹의 장애 또는 점검으로 인한 서버그룹 간 가상머신 마이그레이션의 일 예를 도시한 도면, 그리고,
도 11은 본 발명의 실시 예에 따른 로컬 저장소 통합 관리 방법의 일 예를 도시한 흐름도이다.
이하에서, 첨부된 도면들을 참조하여 본 발명의 실시 예에 따른 서버의 로컬 저장소를 통합 관리하는 방법 및 그 장치에 대해 상세히 살펴본다.
도 1은 본 발명의 실시 예에 따른 통합관리시스템의 개략적인 구조의 일 예를 도시한 도면이다.
도 1을 참조하면, 통합관리시스템은 복수 개의 서버(100,110,120,130) 및 물리스위치(140)로 구성된다. 복수 개의 서버(100,110,120,130)는 물리 스위치(140)를 통해 물리 네트워크를 구성한다. 통합관리시스템은 적어도 둘 이상의 서버로 구현될 수 있다.
서버(100,110,120,130)는 중앙처리장치, 메모리, 인터페이스장치 등의 하드웨어와 운영체제(Operating system), 슈퍼바이저(supervisor) 등의 소프트웨어를 포함할 수 있다. 서버의 하드웨어 및 소프트웨어의 일반적인 구성은 널리 알려져 있으므로, 이하에서는 본 실시 예의 통합관리시스템을 위한 서버의 구성을 위주로 설명한다.
서버(100,110,120,130)는 적어도 하나 이상의 가상머신을 포함하거나 포함하지 않을 수 있다. 예를 들어, 제1서버 내지 제3서버(100,110,120)는 각각 적어도 하나 이상의 가상머신을 포함하고, 제4서버(130)는 가상머신을 포함하지 않을 수 있다.
본 실시 예는 복수의 서버 로컬저장소를 통합 관리하는 가상머신을 포함한다. 이하에서는 복수 서버의 로컬저장소를 통합관리하는 가상머신을 '관리가상머신'이라고 하고, 이 외의 일반적인 가상머신을 '일반가상머신'이라고 한다.
관리가상머신은 복수 개의 서버 중 어느 하나에 위치하며, 필요에 따라 서버 사이를 마이그레이션할 수 있다. 관리가상머신을 포함하는 본 실시 예의 서버 구성에 대해 도 2 이하에서 다시 살펴본다.
도 2는 본 발명의 실시 예에 따른 서버의 구성의 일 예를 도시한 도면이다.
도 2를 참조하면, 서버(100)는 적어도 하나 이상의 일반가상머신(200), 관리가상머신(210), 로컬저장소(220), 물리포트(230) 및 백업부(240)를 포함한다. 관리가상머신은 통합관리시스템을 구성하는 복수의 서버 중 어느 하나에 위치한다.
로컬저장소(220)는 서버 내에 위치하는 HDD(Hard Disk Drive), SSD(Solid State Drive) 등의 저장매체이다. 로컬저장소(220)는 적어도 하나 이상의 HDD 또는 적어도 하나 이상의 SSD를 포함할 수 있다.
일반가상머신(200) 및 관리가상머신(210)의 데이터는 네트워크로 연결된 외부 스토리지 시스템에 저장되는 것이 아니라 로컬저장소(220)에 저장된다. 그러나 서버(100)의 로컬저장소(220)의 확장에는 한계가 존재한다. 예를 들어, 서버(100)에 장착 가능한 HDD, SSD의 개수는 정해져 있을 수 있다. 서버(100) 내 로컬저장소(220)의 물리적인 확장 없이 신규 서버그룹의 추가를 통해 로컬저장소의 저장공간이 확대되는 것과 동일한 효과를 달성할 수 있는 방법이 도 9에 도시되어 있다.
일반가상머신(200)의 데이터가 로컬저장소(220)에 저장되므로, 서버의 점검이나 장애 등이 발생하면 서버 내 가상머신의 동작이 일시 중지되는 문제점이 존재한다. 이를 해결하기 위하여, 본 실시 예는 가상머신의 마이그레이션을 신속하게 수행하여 끊김없는 가상머신 서비스를 제공할 수 있도록 적어도 둘 이상의 서버를 서버그룹으로 묶은 후 서버그룹 내 데이터를 중복저장한다. 이와 관련하여 도 5 이하에서 살펴본다.
서버(100) 내 복수 개의 가상머신(200)이 존재하는 경우 각 가상머신9200)의 데이터 읽기/쓰기에 병목현상이 발생하거나, 외부 서버의 가상머신과의 데이터 송수신에 병목현상이 발생할 수 있다. 또는 관리가상머신(210)이 복수 서버의 로컬저장소를 관리하기 위한 제어명령이나 데이터를 병목현상없이 신속하게 처리할 필요가 있다. 신속한 데이터 송수신을 위해 본 실시 예는 복수 개의 물리포트(230)를 포함하며, 그 일 예가 도 3에 도시되어 있다.
백업부(240)는 서버(100)의 로컬저장소(220)에 저장된 데이터를 일정 주기로 백업저장한다. 백업부(240)는 매번 로컬저장소의 전체 데이터를 백업하거나, 이전 백업시점부터 현시점까지 변경된 데이터만을 추출하여 백업할 수 있다. 백업부(240)는 실시 예에 따라 생략 가능한다.
도 3은 본 발명의 실시 예에 따른 물리포트의 일 예를 도시한 도면이다.
도 2 및 도 3을 참조하면, 물리포트(230)는 제1 내지 제4 물리포트(300,310,320,330)를 포함한다.
제1 물리포트(300)는 제1 가상스위치(340)를 통해 관리가상머신(210)과 연결된다. 예를 들어, 관리가상머신(210)은 제1 물리포트(300)를 통해 복수 서버의 로컬저장소를 관리하기 위한 제어명령이나 데이터 등을 송수신할 수 있다.
제2 물리포트(310)는 제2 가상스위치(342)와 연결되어 가상머신(200,210)의 마이그레이션을 위한 데이터 송수신에 사용된다. 예를 들어, 제1 서버(100)에 위치한 제1 가상머신이 제2 서버(110)로 마이그레이션하는 경우, 제1 서버(100)의 제2 물리포트와 제2 서버(1100의 제2 물리포트를 통해 가상머신 마이그레이션을 위한 데이터를 송수신할 수 있다.
제3 물리포트(320)는 제3 가상스위치(344)와 연결되어 로컬저장소(220)에 대한 데이터 송수신에 사용된다. 예를 들어, 서버(100) 내 일반가상머신(200) 또는 외부 서버의 일반가상머신의 데이터는 제3 물리포트(320)를 통해 로컬저장소(220)에 전달되어 저장된다.
제4 물리포트(330)는 제4 가상스위치(346)를 통해 적어도 하나 이상의 일반가상머신(200)과 연결된다.
본 실시 예에서, 제1 내지 제4 가상스위치(340,342,344,346)는 서로 다른 가상스위치이거나 동일 가상스위치일 수 있다. 제1 내지 제4 가상스위치(340,342,344,346)를 통해 일반가상머신(200) 및 관리가상머신(210)은 가상 네트워크를 형성한다. 예를 들어, 일반가상머신(200) 및 관리가상머신(210)에는 가상 네트워크에서 사용되는 사설 IP(Internet Protocol) 주소가 할당되며, 각 가상머신(200,210)은 사설 IP 주소를 이용하여 데이터를 송수신할 수 있다.
도 4는 본 발명의 실시 예에 따른 가상네트워크의 일 예를 도시한 도면이다.
도 4를 참조하면, 적어도 하나 이상의 일반가상머신(400) 및 관리가상머신(430)은 가상스위치(440)를 통해 가상네트워크를 형성한다. 예를 들어, 통합관리시스템이 도 1의 제1 서버(100) 및 제2 서버(200)의 두 서버로 구성된 경우에, 제1 서버(100) 및 제2 서버(110)에 존재하는 복수 개의 일반가상머신(410,420)과 관리가상머신(430)은 도 3에서 살핀 적어도 하나 이상의 가상스위치를 통해 가상네트워크를 형성한다.
도 5는 본 발명의 실시 예에 따른 로컬 저장소 통합 관리 방법의 일 예를 도시한 도면이다.
도 5를 참조하면, 통합관리시스템은 적어도 하나 이상의 서버그룹(150 또는160)으로 구성되고, 각 서버그룹(150 또는 160)은 적어도 둘 이상의 서버(100,110,120,130)로 구성될 수 있다. 본 실시 예에서, 통합관리시스템은 제1 서버(100) 및 제2 서버(110)를 포함하는 제1 서버그룹(150)과 제3 서버(120) 및 제4 서버(130)를 포함하는 제2 서버그룹(160)으로 구성된다.
다른 실시 예로, 서버그룹별 포함되는 서버의 개수는 서로 다를 수 있다. 예를 들어, 제1 서버그룹은 2개의 서버로 구성되고, 제2 서버그룹은 3개의 서버로 구성될 수 있다.
관리가상머신(210)은 복수 개의 서버 로컬 저장소(510,520,530,540)를 서버그룹의 그룹핑 정보에 따라 통합 관리한다. 예를 들어, 관리가상머신(210)은 제1 내지 제4 서버(100,110,120,130)의 로컬저장소(510,520,530,540)의 자원정보를 파악한 후 이를 하나의 통합저장소(500)로 관리한다.
일 실시 예로, 관리가상머신(210)은 일반가상머신의 데이터를 서버그룹(150,160) 내 로컬저장소(510,520,530,540)에 중복 저장한다. 예를 들어, 제1 서버그룹(150)의 제1 서버(100)에 위치한 제1 가상머신의 데이터쓰기요청이 있으면, 관리가상머신은 제1 가상머신의 데이터쓰기요청에 해당하는 데이터를 제1 가상머신이 위치한 제1 서버(100)의 제1 로컬저장소(510)에 저장할 뿐만 아니라 제1 서버(100)와 동일한 서버그룹(150)에 존재하는 제2 서버(110)의 제2 로컬저장소(520)에 중복 저장한다.
다른 실시 예로, 관리가상머신(210)은 일반가상머신 및 관리가상머신(210)의 메타데이터를 서버그룹(150,160) 내 중복저장할 수 있다. 예를 들어, 제1 서버(100)의 제1 가상머신에 대한 메타데이터는 제1 서버(100)의 제1 로컬저장소(510) 및 제2 서버(110)의 제2 로컬저장소(520)에 중복 저장된다. 일 예로, 각 서버(100,110,120,130)에 가상머신이 생성될 때, 각 서버(100,110,120,130)는 서버 그룹핑 정보에 따라 동일 서버그룹(150,160) 내 각 로컬저장소(510,520,530,540)에 가상머신 메타정보를 중복 저장할 수 있다.
서버그룹(150,160) 내 각 가상머신의 일반데이터 및 메타데이터 등이 중복저장되므로, 서버그룹(150,160) 내 가상머신 마이그레이션은 신속하게 수행될 수 있다. 서브그룹 내 가상머신 마이그레이션의 일 예가 도 8에 도시되어 있다. 서브그룹간 마이그리션의 일 예는 도 9 및 도 10에 도시되어 있다.
다른 실시 예로, 각 서버의 로컬저장소는 복수 개의 디스크로 구성될 수 있다. 이 경우에, 관리가상머신(210)은 데이터의 파일이름에 해시함수를 적용하여 일정 길이의 숫자를 생성한 후 해당 숫자에 따라 해당하는 디스크에 데이터를 저장할 수 있다. 예를 들어, 로컬저장소가 5개의 디스크로 구성되고 데이터 파일이름을 5자리의 숫자로 변경한다면, 제1 디스크에는 0~10000 사이의 숫자로 표현되는 데이터를 저장하고, 제2 디스크에는 10001~20000 사이의 숫자로 표현되는 데이터를 저장할 수 있다. 데이터가 숫자 기반으로 복수의 디스크에 분류 저장되므로 데이터를 신속하게 검색하여 찾을 수 있다.
도 6은 본 발명의 실시 예에 따른 복수의 서버그룹 사이의 데이터 밸런싱의 일 예를 도시한 도면이다.
도 6을 참조하면, 제1 서버그룹(150) 내 제1 로컬저장소(510)와 제2 로컬저장소(520)는 제1 서버그룹(150)에 속한 적어도 하나 이상의 일반가상머신의 데이터를 중복 저장하고, 제2 서버그룹(160) 내 제3 로컬저장소(530)와 제4 로컬저장소(540)는 제2 서버그룹(160)에 속한 적어도 하나 이상의 일반가상머신의 데이터를 중복 저장한다. 따라서 시간이 흐름에 따라 제1 서버그룹(150) 내 스토리지 사용률과 제2 서버그룹(160) 내 스토리지 사용률이 달라질 수 있다.
관리가상머신(210)은 각 서버그룹의 스토리지 사용률을 기초로 데이터 밸런싱을 수행할 수 있다. 관리가상머신은 각 서버그룹(150,160)의 스토리지 사용률이 기 설정된 임계값에 해당하면 데이터 밸런싱을 수행할 수 있다. 예를 들어, 제1 서버그룹의 데이터 사용률이 임계값인 50%에 도달하면, 관리가상머신(210)은 제1 서버그룹(150)의 제1 및 제2 로컬저장소(510,520)에 중복 저장된 데이터의 일부를 제2 서버그룹(160)의 제3 및 제4 로컬저장소(530,540)에 이동 저장하여 두 서버그룹의 스토리지 사용률을 조정할 수 있다.
도 7은 본 발명의 실시 예에 따른 통합저장소에 저장되는 데이터의 예를 도시한 도면이다.
도 5 및 도 7을 함께 참조하면, 복수 서버의 로컬저장소를 통합한 통합저장소에는 일반가상머신 및 관리가상머신의 일반데이터(710)와 메타데이터(720)가 저장된다. 일반데이터(710)는 가상머신 서비스에서 발생하는 여러 데이터를 의미하고, 메타데이터(720)는 가상머신 식별자, 가상머신 IP 주소, 운영체제 등 가상머신을 정의하는 각종 데이터를 의미한다. 일반데이터(710) 및 메타데이터(720)는 서버그룹(150,160)별로 적어도 둘 이상의 서버 로컬저장소(510,520,530,540)에 중복 저장된다.
도 8은 본 발명의 실시 예에 따른 서버그룹 내 가상머신 마이그레이션의 일 예를 도시한 도면이다.
도 8을 참조하면, 통합관리시스템은 하나의 서버그룹(150)을 포함하고, 해당 서버그룹(150)은 제1 서버(100) 및 제2 서버(110)를 포함한다. 제1 서버(100)에는 관리가상머신(800)과 제1 및 제2 일반가상머신(810,820)이 존재하고, 제2 서버(110)에는 제3 및 제4 일반가상머신(830,840)이 존재한다.
서버의 점검 또는 장애가 발생한 경우에 가상머신 마이그레이션이 발생할 수 있다. 예를 들어, 관리가상머신(800)은 주기적으로 핑(PING) 신호를 각 서버에 전송하여 어느 서버에 장애가 발생하는지 확인할 수 있다.
본 실시 예는 제1 서버(100)에 대한 점검 요청이 있거나 장애가 발생한 경우이다. 먼저 관리가상머신(800)은 제1 서버(100)에서 제2 서버(110)로 마이그레이션된다. 그리고 제1 서버(100)의 제1 및 제2 일반가상머신(810,820)이 제1 서버(100)에서 제2 서버(110)로 마이그레이션된다. 데이터는 제1 서버(100)와 제2 서버(110)의 로컬저장소에 중복저장되므로 별도의 데이터 송수신 없이 마이그레이션이 신속하게 완료될 수 있어, 가상머신 서비스의 끊김없는 제공이 가능하다.
제1 서버(100)의 점검이 완료되거나 장애가 해소되면, 일반가상머신(810,820)은 다시 제1 서버(100)로 마이그레이션될 수 있다. 이때 제1 서버(100)에는 일반가상머신(810,820)의 데이터가 그대로 존재하므로, 제2 서버(110)에서 일반가상머신(810,820)이 새롭게 저장한 데이터만 제1 서버(100)로 전송될 수 있다.
도 9는 본 발명의 실시 예에 따른 새로운 서버그룹 추가로 인한 서버그룹 간 가상머신 마이그레이션의 일 예를 도시한 도면이다.
도 9를 참조하면, 제1 서버그룹(150)은 제1 서버(100) 및 제2 서버(110)로 구성된다. 제1 서버(100) 및 제2 서버(110)에 위치한 제1 내지 제4 가상머신(910,920,930,940)의 데이터는 제1 서버그룹(100) 내 각 서버(100,110)의 로컬저장소에 중복 저장된다.
로컬저장소의 저장공간이 부족할 경우 가상머신 서비스가 불가능하므로, 로컬저장소를 더 늘려야 하나 서버(100,110)의 로컬저장소의 물리적 확장에는 한계가 존재한다. 본 실시 예는 새로운 서브그룹(160)의 추가를 통해 로컬저장소를 확장하는 효과를 달성한다.
제3 서버(120) 및 제4 서버(130)를 포함하는 새로운 제2 서버그룹(160)이 추가되면, 제1 서버그룹과 제2 서버그룹 사이에 데이터 밸런싱이 수행된다. 데이터 밸랜싱은 종래의 다양한 스토리지 솔루션을 통해 구현될 수 있다. 데이터 밸런싱을 통해 제1 서버그룹(150)의 로컬저장소에 저장된 데이터 A,B,C,D 중 데이터 B,D가 제2 서버그룹(160)의 로컬저장소로 이동된다. 따라서 제1 서버그룹의 로컬저장소의 빈공간이 증가하며, 그 결과 로컬저장소가 확장된 것과 같은 효과를 달성할 수 있다.
새로운 서버그룹의 추가시 서버그룹 간 가상머신 마이그레이션이 발생할 수 있다. 예를 들어, 제1 서버그룹(150)의 데이터B,D가 제2 서버그룹(160)으로 이동될 때 데이터 B,D를 사용하는 제2 및 제4 일반가상머신(920,940)이 제2 서버그룹(160)의 제3 및 제4 서버(120,130)로 각각 마이그레이션될 수 있다. 이때 새로운 서버그룹에는 가상머신 메타데이터가 존재하지 아니하므로, 제2 및 제4 일반가상머신(920,940)에 대한 메타데이터는 도 3에서 살펴본 제2 물리포트(310)를 통해 각 서버 사이에 신속하게 송수신되도록 한다.
제1 서버그룹(150) 및 제2 서버그룹(160)이 존재하는 상황에서 또 다시 새로운 제3 서버그룹(미도시)이 추가되면, 제1 내지 제3 서버그룹 내 로컬데이터에 저장된 데이터가 다시 분산 저장되므로 각 서버그룹 내 로컬 저장소의 저장용량이 증가하는 효과가 발생한다.
도 10은 본 발명의 실시 예에 따른 서버그룹의 장애 또는 점검으로 인한 서버그룹 간 가상머신 마이그레이션의 일 예를 도시한 도면이다.
도 10을 참조하면, 제1 서버그룹(150)은 제1 서버(100) 및 제2 서버(110)로 구성되고, 제2 서버그룹(160)은 제3 서버(120) 및 제4 서버(140)로 구성된다. 이때 제1 서버그룹(150)의 점검 또는 장애가 발생하면, 제1 서버그룹(150) 내 존재하는 관리가상머신(1000)과 일반가상머신(1010,1020,1030,1040)은 제2 서버그룹(160)의 각 서버(120,130)에 마이그레이션되고, 또한 제1 서버그룹(150)의 로컬저장소에 저장된 데이터는 제2 서버그룹(160)의 로컬저장소에 저장된다.
제1 서버그룹(150)의 점검이 완료되거나 장애가 해소되면, 일반가상머신(1010,1020,1030,1040)이 다시 제1 서버그룹(150)으로 마이그레이션될 수 있다. 이때 제1 서버그룹(150)에는 일반가상머신(1010,1020,1030,1040)의 데이터가 그대로 존재하므로, 제2 서버그룹(160)에서 일반가상머신(1010,1020,1030,1040)이 새롭게 저장한 데이터만 제1 서버그룹(150)으로 전송될 수 있다.
도 11은 본 발명의 실시 예에 따른 로컬 저장소 통합 관리 방법의 일 예를 도시한 흐름도이다.
도 11을 참조하면, 관리가상머신(210)은 적어도 하나 이상의 서버그룹에 속한 적어도 하나 이상의 서버의 자원정보를 파악한다(S1100). 예를 들어, 관리가상머신(210)은 도 5와 같이 각 서버그룹(150,160) 내 각 서버(100,110,120,130)의 로컬저장소(510,520,530,540)의 자원정보를 취합하여 서버 그룹핑 정보에 따라 통합저장소 정보를 생성하고 관리할 수 있다.
관리가상머신(210)은 일반가상머신의 데이터쓰기요청이 있으면, 일반가상머신이 속한 서버그룹 내 복수의 서버에 데이터를 중복 저장한다(S1110). 또 다른 예로, 관리가상머신은 서버의 장애나 점검 또는 서버그룹의 장애나 점검이 발생하면, 장애나 점검이 발생한 서버나 서버그룹에 속한 가상머신을 다른 서버나 다른 서버그룹으로 마이그레이션하고 데이터 또한 이동할 수 있다. 가상머신의 마이그레이션의 예가 도 8 내지 도 10에 도시되어 있다.
관리가상머신(210)은 복수의 서버그룹이 존재하는 경우 각 서버그룹 내 스토리지 사용률에 따라 데이터를 분산저장한다(S1120). 분산저장의 일 예가 도 6에 도시도어 있다. 다른 예로, 새로운 서버그룹이 추가되면, 기존 서버그룹의 데이터를 분산 저장할 수 있다.
본 발명은 또한 컴퓨터로 읽을 수 있는 기록매체에 컴퓨터가 읽을 수 있는 코드로서 구현하는 것이 가능하다. 컴퓨터가 읽을 수 있는 기록매체는 컴퓨터 시스템에 의하여 읽혀질 수 있는 데이터가 저장되는 모든 종류의 기록장치를 포함한다. 컴퓨터가 읽을 수 있는 기록매체의 예로는 ROM, RAM, CD-ROM, 자기 테이프, 플로피디스크, 광데이터 저장장치 등이 있다. 또한 컴퓨터가 읽을 수 있는 기록매체는 네트워크로 연결된 컴퓨터 시스템에 분산되어 분산방식으로 컴퓨터가 읽을 수 있는 코드가 저장되고 실행될 수 있다.
이제까지 본 발명에 대하여 그 바람직한 실시 예들을 중심으로 살펴보았다. 본 발명이 속하는 기술 분야에서 통상의 지식을 가진 자는 본 발명이 본 발명의 본질적인 특성에서 벗어나지 않는 범위에서 변형된 형태로 구현될 수 있음을 이해할 수 있을 것이다. 그러므로 개시된 실시 예들은 한정적인 관점이 아니라 설명적인 관점에서 고려되어야 한다. 본 발명의 범위는 전술한 설명이 아니라 특허청구범위에 나타나 있으며, 그와 동등한 범위 내에 있는 모든 차이점은 본 발명에 포함된 것으로 해석되어야 할 것이다.
Claims (10)
- 로컬저장소를 포함하는 복수의 서버;
상기 복수의 서버와 연결된 물리스위치;
상기 복수의 서버에 위치한 복수의 일반가상머신; 및
상기 복수의 서버 중 어느 하나에 위치하고, 상기 복수의 서버의 로컬저장소의 자원정보를 기초로 전체 로컬저장소에 대한 데이터 입출력을 제어하는 관리가상머신;을 포함하고,
상기 복수의 서버는 복수 개의 서버그룹으로 그룹핑되고,
상기 관리가상머신은 상기 일반가상머신의 데이터쓰기요청을 수신하면, 상기 일반가상머신이 위치한 서버가 속한 서버그룹 내 서버의 각 로컬저장소에 상기 데이터쓰기요청에 해당하는 데이터를 중복 저장하고,
상기 관리가상머신은 적어도 하나 이상의 서버를 포함하는 새로운 서버그룹이 추가되면, 기존 서버그룹과 새로운 서버그룹 사이에 데이터 밸런싱을 수행하는 것을 특징으로 하는 통합관리시스템. - 제 1항에 있어서,
상기 복수의 서버는 각각 복수 개의 물리포트를 포함하고,
상기 복수 개의 물리포트는,
제1 가상스위치를 통해 상기 관리가상머신과 연결되는 제1 물리포트;
제2 가상스위치와 연결되어 가상머신의 마이그레이션을 위한 데이터 송수신에 사용되는 제2 물리포트;
제3 가상스위치와 연결되어 상기 로컬저장소에 대한 데이터 송수신에 사용되는 제3 물리포트; 및
제4 가상스위치를 통해 적어도 하나 이상의 일반가상머신과 연결되는 제4 물리포트;를 포함하고,
상기 일반가상머신 및 상기 관리가상머신은 상기 제1 내지 제4 가상스위치를 통해 형성된 가상 네트워크를 통해 데이터를 송수신하는 것을 특징으로 하는 통합관리시스템. - 삭제
- 제 1항에 있어서, 상기 관리가상머신은,
적어도 하나 이상의 서버를 포함하는 새로운 서버그룹이 추가된 경우에 새로운 서버그룹 내 로컬저장소의 자원정보를 파악하고,
기존 서버그룹의 로컬저장소에 저장된 데이터는 상기 새로운 서버그룹에 분산 저장되는 것을 특징으로 하는 통합관리시스템. - 제 1항에 있어서, 상기 관리가상머신은,
복수 개의 서버그룹의 로컬저장소의 사용률을 기초로 서버그룹 사이에 데이터를 분산 저장하는 것을 특징으로 하는 통합관리시스템. - 제 1항에 있어서, 상기 관리가상머신은,
동일 서버그룹 내 일반가상머신의 마이그레이션은 동일 서버그룹 내 각 로컬저장소에 중복 저장된 가상머신 메타정보를 이용하여 수행하고,
서버그룹 사이의 일반가상머신의 마이그레이션은 이동할 서버그룹의 로컬저장소에 가상머신 메타정보를 저장하여 수행하는 것을 특징으로 하는 통합관리시스템. - 복수의 서버 중 어느 하나에 위치한 관리가상머신이 수행하는 통합관리방법에 있어서,
각 로컬저장소를 포함하는 복수의 서버로 구성되는 복수의 서버그룹의 자원정보를 파악하는 단계; 및
일반가상머신의 데이터쓰기요청을 수신하면 상기 일반가상머신이 위치한 서버가 속한 서버그룹 내 서버의 각 로컬저장소에 상기 데이터쓰기요청에 해당하는 데이터를 중복 저장하는 단계;를 포함하고,
상기 관리가상머신의 가상머신 메타정보는 상기 서버그룹의 각 로컬저장소에 중복저장되며, 상기 관리가상머신은 각 로컬저장소에 저장된 가상머신 메타정보를 이용하여 상기 서버그룹 내 서버 사이에서 마이그레이션되고,
상기 관리가상머신은 적어도 하나 이상의 서버를 포함하는 새로운 서버그룹이 추가되면, 기존 서버그룹과 새로운 서버그룹 사이에 데이터 밸런싱을 수행하는 것을 특징으로 하는 통합관리방법. - 제 7항에 있어서,
새로운 서버그룹이 추가되면 새로운 서버그룹에 포함된 각 서버의 로컬저장소의 자원정보를 파악하고, 기존 서버그룹과 새로운 서버그룹의 전체 로컬저장소를 일반가상머신의 데이터쓰기요청에 대한 저장소로 관리하는 것을 특징으로 하는 통합관리방법. - 제 8항에 있어서,
기존 서버그룹과 새로운 서버그룹을 포함하는 복수 개의 서브그룹에 위치한 복수 개의 일반가상머신 사이의 통신을 위한 각 서버의 물리포트와 상기 복수 개의 서브그룹의 각 로컬저장소 사이의 데이터 송수신을 위한 각 서버의 물리포트는 서로 다른 것을 특징으로 하는 통합관리방법. - 제 7항 내지 제 9항 중 어느 한 항에 기재된 방법을 수행하기 위한 프로그램을 기록한 컴퓨터로 읽을 수 있는 기록매체.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020190096329A KR102084031B1 (ko) | 2019-08-07 | 2019-08-07 | 복수 서버의 로컬 저장소를 통합 관리하는 방법 및 그 장치 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020190096329A KR102084031B1 (ko) | 2019-08-07 | 2019-08-07 | 복수 서버의 로컬 저장소를 통합 관리하는 방법 및 그 장치 |
Publications (1)
Publication Number | Publication Date |
---|---|
KR102084031B1 true KR102084031B1 (ko) | 2020-05-29 |
Family
ID=70911554
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020190096329A KR102084031B1 (ko) | 2019-08-07 | 2019-08-07 | 복수 서버의 로컬 저장소를 통합 관리하는 방법 및 그 장치 |
Country Status (1)
Country | Link |
---|---|
KR (1) | KR102084031B1 (ko) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20230173351A (ko) | 2022-06-17 | 2023-12-27 | 주식회사 도시엔컴 | 서버 이중화를 통한 데이터 관리, 공유 스토리지 제공 및 데이터 백업 서비스가 가능한 데이터 통합 관리 시스템 |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20050115063A (ko) * | 2004-06-03 | 2005-12-07 | 삼성전자주식회사 | 외부 저장장치, 화상획득장치, 및 드라이버를 구동하는방법 및 시스템 |
KR20100069695A (ko) * | 2007-09-19 | 2010-06-24 | 케이피아이티 커민즈 인포시스템즈 엘티디. | 반자동 소프트웨어 마이그레이션을 위해 플러그-앤-플레이 하드웨어 컴포넌트들을 동작시키는 메커니즘 |
KR20110049418A (ko) * | 2009-11-05 | 2011-05-12 | 한국전자통신연구원 | 다중 호스트 상의 다중 가상머신을 지원하는 원격 usb 시스템 및 그 방법 |
JP2012208541A (ja) * | 2011-03-29 | 2012-10-25 | Mitsubishi Electric Corp | 仮想マシン管理装置、仮想マシン管理方法及び仮想マシン管理プログラム |
KR20130019698A (ko) * | 2011-08-17 | 2013-02-27 | 주식회사 케이티 | 사용자 스케줄러와 마이그레이션(Migration)을 통한 자원 최적화 방법 및 시스템 |
KR20140055112A (ko) * | 2012-10-30 | 2014-05-09 | 삼성에스디에스 주식회사 | 고가용성 가상머신 구성 시스템 및 방법, 이를 기록한 기록매체 |
KR20150029181A (ko) * | 2013-09-09 | 2015-03-18 | 삼성에스디에스 주식회사 | 클러스터 시스템 및 클러스터 시스템에서 서비스 가용성을 제공하기 위한 방법 |
KR101669567B1 (ko) * | 2015-04-27 | 2016-10-27 | 울산과학기술원 | 가상 머신의 배치를 관리하는 방법 |
KR101984714B1 (ko) | 2018-08-23 | 2019-05-31 | (주) 글루시스 | 가상화 자원 모니터링 시스템 |
-
2019
- 2019-08-07 KR KR1020190096329A patent/KR102084031B1/ko active
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20050115063A (ko) * | 2004-06-03 | 2005-12-07 | 삼성전자주식회사 | 외부 저장장치, 화상획득장치, 및 드라이버를 구동하는방법 및 시스템 |
KR20100069695A (ko) * | 2007-09-19 | 2010-06-24 | 케이피아이티 커민즈 인포시스템즈 엘티디. | 반자동 소프트웨어 마이그레이션을 위해 플러그-앤-플레이 하드웨어 컴포넌트들을 동작시키는 메커니즘 |
KR20110049418A (ko) * | 2009-11-05 | 2011-05-12 | 한국전자통신연구원 | 다중 호스트 상의 다중 가상머신을 지원하는 원격 usb 시스템 및 그 방법 |
JP2012208541A (ja) * | 2011-03-29 | 2012-10-25 | Mitsubishi Electric Corp | 仮想マシン管理装置、仮想マシン管理方法及び仮想マシン管理プログラム |
KR20130019698A (ko) * | 2011-08-17 | 2013-02-27 | 주식회사 케이티 | 사용자 스케줄러와 마이그레이션(Migration)을 통한 자원 최적화 방법 및 시스템 |
KR20140055112A (ko) * | 2012-10-30 | 2014-05-09 | 삼성에스디에스 주식회사 | 고가용성 가상머신 구성 시스템 및 방법, 이를 기록한 기록매체 |
KR20150029181A (ko) * | 2013-09-09 | 2015-03-18 | 삼성에스디에스 주식회사 | 클러스터 시스템 및 클러스터 시스템에서 서비스 가용성을 제공하기 위한 방법 |
KR101669567B1 (ko) * | 2015-04-27 | 2016-10-27 | 울산과학기술원 | 가상 머신의 배치를 관리하는 방법 |
KR101984714B1 (ko) | 2018-08-23 | 2019-05-31 | (주) 글루시스 | 가상화 자원 모니터링 시스템 |
Non-Patent Citations (3)
Title |
---|
https://www.iroo.co.kr/irfiles/ko_VMware_vSAN_HCI_IROOhome.pdf * |
https://www.youtube.com/watch?v=FeHEBpPHBG4 * |
https://www.youtube.com/watch?v=-nXs2CsrK44 * |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20230173351A (ko) | 2022-06-17 | 2023-12-27 | 주식회사 도시엔컴 | 서버 이중화를 통한 데이터 관리, 공유 스토리지 제공 및 데이터 백업 서비스가 가능한 데이터 통합 관리 시스템 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11137940B2 (en) | Storage system and control method thereof | |
US20190310925A1 (en) | Information processing system and path management method | |
US9477565B2 (en) | Data access with tolerance of disk fault | |
JP5427630B2 (ja) | 動的ページ再割当てストレージシステムにおけるアプリケーション及び階層構成の管理 | |
US9098466B2 (en) | Switching between mirrored volumes | |
US8386744B2 (en) | Thin provisioning migration and scrubbing | |
US8578121B2 (en) | Computer system and control method of the same | |
US8650381B2 (en) | Storage system using real data storage area dynamic allocation method | |
US20140351545A1 (en) | Storage management method and storage system in virtual volume having data arranged astride storage device | |
US9785349B2 (en) | Efficient free-space management of multi-target peer-to-peer remote copy (PPRC) modified sectors bitmap in bind segments | |
US20170177224A1 (en) | Dynamic storage transitions employing tiered range volumes | |
CN103929500A (zh) | 一种分布式存储系统的数据分片方法 | |
US20240184470A1 (en) | Composite aggregate architecture | |
US8046552B2 (en) | Tracking metadata changes during data copy in a storage system | |
JPWO2008114441A1 (ja) | ストレージ管理プログラム、ストレージ管理方法およびストレージ管理装置 | |
US8001324B2 (en) | Information processing apparatus and informaiton processing method | |
US20150347047A1 (en) | Multilayered data storage methods and apparatus | |
US9792061B2 (en) | Efficient cache management of multi-target peer-to-peer remote copy (PPRC) modified sectors bitmap | |
US10031682B1 (en) | Methods for improved data store migrations and devices thereof | |
US20130246568A1 (en) | Data storage system | |
CN105187502A (zh) | 一种基于分布式弹性块存储的方法和系统 | |
KR102084031B1 (ko) | 복수 서버의 로컬 저장소를 통합 관리하는 방법 및 그 장치 | |
JP6974706B2 (ja) | 情報処理装置、ストレージシステムおよびプログラム | |
WO2021187194A1 (ja) | 分散処理システム、分散処理システムの制御方法、及び、分散処理システムの制御装置 | |
US20170153976A1 (en) | Asynchronous cleanup after a peer-to-peer remote copy (pprc) terminate relationship operation |