KR102316749B1 - 가상 머신 워크로드 예측 방법, 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치 - Google Patents

가상 머신 워크로드 예측 방법, 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치 Download PDF

Info

Publication number
KR102316749B1
KR102316749B1 KR1020200078477A KR20200078477A KR102316749B1 KR 102316749 B1 KR102316749 B1 KR 102316749B1 KR 1020200078477 A KR1020200078477 A KR 1020200078477A KR 20200078477 A KR20200078477 A KR 20200078477A KR 102316749 B1 KR102316749 B1 KR 102316749B1
Authority
KR
South Korea
Prior art keywords
physical server
virtual machine
schedule
objective function
virtual
Prior art date
Application number
KR1020200078477A
Other languages
English (en)
Other versions
KR20210015636A (ko
Inventor
윤호영
김영광
김민준
Original Assignee
오케스트로 주식회사
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from KR1020190092851A external-priority patent/KR102135208B1/ko
Application filed by 오케스트로 주식회사 filed Critical 오케스트로 주식회사
Priority to KR1020200078477A priority Critical patent/KR102316749B1/ko
Publication of KR20210015636A publication Critical patent/KR20210015636A/ko
Application granted granted Critical
Publication of KR102316749B1 publication Critical patent/KR102316749B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • 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/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5027Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
    • G06F9/505Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals considering the load
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/4557Distribution of virtual machine instances; Migration and load balancing

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Debugging And Monitoring (AREA)

Abstract

본 발명의 일 실시예에 따른 가상 머신 배치 방법은, 가상 머신 배치 장치를 이용하여, 가상 머신이 설치된 물리 서버 - 상기 물리 서버는 제1 물리 서버 및 제2 물리 서버를 구비함. -를 효율적으로 운용하기 위하여, 복수의 상기 가상 머신을 상기 제1 물리 서버와 상기 제2 물리 서버 상에 배치하는 방법인 가상 머신 배치 방법에 있어서, 상기 제1 물리 서버와 상기 제2 물리 서버의 작동과 관련된 정보를 기초로 미리 정해진 워크 로드 산출 방법에 의해 상기 가상 머신에 의해 부과되는 물리 서버의 부하인 가상 머신 워크 로드와 관련된 정보인 가상 머신 워크 로드 정보가 산출되는 단계; 상기 가상 머신 워크 로드를 기초로 미리 정해진 제1 기간 동안 예측되는 상기 가상 머신에 의해 부과되는 물리 서버의 부하와 연관된 최초 예측 가상 로드와 관련된 정보인 최초 예측 가상 로드 정보가 산출되는 단계; 미리 정해진 배치 일정 산출 방법에 의해 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치 일정과 관련된 정보인 배치 일정 정보가 산출되는 단계; 상기 미리 정해진 배치 일정 산출 방법에 의해 산출된 배치 일정이 표시되는 단계; 및 상기 미리 정해진 배치 일정 산출 방법에 의해 산출된 상기 배치 일정에 따라 상기 제1 물리 서버와 상기 제2 물리 서버 상에 상기 가상 머신이 배치되도록, 상기 가상 머신이 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 이동되면서 배치되는 단계;를 포함하고, 상기 미리 정해진 배치 일정 산출 방법은, 상기 최초 예측 가상 로드 정보를 기초로 목적 함수 값이 최소화될 때의 상기 가상 머신의 상기 배치 일정이 산출되는 방법이며, 상기 미리 정해진 제1 기간 동안에 상기 물리 서버들 간의 상기 가상 머신의 이동이 허용되도록 상기 배치 일정이 산출되는 방법이고, 상기 목적 함수는, 상기 미리 정해진 제1 기간 동안, 상기 최초 예측 가상 로드에 의해 산출되는 물리 서버의 부하의 변화 량과 관련된 함수인 제1 목적 함수를 구비할 수 있다.

Description

가상 머신 워크로드 예측 방법, 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치{VIRTUAL MACHINE WORKLOAD PREDICTION METHOD, VIRTUAL MACHINE PLACEMENT METHOD AND VIRTUAL MACHINE PLACEMENT DEVICE IMPLEMENTING THE SAME}
본 발명은 가상 머신 워크로드 예측 방법, 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치에 관한 것으로서, 복수의 가상 머신이 각각 배치된 제1 물리 서버와 제2 물리 서버를 효율적으로 운용하기 위하여, 복수의 상기 가상 머신을 상기 제1 물리 서버와 상기 제2 물리 서버 상에 배치하기 위한 것이다.
전 세계 전력사용량의 약 2%를 차지하는 데이터센터는 단일 건물 중 전력을 가장 많이 사용하는 고밀도 에너지 다소비 건물이지만, 안정성을 최우선시하는 보수적인 운영을 고수하여 비효율적인 운영 현황을 보이고 있다. 향후 사물인터넷, 빅 데이터, 클라우드 기술 등의 확산으로 인해 소규모의 데이터센터는 대규모의 데이터센터인 '하이퍼스케일', '메가' 데이터센터로 통합될 것으로 전망되는바, 인프라 확대에 따른 데이터센터 운영관리의 복잡성 또한 심화될 것으로 전망된다. 이에 불필요한 서버는 유휴 혹은 절전모드로 전환하고, 가용되는 서버를 최대한 안정적으로 운영함으로써 데이터센터 운영의 효율성을 극대화하며, 전력소비량을 줄여 운영비용 절감에 기여하기 위하여, 데이터센터에 배치된 수많은 가상 머신들의 배치를 적절하게 하는 것이 매우 중요하다.
물리적 자원(Physical Machine, PM, 물리 서버)들을 논리적 자원(Virtual Machine, VM, 가상 머신)들로 구성하는 가상화 환경에서는 구동 중인 가상 머신을 다른 물리 서버로 이동시킬 수 있는데, 이를 라이브 마이그레이션이라고 한다. 이는 효율적인 데이터센터를 관리하는데 필수적인 관리 방법이다. 다만, 마이그레이션 할 경우 데이터 손실 위험, 리소스의 많은 부분이 차지되는 등의 단점도 있다.
여기서, 기존의 연구(일본특허공보 특허 제5827594, 2015. 10. 23, 등록)들은 특정 시점을 기준으로 임의의 물리 서버에 임계 값 이상의 부하가 걸릴 경우 마이그레이션을 하여, 부하가 걸린 물리 서버의 부하를 저감시키는 방법으로 물리 서버들 간의 균형을 맞추고 있다. 하지만, 이러한 방법은 특정 가상 머신이 마이그레이션된 서버가 과 부화될 가능성이 매우 높아지며, 이로 인해 재차 마이그레이션 과정이 실행되는 것과 같이, 많은 횟수의 마이그레이션이 실행되는 문제가 있다.
본 발명의 해결하고자 하는 과제는 상기 문제점을 해결하기 위하여, 마이그레이션의 횟수를 적게 하여 데이터를 안정적으로 관리할 수 있는, 가상 머신 워크로드 예측 방법, 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치를 제공하고자 한다.
다만, 본 발명이 해결하고자 하는 과제가 상술한 과제로 제한되는 것은 아니며, 언급되지 아니한 과제들은 본 명세서 및 첨부된 도면으로부터 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자에게 명확하게 이해될 수 있을 것이다.
삭제
삭제
삭제
삭제
삭제
삭제
삭제
삭제
삭제
삭제
삭제
삭제
삭제
삭제
삭제
본 발명의 일 실시예에 따른 가상 머신 배치 방법은, 가상 머신 배치 장치를 이용하여, 가상 머신이 설치된 물리 서버 - 상기 물리 서버는 제1 물리 서버 및 제2 물리 서버를 구비함. -를 효율적으로 운용하기 위하여, 복수의 상기 가상 머신을 상기 제1 물리 서버와 상기 제2 물리 서버 상에 배치하는 방법인 가상 머신 배치 방법에 있어서, 상기 제1 물리 서버와 상기 제2 물리 서버의 작동과 관련된 정보를 기초로 미리 정해진 워크 로드 산출 방법에 의해 상기 가상 머신에 의해 부과되는 물리 서버의 부하인 가상 머신 워크 로드와 관련된 정보인 가상 머신 워크 로드 정보가 산출되는 단계; 상기 가상 머신 워크 로드를 기초로 미리 정해진 제1 기간 동안 예측되는 상기 가상 머신에 의해 부과되는 물리 서버의 부하와 연관된 최초 예측 가상 로드와 관련된 정보인 최초 예측 가상 로드 정보가 산출되는 단계; 미리 정해진 배치 일정 산출 방법에 의해 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치 일정과 관련된 정보인 배치 일정 정보가 산출되는 단계; 상기 미리 정해진 배치 일정 산출 방법에 의해 산출된 배치 일정이 표시되는 단계; 및 상기 미리 정해진 배치 일정 산출 방법에 의해 산출된 상기 배치 일정에 따라 상기 제1 물리 서버와 상기 제2 물리 서버 상에 상기 가상 머신이 배치되도록, 상기 가상 머신이 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 이동되면서 배치되는 단계;를 포함하고, 상기 미리 정해진 배치 일정 산출 방법은, 상기 최초 예측 가상 로드 정보를 기초로 목적 함수 값이 최소화될 때의 상기 가상 머신의 상기 배치 일정이 산출되는 방법이며, 상기 미리 정해진 제1 기간 동안에 상기 물리 서버들 간의 상기 가상 머신의 이동이 허용되도록 상기 배치 일정이 산출되는 방법이고, 상기 목적 함수는, 상기 미리 정해진 제1 기간 동안, 상기 최초 예측 가상 로드에 의해 산출되는 물리 서버의 부하의 변화 량과 관련된 함수인 제1 목적 함수를 구비할 수 있다.
또한, 상기 미리 정해진 배치 산출 방법은, 소정 횟수 내에서 상기 미리 정해진 제1 기간 동안에 물리 서버들 간의 가상 머신의 이동이 허용되도록 상기 배치 일정이 산출되는 방법일 수 있다.
또한, 상기 미리 정해진 워크 로드 산출 방법은, 상기 제1 물리 서버와 상기 제2 물리 서버의 사양이 동일하다고 가정하여 산출하는 방법일 수 있다.
또한, 상기 미리 정해진 워크 로드 산출 방법은, CPU의 가동 정도만을 기초로 상기 가상 머신 워크 로드 정보가 산출되는 방법을 포함할 수 있다.
또한, 상기 목적 함수는, 상기 미리 정해진 제1 기간 동안, 상기 최초 예측 가상 로드에 의해 산출되는 물리 서버의 부하들 간의 차이와 관련된 함수인 제2 목적 함수, 상기 가상 머신이 상기 배치 일정에 따라 배치되기 위해서 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 상기 가상 머신이 배치 이동되는 횟수와 관련된 함수인 제3 목적 함수, 상기 미리 정해진 제1 기간 동안, 상기 제1 물리 서버의 가동 여부 및 상기 제2 물리 서버의 가동 여부와 관련된 함수인 제4 목적 함수를 더 구비할 수 있다.
또한, 상기 배치 일정은, 상기 제1 목적 함수의 값이 최소인 상태를 기준으로, 상기 제2 목적 함수의 값, 상기 제3 목적 함수 및 제4 목적 함수의 값이 최소화되는 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치인 제1 배치 일정, 상기 제2 목적 함수의 값이 최소인 상태를 기준으로, 상기 제1 목적 함수의 값, 상기 제3 목적 함수 및 제4 목적 함수의 값이 최소화되는 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치인 제2 배치 일정, 상기 제3 목적 함수의 값이 최소인 상태를 기준으로, 상기 제1 목적 함수의 값, 상기 제2 목적 함수 및 제4 목적 함수의 값이 최소화되는 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치인 제3 배치 일정 및 상기 제4 목적 함수의 값이 최소인 상태를 기준으로, 상기 제1 목적 함수의 값, 상기 제2 목적 함수 및 제3 목적 함수의 값이 최소화되는 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치인 제4 배치 일정을 구비할 수 있다.
또한, 상기 가상 머신은, 상기 배치 일정들 중에서 선택된 하나의 상기 배치 일정에 따라 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 배치될 수 있다.
본 발명의 일 실시예에 따른 가상 머신 배치 장치는, 가상 머신이 설치되는 물리 서버 - 상기 물리 서버는 제1 물리 서버 및 제2 물리 서버를 구비함. - 를 효율적으로 운용하기 위하여, 복수의 상기 가상 머신을 상기 제1 물리 서버와 상기 제2 물리 서버 상에 배치하는 방법인 가상 머신 배치 방법을 구현하는 가상 머신 배치 장치에 있어서, 처리부; 및 상기 가상 머신 배치 방법을 수행하는 프로그램이 저장된 저장부;를 포함하고, 상기 가상 머신 배치 방법은, 상기 제1 물리 서버와 상기 제2 물리 서버의 작동과 관련된 정보를 기초로 미리 정해진 워크 로드 산출 방법에 의해 상기 가상 머신에 의해 부과되는 물리 서버의 부하인 가상 머신 워크 로드와 관련된 정보인 가상 머신 워크 로드 정보가 산출되는 단계; 상기 가상 머신 워크 로드를 기초로 미리 정해진 제1 기간 동안 예측되는 상기 가상 머신에 의해 부과되는 물리 서버의 부하와 연관된 최초 예측 가상 로드와 관련된 정보인 최초 예측 가상 로드 정보가 산출되는 단계; 미리 정해진 배치 일정 산출 방법에 의해 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치 일정과 관련된 정보인 배치 일정 정보가 산출되는 단계; 상기 미리 정해진 배치 일정 산출 방법에 의해 산출된 배치 일정이 표시되는 단계; 및 상기 미리 정해진 배치 일정 산출 방법에 의해 산출된 상기 배치 일정에 따라 상기 제1 물리 서버와 상기 제2 물리 서버 상에 상기 가상 머신이 배치되도록, 상기 가상 머신이 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 이동되면서 배치되는 단계;를 포함하고, 상기 미리 정해진 배치 일정 산출 방법은, 상기 최초 예측 가상 로드 정보를 기초로 목적 함수 값이 최소화될 때의 상기 가상 머신의 상기 배치 일정이 산출되는 방법이며, 상기 미리 정해진 제1 기간 동안에 상기 물리 서버들 간의 상기 가상 머신의 이동이 허용되도록 상기 배치 일정이 산출되는 방법이고, 상기 목적 함수는, 상기 미리 정해진 제1 기간 동안, 상기 최초 예측 가상 로드에 의해 산출되는 물리 서버의 부하의 변화 량과 관련된 함수인 제1 목적 함수를 구비할 수 있다.
또한, 상기 미리 정해진 배치 산출 방법은, 소정 횟수 내에서 상기 미리 정해진 제1 기간 동안에 물리 서버들 간의 가상 머신의 이동이 허용되도록 상기 배치 일정이 산출되는 방법일 수 있다.
또한, 상기 미리 정해진 워크 로드 산출 방법은, 상기 제1 물리 서버와 상기 제2 물리 서버의 사양이 동일하다고 가정하여 산출하는 방법일 수 있다.
또한, 상기 목적 함수는, 상기 미리 정해진 제1 기간 동안, 상기 최초 예측 가상 로드에 의해 산출되는 물리 서버의 부하들 간의 차이와 관련된 함수인 제2 목적 함수, 상기 가상 머신이 상기 배치 일정에 따라 배치되기 위해서 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 상기 가상 머신이 배치 이동되는 횟수와 관련된 함수인 제3 목적 함수, 상기 미리 정해진 제1 기간 동안, 상기 제1 물리 서버의 가동 여부 및 상기 제2 물리 서버의 가동 여부와 관련된 함수인 제4 목적 함수를 더 구비할 수 있다.
본 발명에 따른 가상 머신 워크로드 예측 방법, 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치는 데이터 손실을 최소화할 수 있다.
또한, 리소스의 소요를 최소화할 수 있다.
또한, 데이터센터를 안정적으로 관리할 수 있다.
다만, 본 발명의 효과가 상술한 효과들로 제한되는 것은 아니며, 언급되지 아니한 효과들은 본 명세서 및 첨부된 도면으로부터 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자에게 명확히 이해될 수 있을 것이다.
도 1은 본 발명의 일 실시예에 따른 가상 머신 배치 장치의 개념도 및 상기 가상 머신 배치 장치와 복수의 물리 서버와의 관계를 도시한 도면
도 2는 본 발명의 일 실시예에 따른 가상 머신 배치 방법의 순서도
도 3은 본 발명의 일 실시예에 따른 가상 머신 배치 방법 중에서 제1 목적 함수를 고려한 가상 머신 배치로서 달성되는 효과를 설명하기 위한 그래프
도 4는 본 발명의 일 실시예에 따른 가상 머신 배치 방법 중에서 제2 목적 함수를 고려한 가상 머신 배치로서 달성되는 효과를 설명하기 위한 그래프
도 5는 본 발명의 일 실시예에 따른 가상 머신 배치 방법 중에서 배치 일정 산출 단계를 설명하기 위한 도면
도 6은 본 발명의 일 실시예에 따른 가상 머신 배치 방법 중에서 예측 오류를 산출하는 방법을 설명하기 위한 그래프
이하에서는 도면을 참조하여 본 발명의 구체적인 실시예를 상세하게 설명한다. 다만, 본 발명의 사상은 제시되는 실시예에 제한되지 아니하고, 본 발명의 사상을 이해하는 당업자는 동일한 사상의 범위 내에서 다른 구성요소를 추가, 변경, 삭제 등을 통하여, 퇴보적인 다른 발명이나 본 발명 사상의 범위 내에 포함되는 다른 실시예를 용이하게 제안할 수 있을 것이나, 이 또한 본원 발명 사상 범위 내에 포함된다고 할 것이다.
또한, 각 실시예의 도면에 나타나는 동일한 사상의 범위 내의 기능이 동일한 구성요소는 동일한 참조부호를 사용하여 설명한다.
본 명세서에서 본 발명에 관련된 공지의 구성 또는 기능에 대한 구체적인 설명이 본 발명의 요지를 흐릴 수 있다고 판단되는 경우에 이에 관한 자세한 설명은 생략하기로 한다.
도 1은 본 발명의 일 실시예에 따른 가상 머신 배치 장치의 개념도 및 상기 가상 머신 배치 장치와 복수의 물리 서버와의 관계를 도시한 도면이다.
도 1을 참조하면, 본 발명의 일 실시예에 따른 가상 머신 배치 장치(10)는 가상 머신을 배치하고 정렬하는데 필요한 정보(일례로, 데이터)를 처리하는 처리부(11), 가상 머신을 배치하고 정렬하는데 필요한 정보를 저장하는 저장부(12), 가상 머신을 배치하고 정렬하는데 필요한 정보를 수신하는 수신부(13) 및 가상 머신을 배치하고 정렬하는데 필요한 정보를 송신하는 송신부(14)를 구비할 수 있다.
또한, 상기 가상 머신 배치 장치(10)는 외부로부터 입력되는 것들에 의해 발생되는 정보를 상기 수신부(13)로 전달하는 입력부(15) 및 후술하는 배치 일정을 표시하여 상기 배치 일정을 사용자에게 전달하는 매개체는 표시부(16)를 더 포함할 수 있다.
상기 처리부(11)는 상기 저장부에 저장되어 있는 정보를 기초로 상기 가상 머신 배치 방법이 구현되는데 필요한 모든 정보 처리와 같은 연산을 수행할 수 있다.
일례로, 상기 처리부(11)는 중앙처리장치(CPU)를 의미할 수 있다.
다만, 이에 한정하지 않고 상기 처리부(11)는 상기 가상 머신 배치 방법이 구현되는데 필요한 연산을 수행할 수 있는 모든 장치 혹은 부품을 포함할 수 있다.
상기 저장부(12)는 상기 가상 머신 배치 방법이 구현되는데 필요한 정보(데이터)가 저장되어 있을 수 있다.
상기 저장부(12)에는 상기 가상 머신 배치 방법을 수행하는 프로그램이 저장되어 있을 수 있다.
일례로, 상기 저장부(12)는 보조기억장치로서 하드디스크일 수 있다.
다만, 이에 한정하지 않고 상기 저장부(12)는 상기 가상 머신 배치 방법이 구현되는데 필요한 정보가 저장될 수 있는 모든 요소를 포함할 수 있다.
일례로, 상기 저장부(12)는 데이터베이스일 수 있다.
상기 수신부(13)는 물리 서버로부터 전달되는 정보를 수신할 수 있다.
상기 수신부(13)는 상기 물리 서버의 작동과 관련된 정보를 대응되는 물리 서버로부터 전달받을 수 있다.
상기 송신부(14)는 상기 물리 서버로 정보를 전달할 수 있다.
상기 송신부(14)는 상기 처리부(11)가 산출한 제어 신호를 상기 물리 서버로 전달할 수 있다.
이로 인해 상기 가상 머신 배치 장치(10)는 하나의 물리 서버에 상에서 구동되는 가상 머신을 다른 물리 서버로 마이그레이션되도록, 각 각의 물리 서버에 제어 신호를 전달할 수 있다.
일례로, 상기 입력부(15)는 키보드일 수 있다.
다만, 이에 한정하지 않고 상기 입력부(15)의 종류는 통상의 기술자에게 자명한 수준에서 다양하게 변형 가능하다.
일례로, 상기 표시부(16)는 디스플레이일 수 있다.
다만, 이에 한정하지 않고 상기 표시부(16)의 종류는 통상의 기술자에게 자명한 수준에서 다양하게 변형 가능하다.
상기 가상 머신 배치 장치(10) 내의 구성은 서로 유선 및/또는 무선으로 연결될 수 있다.
상기 가상 머신 배치 장치(10)는 각 각의 상기 물리 서버와 유선 및/또는 무선으로 연결될 수 있다.
물리 서버는 가상 머신이 실행될 수 있는 하드웨어 플랫폼을 의미할 수 있다.
일례로, 상기 물리 서버는 통상적인 데스크톱, 서버 컴퓨터, 랩톱 컴퓨터 또는 휴대 전화 등과 같은 것일 수 있다.
다만, 이에 한정하지 않고 상기 물리 서버는 가상 머신이 실행될 수 있는 모든 수단을 포함하는 개념일 수 있다.
본 발명의 일 실시예에 따른 가상 머신 배치 장치(10)는 제1 물리 서버(20), 제2 물리 서버(30) 및 제3 물리 서버(40)를 통제하고 관리하는 것을 기준으로 설명하나, 이에 본 발명이 한정되는 것은 아니고, 상기 가상 머신 배치 장치(10)가 관리 및 통제하는 물리 서버의 개수는 통상의 기술자에게 자명한 수준에서 다양하게 변형 가능하다.
도 1에 도시된 것에 따르면, 물리 서버는 제1 물리 서버(20), 제2 물리 서버(30) 및 제3 물리 서버(40)로 이루어지며, 상기 제1 물리 서버(20) 상에서는 제a 가상 머신(21), 제b 가상 머신(22) 및 제c 가상 머신(23)이 구동되고 있을 수 있으며, 상기 제2 물리 서버(30) 상에는 제d 가상 머신(31) 및 제e 가상 머신(32)이 구동되고 있을 수 있으며, 상기 제3 물리 서버(40) 상에는 제f 가상 머신(41) 및 제g 가상 머신(42)이 구동되고 있을 수 있다.
이하, 가상 머신 배치 장치(10)를 이용하여 구현되는 가상 머신 배치 방법에 대해서 자세하게 서술하도록 한다.
도 2는 본 발명의 일 실시예에 따른 가상 머신 배치 방법의 순서도이다.
도 2를 참조하면, 본 발명의 일 실시예에 따른 가상 머신 배치 방법은, 가상 머신이 설치된 물리 서버 - 상기 물리 서버는 제1 물리 서버 및 제2 물리 서버를 구비함. -를 효율적으로 운용하기 위하여, 복수의 상기 가상 머신을 상기 제1 물리 서버와 상기 제2 물리 서버 상에 배치하는 방법인 가상 머신 배치 방법에 있어서, 상기 제1 물리 서버와 상기 제2 물리 서버의 작동과 관련된 정보를 기초로 미리 정해진 워크 로드 산출 방법에 의해 상기 가상 머신에 의해 부과되는 물리 서버의 부하인 가상 머신 워크 로드와 관련된 정보인 가상 머신 워크 로드 정보가 산출되는 단계(S10), 상기 가상 머신 워크 로드를 기초로 미리 정해진 제1 기간 동안 예측되는 상기 가상 머신에 의해 부과되는 물리 서버의 부하와 연관된 최초 예측 가상 로드와 관련된 정보인 최초 예측 가상 로드 정보가 산출되는 단계(S20), 미리 정해진 배치 일정 산출 방법에 의해 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치 일정과 관련된 정보인 배치 일정 정보가 산출되는 단계(S30) 및 상기 미리 정해진 배치 일정 산출 방법에 의해 산출된 상기 배치 일정에 따라 상기 제1 물리 서버와 상기 제2 물리 서버 상에 상기 가상 머신이 배치되도록, 상기 가상 머신이 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 이동되면서 배치되는 단계(S50)를 포함할 수 있다.
또한, 상기 가상 머신 배치 방법은 상기 미리 정해진 배치 일정 산출 방법에 의해 산출된 복수의 배치 일정이 상기 표시부에 의해 표시되는 단계(S40)를 더 포함할 수 있다.
또한, 상기 가상 머신 배치 방법은 상기 표시부에 의해 표시된 상기 배치 일정 중에서 하나의 배치 일정인 선택된 배치 일정이 상기 입력부에 의해 입력되어, 선택된 배치 일정과 관련된 정보가 상기 처리부로 전달되는 단계(S50)를 더 포함할 수 있다.
또한, 상기 가상 머신 배치 방법은 선택된 상기 배치 일정에 따라 상기 가상 머신이 상기 제1 물리 서버와 상기 제2 물리 서버에 배치되는 경우, 예측되는 물리 서버의 부하와 연관된 선택 예측 가상 로드와 관련된 정보인 선택 예측 가상 로드 정보와 가상 머신의 실제 워크 로드와 관련된 정보인 실제 가상 워크 로드 정보를 기초로 미리 정해진 점검 방법에 따라 상기 선택 예측 가상 로드 정보가 정상적으로 산출되었는지 여부를 판단하는 단계(S70)를 더 포함할 수 있다.
상기 저장부에는 상기 제1 물리 서버의 작동 관련된 정보, 상기 제2 물리 서버의 작동과 관련된 정보 및 상기 제3 물리 서버의 작동과 관련된 정보가 저장되어 있을 수 있다.
일례로, 상기 제1 물리 서버, 상기 제2 물리 서버 및 상기 제3 물리 서버의 작동과 관련된 정보는 시계열적으로 상기 저장부에 저장되어 있을 수 있다.
이를 위해 상기 제1 물리 서버, 상기 제2 물리 서버 및 상기 제3 물리 서버로부터 각 각의 작동과 관련된 정보를 상기 수신부가 전달받을 수 있다.
일례로, 작동과 관련된 정보는 물리 서버의 구성들의 가동률과 관련된 정보 일 수도 있다.
상기 처리부는 상기 저장부에 저장된 각 각의 물리 서버들의 작동과 관련된 정보를 기초로 미리 정해진 워크 로드 산출 방법에 의해 상기 가상 머신에 의해 부과되는 물리 서버의 부하인 가상 머신 워크 로드와 관련된 정보인 가상 머신 워크 로드 정보를 산출(S10)할 수 있다.
가상 머신 워크 로드는 가상 머신이 물리 서버 상에서 구동되는 경우, 해당 물리 서버의 리소스의 부하를 의미할 수 있다.
상기 가상 머신 워크 로드는 상기 가상 머신이 상기 물리 서버 상에서 구동되는 경우 상기 물리 서버에 인가되는 부하를 의미할 수 있다.
일례로, 상기 가상 머신 워크 로드는 상기 가상 머신이 상기 물리 서버에서 동작되는 것에 의해 상기 물리 서버의 중앙처리장치(CPU)에 부과되는 부하로서 산출될 수 있다.
따라서, 상기 미리 정해진 워크 로드 산출 방법은 물리 서버의 중앙처리장치에 부과되는 부하로서 상기 가상 머신 워크 로드를 산출하는 방법을 포함할 수 있다.
다시 말해서, 상기 미리 정해진 워크 로드 산출 방법은 CPU의 가동 정도만을 기초로 상기 가상 머신 워크 로드 정보가 산출될 수 있다.
상기 미리 정해진 워크 로드 산출 방법 상에서는 하나의 가상 머신은 하나의 물리 서버 상에서만 실행될 수 있다고 가정할 수 있다.
일례로, 이는 하나의 가상 머신은 두 개의 물리 서버 상에서 구현될 수 없다는 것을 의미할 수 있다.
물리 서버의 워크 로드라는 것의 의미는 상기 물리 서버에 부과되는 부하를 의미할 수 있다.
일례로, 상기 물리 서버의 워크 로드는 상기 물리 서버의 중앙처리장치(CPU)에 부과되는 부하로서 산출될 수 있다.
일례로, 물리 서버의 워크 로드는 물리 서버에 배치되는 가상 머신들의 부하(워크 로드)인 가상 머신 워크 로드들의 합에 의해 산출될 수 있다.
이는, 후술하는 예측하는데 필요한 기초 데이터를 단순화 함으로써, 후술하는 단계에서 예측의 정확도를 더욱 상승시킬 수 있다.
상기 처리부는 상기 가상 머신 워크 로드 정보를 기초로 기준 시점에서부터 미래의 기간인 미리 정해진 제1 기간 동안 예측되는 상기 가상 머신에 의해 부과되는 물리 서버의 부하와 연관된 최초 예측 가상 로드와 관련된 정보인 최초 예측 가상 로드 정보를 산출(S20)할 수 있다.
일례로, 기준 시점은 가상 머신 워크 로드 정보 산출 시점일 수 있다.
다만, 이에 한정하지 않고 상기 기준 시점은 통상의 기술자에게 자명한 수준에서 다양하게 변형 가능하다.
상기 최초 예측 가상 로드가 산출되기 위해서, 상기 미리 정해진 제1 기간 동안에 각 각의 상기 가상 머신들의 워크 로드인 가상 머신 워크 로드 정보가 예측될 수 있다.
미리 정해진 제1 기간 동안의 가상 머신의 워크 로드를 예측하여, 이를 기준으로 가상 머신들을 재 배치 하는 이유로는, 특정 시점의 과부화를 기초로 마이그레이션을 할 경우, 마이그레이션의 횟수 증가 및 전반적인 물리 서버의 안정화를 구현할 수 없기 때문이다.
따라서, 미래의 특정 시점이 아닌 특정 기간을 기초로 가상 머신을 물리 서버 상에 배치하여, 상술한 문제점을 효과적으로 해결할 수 있다.
일례로, 미리 정해진 제1 기간은 3 개월일 수 있다.
다만, 이에 본 발명이 한정되는 것은 아니고 상기 미리 정해진 제1 기간은 통상의 기술자에게 자명한 수준에서 다양하게 변형 가능하다.
일례로, 상기 처리부는 상기 저장부에 저장된 상기 가상 머신 워크 로드 정보를 기초로 다중회귀모형, ARIMA 분석 또는 Deep Learning과 같은 알고리즘을 활용하여 상기 미리 정해진 제1 기간 동안의 가상 머신 워크 로드 정보를 산출할 수 있다.
상기 처리부는 산출된 상기 미리 정해진 제1 기간 동안의 가상 머신 워크 로드 정보를 기초로 상기 미리 정해진 제1 기간 동안의 예측되는 물리 서버의 워크 로드를 산출할 수 있다.
이는, 통상의 기술자에게 자명한 기술로서 이에 대한 자세한 설명은 생략될 수 있다.
일례로, 최초 예측 가상 로드란 상기 가상 머신 워크 로드 정보 산출 시점에서부터 미리 정해진 제1 기간 동안 또는 임의의 시점에서부터 미리 정해진 제1 기간 동안 예측되는 가상 머신의 워크 로드를 의미할 수 있다.
상기 처리부는 미리 정해진 배치 일정 산출 방법에 의해 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치인 배치 일정과 관련된 정보인 배치 일정 정보를 산출(S30)할 수 있다.
여기서, 상기 미리 정해진 배치 일정 산출 방법은, 상기 최초 예측 가상 로드 정보를 기초로 목적 함수 값이 최소화될 때의 상기 가상 머신의 상기 배치 일정이 산출되는 방법을 의미할 수 있다.
상기 미리 정해진 배치 일정 산출 방법은 임의의 물리 서버에 대해서 상기 물리 서버의 부하가 미리 정해진 범위 내에서만 부과되도록, 상기 가상 머신의 배치 일정이 산출되는 방법을 포함할 수 있다. (제1 조건)
일례로, 상기 미리 정해진 범위는 물리 서버의 가동률(부하가 부과되는 정도)이 10% ~ 80%일 수 있다.
다만, 이에 한정하지 않고 상기 미리 정해진 범위는 통상의 기술자에게 자명한 수준에서 다양하게 변형 가능하다.
상기 미리 정해진 배치 산출 방법은 상기 임의의 물리 서버에 대해서 상기 물리 서버의 부하가 미리 정해진 범위 내에서만 부과될 수 있도록, 상기 임의의 물리 서버의 부하가 제1 기준(X10, 도 3 및 도 4 참조) 이상 될 것으로 예측될 경우에는, 상기 임의의 물리 서버에 배치된 상기 가상 머신들 중 적어도 하나의 상기 가상 머신을 다른 물리 서버로 이동시키는 방법을 포함할 수 있다. (제1-1 조건)
일례로, 상기 제1 기준(X10, 도 3 및 도 4 참조)은 상기 물리 서버의 가동률(부하가 부과되는 정도)이 80 %인 것을 의미할 수 있다.
상기 처리부는 상기 물리 서버의 부하가 제1 기준이 넘지 않도록 하는 해결 방법으로, 대상 물리 서버의 워크 로드가 제1 기준이 넘을 것으로 예측되는 시점을 기준으로, 상기 대상 물리 서버에 배치되는 적어도 하나의 가상 머신을 다른 물리 서버로 이전 하는 방법을 이용하여 상기 배치 일정을 산출할 수 있다.
이로 인해, 상기 물리 서버의 워크 로드(가동률)가 제1 기준을 넘어 과잉 부하가 인가되는 것을 효과적으로 예방할 수 있다.
다만, 이에 한정하지 않고 상기 제1 기준은 통상의 기술자에게 자명한 수준에서 다양하게 변형 가능하다.
또한, 상기 미리 정해진 배치 산출 방법은 상기 임의의 물리 서버에 대해서 상기 물리 서버의 부하가 미리 정해진 범위 내에서만 부과될 수 있도록, 상기 임의의 물리 서버의 부하가 제2 기준(X20, 도 3 및 도 4 참조) 이하 될 것으로 예측될 경우에는, 상기 임의의 물리 서버에 배치된 상기 가상 머신들 모두를 다른 물리 서버로 이동시키는 방법을 포함할 수 있다. (제1-2 조건)
일례로, 상기 제2 기준(X20, 도 3 및 도 4 참조)은 상기 물리 서버의 가동률(부하가 부과되는 정도)이 10 %인 것을 의미할 수 있다.
상기 처리부는 상기 물리 서버 부하가 제2 기준 이하로 되지 않도록 하는 해결 방법으로, 대상 물리 서버의 워크 로드가 제2 기준 이하로 떨어질 것으로 예측되는 시점을 기준으로, 상기 대상 물리 서버에 배치되는 모든 가상 머신들을 다른 물리 서버로 이전하는 방법을 이용하여 상기 배치 일정을 산출할 수 있다.
이는, 물리 서버가 가동되지 않는 조건의 개시 조건을 의미할 수 있다.
다시 말하면, 상기 처리부는 상기 물리 서버 부하가 제2 기준 이하로 되지 않도록 하는 해결 방법으로, 대상 물리 서버에 배치된 가상 머신을 다른 물리 서버로 배치하여, 대상 물리 서버의 동작을 정지시킬 수 있다.
상기 미리 정해진 배치 산출 방법은 가동되지 않는 상기 물리 서버가 가동되도록 하는 상기 가상 머신의 이동으로 인해 가동 중인 상기 물리 서버가 가동되지 않는 상태로 변화되지 않도록, 상기 배치 일정 정보가 산출되는 방법을 포함할 수 있다. (제2 조건)
하나의 물리 서버를 중단 시키는 것과 동시에 다른 물리 서버의 동작을 개시하게 되면, 물리 서버를 중단 시키는 것에 대한 이익이 없으며, 서버를 가동하는데 발생되는 전력 및 시간이 더 소요되기 문제가 발생된다.
따라서, 제2 조건을 통해, 이와 같은 문제를 해결하고자 하는 것일 수 있다.
이에 대한 자세한 설명은 후술한다.
또한, 상기 미리 정해진 배치 산출 방법으로 배치 일정을 산출하는 경우, 상기 미리 정해진 제1 기간 동안에 물리 서버들 간의 가상 머신의 이동이 허용되도록 배치 일정이 산출될 수 있다. (제3 조건)
다만, 가상 머신의 이동이 잦을 경우 데이터 손실이 유발될 수 있기 때문에, 상기 미리 정해진 제1 기간 동안의 하나의 가상 머신의 이동을 소정 횟수로 제한할 수 있다. (제4 조건)
일례로, 소정 횟수는 2회일 수 있다.
다만, 이에 한정하지 않고 상기 소정 횟수는 통상의 기술자에게 자명한 수준에서 다양하게 변형 가능하다.
또한, 상기 미리 정해진 배치 산출 방법으로 배치 일정을 산출하는 경우, 각 각의 물리 서버의 사양이 동일(homogenous 조건)하다고 가정하여 배치 일정을 산출할 수 있다. (제5 조건)
상기 목적 함수는 제1 목적 함수, 제2 목적 함수, 제 3 목적 함수 및 제4 목적 함수를 구비할 수 있다.
상기 처리부는 각 각의 목적 함수 값들이 최소 값을 갖는 비 지배해 4 개를 산출할 수 있다.
따라서, 상기 미리 정해진 배치 일정 산출 방법에 의하면, 4 개의 배치 일정이 산출될 수 있다.
이하, 상기 미리 정해진 배치 일정 산출 방법에 대해서 자세하게 서술하도록 한다.
도 3은 본 발명의 일 실시예에 따른 가상 머신 배치 방법 중에서 제1 목적 함수를 고려한 가상 머신 배치로서 달성되는 효과를 설명하기 위한 그래프이다.
도 3을 참조하면, 상기 목적 함수는 상기 미리 정해진 제1 기간 동안, 상기 최초 예측 가상 로드에 의해 산출되는 물리 서버의 부하(워크 로드)의 변화 량과 관련된 함수인 제1 목적 함수를 구비할 수 있다.
일례로, 도 3(a)는 제1 일정에 따라 가상 머신들이 제1 물리 서버 내지 제3 물리 서버에 배치되는 경우, 상기 제1 물리 서버 내지 제3 물리 서버의 워크 로드를 도시한 그래프이다.
또한, 도 3(b)는 제2 일정에 따라 가상 머신들이 제1 물리 서버 내지 제3 물리 서버에 배치되는 경우, 상기 제1 물리 서버 내지 제3 물리 서버의 워크 로드를 도시한 그래프이다.
각 각의 물리 서버의 워크 로드는 각 물리 서버에 설치된 가상 머신 워크 로드들의 합으로 산출될 수 있음을 상술된 내용에서 확인할 수 있다.
도 3(a)를 참조하면, 가상 머신들이 제1 일정에 따라 물리 서버 상에 배치되는 경우, 모든 물리 서버의 워크 로드가 제1 기준 미만(X10) 및 제2 기준 초과(X20)가 될 수 있다.
또한, 도 3(b)를 참조하면, 가상 머신들이 제2 일정에 따라 물리 서버 상에 배치되는 경우, 모든 물리 서버의 워크 로드가 제1 기준 미만(X10) 및 제2 기준 초과(X20)가 될 수 있다.
다만, 제2 일정을 기초로 하여 가상 머신들이 물리 서버에 배치되는 경우, 제1 일정을 기초로 가상 머신들이 물리 서버에 배치되는 경우보다, 각 각의 물리 서버의 워크 로드의 변화량(기울기)가 더 작을 수 있다.
이는, 물리 서버 상의 가상 머신의 배치 일정으로서 제1 일정보다 제2 일정이 더 바람직한 일정일 수 있다.
또한, 상기 제2 일정이 도출되도록 하는 제1 목적 함수의 값이 상기 제1 일정이 도출되도록 하는 제1 목적 함수의 값 보다 더 작을 수 있다.
만일 물리 서버의 워크 로드의 변화율이 크다면, 짧은 시간 동안만 물리 서버의 워크 로드가 임의의 기준이 넘어, 가상 머신의 마이그레이션(이전)이 이루어질 수 있다.
이럴 경우, 앞서 상술한 가상 머신의 잦은 마이그레이션이 발생될 수 있으므로, 가상 머신의 데이터 손실의 위험성이 더욱 높아질 수 있다.
제1 목적 함수는 이를 예방하기 위한 함수일 수 있다.
도 4는 본 발명의 일 실시예에 따른 가상 머신 배치 방법 중에서 제2 목적 함수를 고려한 가상 머신 배치로서 달성되는 효과를 설명하기 위한 그래프이다.
도 4를 참조하면, 상기 목적 함수는 상기 미리 정해진 제1 기간 동안, 상기 최초 예측 가상 로드에 의해 산출되는 물리 서버의 부하(워크 로드)들 간의 차이와 관련된 함수인 제2 목적 함수를 구비할 수 있다.
일례로, 도 4(a)는 제3 일정에 따라 가상 머신들이 제1 물리 서버 내지 제3 물리 서버에 배치되는 경우, 상기 제1 물리 서버 내지 제3 물리 서버의 워크 로드를 도시한 그래프이다.
또한, 도 4(b)는 제4 일정에 따라 가상 머신들이 제1 물리 서버 내지 제3 물리 서버에 배치되는 경우, 상기 제1 물리 서버 내지 제3 물리 서버의 워크 로드를 도시한 그래프이다.
각 각의 물리 서버의 워크 로드는 각 물리 서버에 설치된 가상 머신 워크 로드들의 합으로 산출될 수 있음을 상술된 내용에서 확인할 수 있다.
도 4(a)를 참조하면, 가상 머신들이 제3 일정에 따라 물리 서버 상에 배치되는 경우, 모든 물리 서버의 워크 로드가 제1 기준(X10) 미만 및 제2 기준(X20) 초과가 될 수 있다.
또한, 도 4(b)를 참조하면, 가상 머신들이 제4 일정에 따라 물리 서버 상에 배치되는 경우, 모든 물리 서버의 워크 로드가 제1 기준(X10) 미만 및 제2 기준(X20) 초과가 될 수 있다.
다만, 제4 일정을 기초로 하여 가상 머신들이 물리 서버에 배치되는 경우, 제3 일정을 기초로 가상 머신들이 물리 서버에 배치되는 경우보다, 각 각의 물리 서버의 워크 로드들 간의 차이가 더 작을 수 있다.
이는, 물리 서버 상의 가상 머신의 배치 일정으로서 제3 일정보다 제4 일정이 더 바람직한 일정일 수 있다.
또한, 상기 제4 일정이 도출되도록 하는 제2 목적 함수의 값이 상기 제3 일정이 도출되도록 하는 제2 목적 함수의 값 보다 더 작을 수 있다.
여기서, 물리 서버들 간의 워크 로드를 비교하기 위해서, 상기 미리 정해진 제1 기간 동안의 물리 서버의 워크 로드의 평균 값을 활용하여 물리 서버들이 서로 비교될 수 있다.
제2 목적 함수의 의미는 물리 서버를 고르게 활용하고자 함일 수 있다.
상기 목적 함수는 상기 가상 머신이 상기 배치 일정에 따라 배치되기 위해서 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 상기 가상 머신이 배치 이동되는 횟수와 관련된 함수인 제3 목적 함수를 구비할 수 있다.
다시 말하면, 상기 제3 목적 함수는 현재의 가상 머신들의 배치에서 배치 일정을 따라 배치되기 위하여 물리 서버들 사이에서 가상 머신의 이동 횟수와 관련될 수 있다.
상기 제3 목적 함수의 의미는, 상기 가상 머신의 이동 횟수를 최소하는 배치를 찾고자 함일 수 있다.
가상 머신이 마이그레이션 될 때 마다 데이터 손실의 위험성을 항상 내포하고 있다.
제3 목적 함수의 의미는 데이터 손실 가능성을 최소화하는데 있을 수 있다.
상기 목적 함수는 상기 미리 정해진 제1 기간 동안, 상기 제1 물리 서버의 가동 여부 및 상기 제2 물리 서버의 가동 여부와 관련된 함수인 제4 목적 함수를 구비할 수 있다.
다시 말하면, 상기 제4 목적 함수는 상기 미리 정해진 제1 기간 동안 물리 서버의 가동 여부와 관련된 함수일 수 있다.
제4 목적 함수가 작을수록 가동되지 않는 물리 서버의 개수 및 물리 서버의 가동되지 않는 시간이 최대로 될 수 있다.
상기 제4 목적 함수가 최소일 경우, 모든 물리 서버에 대해서 물리 서버 한대 당 가동되지 않는 시간들의 총합이 최대로 될 수 있다.
제4 목적 함수의 의미는 서버 가동 시간을 최소화 하여 물리 서버 가동에 따란 전력 손실을 최소화 하는데 의미가 있을 수 있다.
배치 일정은 제1 조건 내지 제5 조건이 만족되는 상태에서 각각의 목적 함수가 최소화될 수 있도록, 물리 서버들 상에서 가상 머신들이 어떻게 배치되는지에 대한 일정을 의미할 수 있다.
상기 목적 함수는 상기 미리 정해진 제1 기간 동안, 상기 최초 예측 가상 로드에 의해 산출되는 물리 서버의 부하의 변화 량과 관련된 함수인 제1 목적 함수, 상기 미리 정해진 제1 기간 동안, 상기 최초 예측 가상 로드에 의해 산출되는 물리 서버의 부하들 간의 차이와 관련된 함수인 제2 목적 함수, 상기 가상 머신이 상기 탐색 배치로 배치되기 위해서 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 상기 가상 머신이 배치 이동되는 횟수와 관련된 함수인 제3 목적 함수 및 상기 미리 정해진 제1 기간 동안, 상기 제1 물리 서버의 가동 여부 및 상기 제2 물리 서버의 가동 여부와 관련된 함수인 제4 목적 함수를 구비할 수 있다.
상기 표시부는 상기 처리부에서 전달되는 배치 일정들을 표시(S40)할 수 있다.
상기 처리부는 제1 배치 일정과 관련된 정보인 제1 배치 일정 정보, 상기 제2 배치 일정과 관련된 정보인 제2 배치 일정 정보, 제3 배치 일정과 관련된 정보인 제3 배치 일정 정보 및 제4 배치 일정과 관련된 정보인 제4 배치 일정 정보를 산출한 뒤에 상기 표시부에 전달할 수 있다.
상기 배치 일정은 상기 제1 목적 함수의 값이 최소인 상태를 기준으로, 상기 제2 목적 함수의 값, 상기 제3 목적 함수 및 제4 목적 함수의 값이 최소화되는 물리 서버들(일례로, 제1 물리 서버와 상기 제2 물리 서버) 상의 상기 가상 머신의 배치인 제1 배치 일정, 상기 제2 목적 함수의 값이 최소인 상태를 기준으로, 상기 제1 목적 함수의 값, 상기 제3 목적 함수 및 제4 목적 함수의 값이 최소화되는 물리 서버들(일례로, 제1 물리 서버와 제2 물리 서버) 상의 상기 가상 머신의 배치인 제2 배치 일정, 상기 제3 목적 함수의 값이 최소인 상태를 기준으로, 상기 제1 목적 함수의 값, 상기 제2 목적 함수 및 제4 목적 함수의 값이 최소화되는 물리 서버들(일례로, 제1 물리 서버와 제2 물리 서버) 상의 상기 가상 머신의 배치인 제3 배치 일정 및 상기 제4 목적 함수의 값이 최소인 상태를 기준으로, 상기 제1 목적 함수의 값, 상기 제2 목적 함수 및 제3 목적 함수의 값이 최소화되는 물리 서버들(일례로, 제1 물리 서버와 제2 물리 서버) 상의 상기 가상 머신의 배치인 제4 배치 일정을 구비할 수 있다.
이하, 하나의 배치 일정을 예시로서 미리 정해진 배치 일정 산출 방법을 설명하도록 한다.
도 5는 본 발명의 일 실시예에 따른 가상 머신 배치 방법 중에서 배치 일정 산출 단계를 설명하기 위한 도면이다.
도 5는 미리 정해진 제1 기간 중에서 일정 기간에 대해서 물리 서버들에 배치되는 가상 머신들의 일정을 도식화한 도면이다.
일례로, 도 5에 도시된 예시는 제1 목적 함수가 최소화되는 것을 기준으로 하는 제1 배치 일정에 관한 것일 수 있으며, 이하, 이를 기준으로 서술하도록 한다.
다만, 이는 하나의 예시적인 것으로서 이에 본 발명이 한정되지 않는 것은 자명하다.
일례로, 물리 서버는 제1 물리 서버(20), 제2 물리 서버(30) 및 제3 물리 서버(40)로 이루어질 수 있으며, 가상 머신은 제1 가상 머신(91), 제2 가상 머신(92), 제3 가상 머신(93), 제4 가상 머신(94), 제5 가상 머신(95), 제6 가상 머신(96) 및 제7 가상 머신(97)을 구비할 수 있다.
일례로, 상기 처리부는 제1 목적 함수가 최소화되는 상태에서 다른 목적 함수가 최소화될 수 있도록 제1 시간 이전 시간인 제0 시간에는 제1 물리 서버(20)에는 제1 가상 머신(91)과 제2 가상 머신(92)이 배치되도록 하고, 제2 물리 서버(30)에는 제3 가상 머신(93), 제4 가상 머신(94) 및 제5 가상 머신(95)이 배치되도록 하고, 제3 물리 서버(40)에는 제6 가상 머신(96) 및 제7 가상 머신(97)이 배치되도록 배치 일정을 산출할 수 있다.
만일, 상기 제0 시간 대의 가상 머신들에 배치를 따를 경우, 제1 시간에는 제1 물리 서버의 워크 로드가 제2 기준 이하라고 예측될 수 있다.
이와 같을 경우, 제1-2 조건이 만족되는 경우로서, 제1 물리 서버(20)에 배치되어 있는 가상 머신들인 제1 가상 머신(91)과 제2 가상 머신(92)이 다른 물리 서버로 이동되도록 배치 일정이 산출될 수 있다.
여기서, 제1-2 조건 하에 가상 머신이 이전되는 경우, 제1 목적 함수가 최소화 되는 것을 기준으로 어느 물리 서버로 이전되는지가 결정될 수 있다.
이를 기초로 제1 가상 머신(91)은 제2 물리 서버(30)로 이동되고, 제2 가상 머신(92)은 제3 물리 서버(40)로 이동되도록 배치 일정이 산출될 수 있다.
제1 시간에서의 마이그레이션에 의해 제2 시간에는 제1 물리 서버(20)는 가동되지 않도록 배치 일정이 산출될 수 있다.
일례로, 제2 물리 서버(30)에 제3 가상 서버(30), 제4 가상 서버(40), 제5 가상 서버(50) 및 제1 가상 서버(10)가 배치되고, 제3 물리 서버(40)에 제2 가상 서버(92), 제6 가상 서버(96) 및 제7 가상 서버(97)가 배치되었을 때, 제1 목적 함수가 최소인 상태에서 다른 목적 함수도 최소라고 가정할 경우, 제2 시간에서는 마이그레이션이 발생되지 않을 수 있다.
이와 다르게, 제1 목적 함수가 최소인 상태에서 다른 목적 함수도 최소로 하기 위해, 제3 시간에서 제2 물리 서버(30)에 배치되어 있는 제1 가상 서버(91)가 제3 물리 서버(40)로 마이그레이션 되도록 배치 일정이 산출될 수 있다.
또한, 제1 목적 함수가 최소인 상태에서 다른 목적 함수도 최소로 하기 위해, 제4 시간에서 제2 물리 서버(30)에 배치되어 있는 제5 가상 서버(95)가 제3 물리 서버(40)로 마이그레이션 되도록 배치 일정이 산출될 수 있다.
제2 시간 내지 제4 시간 동안 제1 물리 서버(20)는 가동되지 않을 수 있다.
이는 제4 목적 함수에 의한 영향으로 인해, 제2 시간 내지 제4 시간 동안 제1 물리 서버(20)가 가동되지 않도록 배치 일정이 산출되는 것일 수도 있다.
만일, 제4 시간 때의 가상 머신의 배치를 따를 경우 제5 시간 때에는 제3 물리 서버(40)의 워크 로드가 제1 기준이 이상이 된다고 예측될 수 있다.
이와 같은 경우, 상기 제5 시간 때 제3 물리 서버(40)에 배치되는 가상 머신 중에서 적어도 하나가 다른 물리 서버로 이동되도록 배치 일정이 산출될 수 있다. (제1-1 조건)
또한, 만일, 제4 시간 때의 가상 머신의 배치를 따를 경우 제5 시간 때에는 제2 물리 서버(30)의 워크 로드가 제1 기준이 이상이 된다고 예측될 수 있다. (제1-1 조건)
이와 같을 경우, 상기 제5 시간 때 제2 물리 서버(30)에 배치되는 가상 머신 중 적어도 하나가 다른 물리 서버로 이동되도록 배치 일정이 산출될 수 있다. (제1-1 조건)
다만, 제3 물리 서버(40)에 배치된 제1 가상 머신(91)은 제1 시간 및 제3 시간 때에 마이드레이션이 실시되었기 때문에, 제5 시간 때에는 마이그레이션 대상에서 제외될 수 있다. (제4 조건)
또한, 상기 제2 물리 서버(30)에 배치된 제3 가상 머신(93)과 제4 가상 머신(94) 모두가 제1 물리 서버(20)에 이동되는 경우, 제2 물리 서버(30) 가동은 중단되고 제1 물리 서버(20)의 가동은 개시될 수 있다.
이는 제2 조건이 만족되지 않기 때문에, 제2 물리 서버(30)에서는 제3 가상 머신(93)과 제4 가상 머신(94) 중 하나의 가상 머신 만이 제1 물리 서버(20)로 이동될 수 있다.
일례로, 제1 목적 함수가 최소화되는 상태에서 모든 목적 함수가 최소화되도록, 제1 조건 내지 제4 조건(구체적으로 제1-2 조건과 제2 조건)이 만족되도록, 제2 물리 서버(30)에서는 제3 가상 머신(93)이 제1 물리 서버(20)로 이동될 수 있고, 제3 물리 서버(40)에서는 제6 가상 머신(96)과 제7 가상 머신(97)이 제1 물리 서버(20)로 이동될 수 있다.
제5 시간에서의 마이그레이션에 의해 목적 함수의 최소 값이 만족되어 제6 시간에는 마이그레이션이 발생되지 않도록 배치 일정이 산출될 수 있다.
여태까지, 제1 배치 일정을 기초로 기술을 하였지만, 이는 하나의 예시에 불과하고, 제2 배치 일정, 제3 배치 일정 및 제4 배치 일정을 기초로 일정이 산출되는 방식에 대한 자세한 설명은 상술한 내용과 중복되는 한도에서 생략될 수 있다.
상기 표시부는 상기 제1 배치 일정, 상기 제2 배치 일정, 상기 제3 배치 일정 및 제4 배치 일정을 표시할 수 있다.
4 개의 목적 함수들은 각 각 독립적인 함수로서 4 개의 비 지배해를 가질 수 있기 때문에, 상기 제1 배치 일정, 상기 제2 배치 일정, 상기 제3 배치 일정 및 제4 배치 일정은 서로 독립적인 해결 방법을 의미할 수 있다.
작업자는 입력부를 통해 상기 제1 배치 일정, 제2 배치 일정, 제3 배치 일정 및 제4 배치 일정 중 하나의 배치 일정을 결정하여, 결정한 배치 일정을 선택 입력할 수 있다.
상기 입력부는 선택된 배치 일정과 관련된 정보를 산출하여 해당 정보를 상기 처리부로 전달할 수 있다.
도 6은 본 발명의 일 실시예에 따른 가상 머신 배치 방법 중에서 예측 오류를 산출하는 방법을 설명하기 위한 그래프이다.
상기 처리부는 선택된 배치 일정을 기초로 가상 머신들을 물리 서버들 상에서 이동 시키면서 배치(S60)할 수 있다.
이러한 방법을 통해 상기 물리 서버의 자원이 일 물리 서버로 치우치지 않고 고르게 활용될 수 있다.
또한, 본 발명의 일 실시예에 따른 가상 머신 배치 방법은 상기 배치 일정에 따라 상기 가상 머신이 상기 제1 물리 서버와 상기 제2 물리 서버에 배치되는 경우, 상기 물리 서버의 예측되는 부하와 연관된 선택 예측 가상 로드와 관련된 정보인 선택 예측 가상 로드 정보와 상기 가상 머신의 실제 워크 로드와 관련된 정보인 실제 가상 워크 로드 정보를 기초로 미리 정해진 점검 방법에 따라 상기 선택 예측 가상 로드 정보가 정상적으로 산출되었는지 여부를 판단하는 단계(S70)를 더 포함할 수 있다.
여기서, 선택 예측 가상 로드 정보는 상술한 최초 예측 가상 로드 정보들과 동일할 수 있다.
다만, 이에 한정하지 않고 상기 선택 예측 가상 로드 정보는 최초 예측 가상 로드 정보와 일치되지 않을 수 있다.
이와 같을 경우, 상기 처리부는 선택된 상기 배치 일정에 따라 상기 가상 머신들을 배치한 후, 소정 기간 동안의 상기 가상 머신들의 워크 로드를 예측하여 상기 선택 예측 가상 로드 정보를 산출할 수 있다.
상기 미리 정해진 점검 방법은 상기 가상 머신의 실제 워크 로드가 대응되는 상기 선택 예측 가상 로드와 소정 값 이상 차이 날 경우 상기 선택 예측 가상 로드가 잘못 산출되었다고 판단하는 방법일 수 있다.
구체적인 일례로서, 도 6은 제a 가상 머신의 예측되는 워크 로드인 선택 예측 가상 로드를 나타내는 제1 워크 로드(Y10)와 제a 가상 머신의 실제 워크 로드를 나타내는 제2 워크 로드(Y20)에 대한 그래프일 수 있다.
상기 처리부는 상기 제1 워크 로드와 상기 제2 워크 로드가 소정 워크 로드(소정 값, Y) 이상 차이날 경우 상기 제a 가상 머신의 워크 로드가 잘못 예측되었다고 판단할 수 있다.
상기 처리부가 상기 선택 예측 가상 로드가 잘못 산출되었다고 판단하는 경우, 상기 처리부는 상기 선택 예측 가상 로드가 잘못 산출되었다고 판단하는 시점인 재 판단 시점부터 미리 정해진 제2 기간 동안, 예측되는 상기 가상 머신에 의해 발생되는 물리 서버의 부하와 연관된 재 예측 가상 로드와 관련된 정보인 재 예측 가상 로드 정보를 산출(S80)할 수 있다.
상기 처리부는 상기 재 예측 가상 로드 정보를 기초로 상술한 미리 정해진 배치 일정 산출 방법에 의해 배치 일정을 재 산출(S80)할 수 있으며, 이를 기초로 가상 머신들이 재 배치(S90)될 수 있도록, 소정의 연산을 할 수 있다.
이에 대한 자세한 설명은 상술한 내용과 중복되는 한도에서 생략될 수 있다.
여기서, 미리 정해진 제2 기간은 상술한 상기 미리 정해진 제1 기간과 동일할 수도 있고 상이할 수도 있다.
이와 같은 상기 가상 머신 배치 방법은 반복 연속적으로 이루어질 수 있다.
상기 가상 머신들이 재 배치(S90)되기 위하여 작업자는 복수의 배치 일정들 중에 하나의 배치 일정을 선택할 수 있으며, 상기 처리부는 선택된 배치 일정을 기초로 상기 가상 머신들을 재 배치(S90) 할 수 있다.
이에 대한 자세한 설명은 상술한 내용과 중복되는 한도에서 생략될 수 있다.
본 발명의 일 실시예에 따른 가상 머신 배치 장치는 가상 머신이 설치되는 물리 서버 - 상기 물리 서버는 제1 물리 서버 및 제2 물리 서버를 구비함. - 를 효율적으로 운용하기 위하여, 복수의 상기 가상 머신을 상기 제1 물리 서버와 상기 제2 물리 서버 상에 배치하는 방법인 가상 머신 배치 방법을 구현하는 가상 머신 배치 장치에 있어서, 처리부; 및 상기 가상 머신 배치 방법을 수행하는 프로그램이 저장된 저장부;를 포함하고, 상기 가상 머신 배치 방법은, 상기 제1 물리 서버와 상기 제2 물리 서버의 작동과 관련된 정보를 기초로 미리 정해진 워크 로드 산출 방법에 의해 상기 가상 머신에 의해 부과되는 물리 서버의 부하인 가상 머신 워크 로드와 관련된 정보인 가상 머신 워크 로드 정보가 산출되는 단계, 상기 가상 머신 워크 로드를 기초로 미리 정해진 제1 기간 동안 예측되는 상기 가상 머신에 의해 부과되는 물리 서버의 부하와 연관된 최초 예측 가상 로드와 관련된 정보인 최초 예측 가상 로드 정보가 산출되는 단계, 미리 정해진 배치 일정 산출 방법에 의해 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치 일정과 관련된 정보인 배치 일정 정보가 산출되는 단계 및 상기 미리 정해진 배치 일정 산출 방법에 의해 산출된 상기 배치 일정에 따라 상기 제1 물리 서버와 상기 제2 물리 서버 상에 상기 가상 머신이 배치되도록, 상기 가상 머신이 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 이동되면서 배치되는 단계를 포함하고, 상기 미리 정해진 배치 일정 산출 방법은, 상기 최초 예측 가상 로드 정보를 기초로 목적 함수 값이 최소화될 때의 상기 가상 머신의 상기 배치 일정이 산출되는 방법일 수 있다.
첨부된 도면은 본 발명의 기술적 사상을 보다 명확하게 표현하기 위해, 본 발명의 기술적 사상과 관련성이 없거나 떨어지는 구성에 대해서는 간략하게 표현하거나 생략하였다.
상기에서는 본 발명에 따른 실시예를 기준으로 본 발명의 구성과 특징을 설명하였으나 본 발명은 이에 한정되지 않으며, 본 발명의 사상과 범위 내에서 다양하게 변경 또는 변형할 수 있음은 본 발명이 속하는 기술분야의 당업자에게 명백한 것이며, 따라서 이와 같은 변경 또는 변형은 첨부된 특허청구범위에 속함을 밝혀둔다.
10 : 가상 머신 배치 장치 11 : 처리부
12 : 저장부 13 : 수신부
14 : 송신부 15 : 입력부
16 : 표시부

Claims (11)

  1. 가상 머신 배치 장치를 이용하여, 가상 머신이 설치된 물리 서버 - 상기 물리 서버는 제1 물리 서버 및 제2 물리 서버를 구비함. -를 효율적으로 운용하기 위하여, 복수의 상기 가상 머신을 상기 제1 물리 서버와 상기 제2 물리 서버 상에 배치하는 방법인 가상 머신 배치 방법에 있어서,
    상기 제1 물리 서버와 상기 제2 물리 서버의 작동과 관련된 정보를 기초로 미리 정해진 워크 로드 산출 방법에 의해 상기 가상 머신에 의해 부과되는 물리 서버의 부하인 가상 머신 워크 로드와 관련된 정보인 가상 머신 워크 로드 정보가 산출되는 단계;
    상기 가상 머신 워크 로드를 기초로 미리 정해진 제1 기간 동안 예측되는 상기 가상 머신에 의해 부과되는 물리 서버의 부하와 연관된 최초 예측 가상 로드와 관련된 정보인 최초 예측 가상 로드 정보가 산출되는 단계;
    미리 정해진 배치 일정 산출 방법에 의해 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치 일정과 관련된 정보인 배치 일정 정보가 산출되는 단계;
    상기 미리 정해진 배치 일정 산출 방법에 의해 산출된 배치 일정이 표시되는 단계; 및
    상기 미리 정해진 배치 일정 산출 방법에 의해 산출된 상기 배치 일정에 따라 상기 제1 물리 서버와 상기 제2 물리 서버 상에 상기 가상 머신이 배치되도록, 상기 가상 머신이 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 이동되면서 배치되는 단계;를 포함하고,
    상기 미리 정해진 배치 일정 산출 방법은,
    상기 최초 예측 가상 로드 정보를 기초로 목적 함수 값이 최소화될 때의 상기 가상 머신의 상기 배치 일정이 산출되는 방법이며,
    상기 미리 정해진 제1 기간 동안에 상기 물리 서버들 간의 상기 가상 머신의 이동이 허용되도록 상기 배치 일정이 산출되는 방법이고,
    상기 목적 함수는,
    상기 미리 정해진 제1 기간 동안, 상기 최초 예측 가상 로드에 의해 산출되는 물리 서버의 부하의 변화 량과 관련된 함수인 제1 목적 함수를 구비하는,
    가상 머신 배치 방법.
  2. 제1항에 있어서,
    상기 미리 정해진 배치 산출 방법은,
    소정 횟수 내에서 상기 미리 정해진 제1 기간 동안에 물리 서버들 간의 가상 머신의 이동이 허용되도록 상기 배치 일정이 산출되는 방법인,
    가상 머신 배치 방법.
  3. 제1항에 있어서,
    상기 미리 정해진 워크 로드 산출 방법은,
    상기 제1 물리 서버와 상기 제2 물리 서버의 사양이 동일하다고 가정하여 산출하는 방법인,
    가상 머신 배치 방법.
  4. 제1항에 있어서,
    상기 미리 정해진 워크 로드 산출 방법은,
    CPU의 가동 정도만을 기초로 상기 가상 머신 워크 로드 정보가 산출되는 방법을 포함하는,
    가상 머신 배치 방법.
  5. 제1항에 있어서,
    상기 목적 함수는,
    상기 미리 정해진 제1 기간 동안, 상기 최초 예측 가상 로드에 의해 산출되는 물리 서버의 부하들 간의 차이와 관련된 함수인 제2 목적 함수, 상기 가상 머신이 상기 배치 일정에 따라 배치되기 위해서 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 상기 가상 머신이 배치 이동되는 횟수와 관련된 함수인 제3 목적 함수, 상기 미리 정해진 제1 기간 동안, 상기 제1 물리 서버의 가동 여부 및 상기 제2 물리 서버의 가동 여부와 관련된 함수인 제4 목적 함수를 더 구비하는,
    가상 머신 배치 방법.
  6. 제5항에 있어서,
    상기 배치 일정은,
    상기 제1 목적 함수의 값이 최소인 상태를 기준으로, 상기 제2 목적 함수의 값, 상기 제3 목적 함수 및 제4 목적 함수의 값이 최소화되는 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치인 제1 배치 일정,
    상기 제2 목적 함수의 값이 최소인 상태를 기준으로, 상기 제1 목적 함수의 값, 상기 제3 목적 함수 및 제4 목적 함수의 값이 최소화되는 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치인 제2 배치 일정,
    상기 제3 목적 함수의 값이 최소인 상태를 기준으로, 상기 제1 목적 함수의 값, 상기 제2 목적 함수 및 제4 목적 함수의 값이 최소화되는 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치인 제3 배치 일정 및
    상기 제4 목적 함수의 값이 최소인 상태를 기준으로, 상기 제1 목적 함수의 값, 상기 제2 목적 함수 및 제3 목적 함수의 값이 최소화되는 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치인 제4 배치 일정을 구비하는,
    가상 머신 배치 방법.
  7. 제6항에 있어서,
    상기 가상 머신은,
    상기 배치 일정들 중에서 선택된 하나의 상기 배치 일정에 따라 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 배치되는,
    가상 머신 배치 방법.
  8. 가상 머신이 설치되는 물리 서버 - 상기 물리 서버는 제1 물리 서버 및 제2 물리 서버를 구비함. - 를 효율적으로 운용하기 위하여, 복수의 상기 가상 머신을 상기 제1 물리 서버와 상기 제2 물리 서버 상에 배치하는 방법인 가상 머신 배치 방법을 구현하는 가상 머신 배치 장치에 있어서,
    처리부; 및
    상기 가상 머신 배치 방법을 수행하는 프로그램이 저장된 저장부;를 포함하고,
    상기 가상 머신 배치 방법은,
    상기 제1 물리 서버와 상기 제2 물리 서버의 작동과 관련된 정보를 기초로 미리 정해진 워크 로드 산출 방법에 의해 상기 가상 머신에 의해 부과되는 물리 서버의 부하인 가상 머신 워크 로드와 관련된 정보인 가상 머신 워크 로드 정보가 산출되는 단계;
    상기 가상 머신 워크 로드를 기초로 미리 정해진 제1 기간 동안 예측되는 상기 가상 머신에 의해 부과되는 물리 서버의 부하와 연관된 최초 예측 가상 로드와 관련된 정보인 최초 예측 가상 로드 정보가 산출되는 단계;
    미리 정해진 배치 일정 산출 방법에 의해 상기 제1 물리 서버와 상기 제2 물리 서버 상의 상기 가상 머신의 배치 일정과 관련된 정보인 배치 일정 정보가 산출되는 단계;
    상기 미리 정해진 배치 일정 산출 방법에 의해 산출된 배치 일정이 표시되는 단계; 및
    상기 미리 정해진 배치 일정 산출 방법에 의해 산출된 상기 배치 일정에 따라 상기 제1 물리 서버와 상기 제2 물리 서버 상에 상기 가상 머신이 배치되도록, 상기 가상 머신이 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 이동되면서 배치되는 단계;를 포함하고,
    상기 미리 정해진 배치 일정 산출 방법은,
    상기 최초 예측 가상 로드 정보를 기초로 목적 함수 값이 최소화될 때의 상기 가상 머신의 상기 배치 일정이 산출되는 방법이며,
    상기 미리 정해진 제1 기간 동안에 상기 물리 서버들 간의 상기 가상 머신의 이동이 허용되도록 상기 배치 일정이 산출되는 방법이고,
    상기 목적 함수는,
    상기 미리 정해진 제1 기간 동안, 상기 최초 예측 가상 로드에 의해 산출되는 물리 서버의 부하의 변화 량과 관련된 함수인 제1 목적 함수를 구비하는,
    가상 머신 배치 장치.
  9. 제8항에 있어서,
    상기 미리 정해진 배치 산출 방법은,
    소정 횟수 내에서 상기 미리 정해진 제1 기간 동안에 물리 서버들 간의 가상 머신의 이동이 허용되도록 상기 배치 일정이 산출되는 방법인,
    가상 머신 배치 장치.
  10. 제8항에 있어서,
    상기 미리 정해진 워크 로드 산출 방법은,
    상기 제1 물리 서버와 상기 제2 물리 서버의 사양이 동일하다고 가정하여 산출하는 방법인,
    가상 머신 배치 장치.
  11. 제8항에 있어서,
    상기 목적 함수는,
    상기 미리 정해진 제1 기간 동안, 상기 최초 예측 가상 로드에 의해 산출되는 물리 서버의 부하들 간의 차이와 관련된 함수인 제2 목적 함수, 상기 가상 머신이 상기 배치 일정에 따라 배치되기 위해서 상기 제1 물리 서버와 상기 제2 물리 서버 상에서 상기 가상 머신이 배치 이동되는 횟수와 관련된 함수인 제3 목적 함수, 상기 미리 정해진 제1 기간 동안, 상기 제1 물리 서버의 가동 여부 및 상기 제2 물리 서버의 가동 여부와 관련된 함수인 제4 목적 함수를 더 구비하는,
    가상 머신 배치 장치.

KR1020200078477A 2019-07-31 2020-06-26 가상 머신 워크로드 예측 방법, 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치 KR102316749B1 (ko)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020200078477A KR102316749B1 (ko) 2019-07-31 2020-06-26 가상 머신 워크로드 예측 방법, 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
KR1020190092851A KR102135208B1 (ko) 2019-07-31 2019-07-31 스케줄링을 통한 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치
KR1020200078477A KR102316749B1 (ko) 2019-07-31 2020-06-26 가상 머신 워크로드 예측 방법, 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
KR1020190092851A Division KR102135208B1 (ko) 2019-07-31 2019-07-31 스케줄링을 통한 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치

Publications (2)

Publication Number Publication Date
KR20210015636A KR20210015636A (ko) 2021-02-10
KR102316749B1 true KR102316749B1 (ko) 2021-10-25

Family

ID=74561096

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020200078477A KR102316749B1 (ko) 2019-07-31 2020-06-26 가상 머신 워크로드 예측 방법, 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치

Country Status (1)

Country Link
KR (1) KR102316749B1 (ko)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102469718B1 (ko) * 2021-10-29 2022-11-22 오케스트로 주식회사 이상 징후 모니터링 기능이 탑재된 가상 머신 배치 시스템 및 가상 머신 배치 방법

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2011170787A (ja) 2010-02-22 2011-09-01 Nippon Telegraph & Telephone West Corp リソース割当装置、リソース割当方法、およびリソース割当制御プログラム
JP2011186701A (ja) 2010-03-08 2011-09-22 Nec Corp リソース割当装置、リソース割当方法、およびリソース割当プログラム
JP2012159928A (ja) 2011-01-31 2012-08-23 Internatl Business Mach Corp <Ibm> 情報処理装置、情報処理システム、配置構成決定方法、プログラムおよび記録媒体
JP2014006739A (ja) 2012-06-25 2014-01-16 Fujitsu Ltd プログラム、管理サーバおよび仮想マシン移動制御方法
KR101867487B1 (ko) 2016-12-23 2018-07-18 경희대학교 산학협력단 클라우드 환경에서 퍼지기반의 마이그레이션 시스템 및 방법

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2439641B1 (en) * 2009-06-01 2016-10-12 Fujitsu Limited Server control program, control server, virtual server distribution method

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2011170787A (ja) 2010-02-22 2011-09-01 Nippon Telegraph & Telephone West Corp リソース割当装置、リソース割当方法、およびリソース割当制御プログラム
JP2011186701A (ja) 2010-03-08 2011-09-22 Nec Corp リソース割当装置、リソース割当方法、およびリソース割当プログラム
JP2012159928A (ja) 2011-01-31 2012-08-23 Internatl Business Mach Corp <Ibm> 情報処理装置、情報処理システム、配置構成決定方法、プログラムおよび記録媒体
JP2014006739A (ja) 2012-06-25 2014-01-16 Fujitsu Ltd プログラム、管理サーバおよび仮想マシン移動制御方法
KR101867487B1 (ko) 2016-12-23 2018-07-18 경희대학교 산학협력단 클라우드 환경에서 퍼지기반의 마이그레이션 시스템 및 방법

Also Published As

Publication number Publication date
KR20210015636A (ko) 2021-02-10

Similar Documents

Publication Publication Date Title
KR102135208B1 (ko) 스케줄링을 통한 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치
US8489744B2 (en) Selecting a host from a host cluster for live migration of a virtual machine
EP3198429B1 (en) Heterogeneous thread scheduling
Paya et al. Energy-aware load balancing and application scaling for the cloud ecosystem
Tang et al. Twine: A unified cluster management system for shared infrastructure
US8694638B2 (en) Selecting a host from a host cluster to run a virtual machine
US11088961B2 (en) Monitoring data streams and scaling computing resources based on the data streams
CN103631633B (zh) 虚拟机全***在线迁移方法、装置与***
US8695005B2 (en) Model for hosting and invoking applications on virtual machines in a distributed computing environment
US20140237197A1 (en) Non-uniform memory access (numa) resource assignment and re-evaluation
US10061233B2 (en) Computer system backup performance optimization through performance analytics
CN107431696A (zh) 用于应用自动化部署的方法和云管理节点
JP5589218B2 (ja) 計算機システム及び管理計算機
CN101533417A (zh) 一种实现etl调度的方法及***
US20210105322A1 (en) Distributed storage system and data migration method
KR102109088B1 (ko) 가상 머신 예측 워크 로드 산출 방법 및 이를 구현하는 예측 장치
KR102062157B1 (ko) 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치
JP2011186701A (ja) リソース割当装置、リソース割当方法、およびリソース割当プログラム
CN104750538B (zh) 用于为目标应用提供虚拟存储池的方法和***
KR102347375B1 (ko) 복수의 예측 모델을 기초로 가상 머신 워크 로드 예측 방법
US10540202B1 (en) Transient sharing of available SAN compute capability
KR102316749B1 (ko) 가상 머신 워크로드 예측 방법, 가상 머신 배치 방법 및 이를 구현하는 가상 머신 배치 장치
JP5576827B2 (ja) サーバ管理システム、サーバ管理装置、サーバ管理方法、及びサーバ管理プログラム
KR20150007698A (ko) 가상 데스크탑 서비스를 위한 부하 분산 시스템
KR102470086B1 (ko) Sla 위반을 예방한 가상 머신 배치 시스템 및 가상 머신 배치 방법

Legal Events

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