KR101625159B1 - 동적 세션 할당 방법, 동적 세션 관리 방법 및 시스템 - Google Patents

동적 세션 할당 방법, 동적 세션 관리 방법 및 시스템 Download PDF

Info

Publication number
KR101625159B1
KR101625159B1 KR1020140168389A KR20140168389A KR101625159B1 KR 101625159 B1 KR101625159 B1 KR 101625159B1 KR 1020140168389 A KR1020140168389 A KR 1020140168389A KR 20140168389 A KR20140168389 A KR 20140168389A KR 101625159 B1 KR101625159 B1 KR 101625159B1
Authority
KR
South Korea
Prior art keywords
session
server
virtualization
top box
screen
Prior art date
Application number
KR1020140168389A
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 KR1020140168389A priority Critical patent/KR101625159B1/ko
Application granted granted Critical
Publication of KR101625159B1 publication Critical patent/KR101625159B1/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
    • 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
    • G06F15/161Computing infrastructure, e.g. computer clusters, blade chassis or hardware partitioning

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • General Physics & Mathematics (AREA)
  • Mathematical Physics (AREA)
  • Computer And Data Communications (AREA)

Abstract

세션 관리 시스템은 세션 브로커 서버 및 가상화 서버를 포함한다. 상기 세션 브로커 서버는, 복수의 가상화 서버로부터 기설정된 주기로 서버 상태 정보를 수신하고, 셋톱박스로부터 세션에 대한 할당을 요청받고, 상기 서버 상태 정보에 기초하여 상기 복수의 가상화 서버 중 하나를 선정하고, 상기 셋톱박스에 상기 선정된 가상화 서버 및 세션을 할당하도록 구성된다. 상기 가상화 서버는, 상기 셋톱박스로부터 웹앱에 대한 실행을 요청받고, 가상 브라우저를 통하여 상기 웹앱을 실행하고, 상기 가상 브라우저 상에서 표시된 상기 웹앱의 화면 변화를 기설정된 주기로 모니터링하고, 상기 가상 브라우저 상에 표시된 화면을 캡쳐하고, 상기 캡쳐된 화면을 상기 셋톱박스로 전송하도록 구성된다.

Description

동적 세션 할당 방법, 동적 세션 관리 방법 및 시스템{DYNAMIC SESSION ASSIGNMENT METHOD, DYNAMIC SESSION MANAGEMENT METHOD AND SYSTEM}
본 발명은 동적 세션 할당 방법, 동적 세션 관리 방법 및 시스템에 관한 것이다.
서버 가상화(Server virtualization)란, 중앙 처리 장치(CPU), 기억 장치, 입출력 등 단일 플랫폼상의 서버 자원을 사용자가 여러 도메인이나 서버 애플리케이션으로 분할해 사용할 수 있는 기술을 말한다.
이와 관련하여, 한국공개특허 제 2012-0046807호는 단말로부터 가상화 서비스 요청을 수신하고, 단말을 위한 모바일 운영 체제를 구동하여 동작 정보를 단말로 전송하고, 단말로부터 모바일 운영 체제를 조작하기 위한 입력 정보를 수신하는 가상 환경을 제공하기 위한 방법에 대해 개시하고 있다.
한국공개특허 제 2012-0046807호
동적으로 세션을 관리하는 방법을 제공함으로써, 서버 자원을 효율적으로 관리할 수 있는 동적 세션 할당 방법, 동적 세션 관리 방법 및 시스템을 제공하고자 한다. 다만, 본 실시예가 이루고자 하는 기술적 과제는 상기된 바와 같은 기술적 과제들로 한정되지 않으며, 또 다른 기술적 과제들이 존재할 수 있다.
상술한 기술적 과제를 달성하기 위한 기술적 수단으로서, 본 발명의 일 실시예는 세션 관리 시스템에 있어서, 세션 브로커 서버 및 가상화 서버를 포함하되, 세션 브로커 서버는, 복수의 가상화 서버로부터 기설정된 주기로 서버 상태 정보를 수신하고, 셋톱박스로부터 세션에 대한 할당을 요청받고, 서버 상태 정보에 기초하여 복수의 가상화 서버 중 하나를 선정하고, 셋톱박스에 선정된 가상화 서버 및 세션을 할당하도록 구성되고, 가상화 서버는, 셋톱박스로부터 웹앱에 대한 실행을 요청받고, 가상 브라우저를 통하여 웹앱을 실행하고, 가상 브라우저 상에서 표시된 웹앱의 화면 변화를 기설정된 주기로 모니터링하고, 가상 브라우저 상에 표시된 화면을 캡쳐하고, 캡쳐된 화면을 셋톱박스로 전송하도록 구성된, 세션 관리 시스템을 제공할 수 있다.
또한, 본 발명의 다른 실시예는, 세션 브로커 서버에서 동적으로 세션을 할당하는 방법에 있어서, 복수의 가상화 서버로부터 기설정된 주기로 서버 상태 정보를 수신하는 단계, 셋톱박스로부터 세션에 대한 할당을 요청받는 단계, 서버 상태 정보에 기초하여 복수의 가상화 서버 중 하나를 선정하는 단계 및 셋톱박스에 선정된 가상화 서버 및 세션을 할당하는 단계를 포함하는 것인, 동적 세션 할당 방법을 제공할 수 있다.
또한, 본 발명의 또 다른 실시예는, 가상화 서버에서 동적으로 세션을 관리하는 방법에 있어서, 셋톱박스로부터 웹앱에 대한 실행을 요청받는 단계, 가상 브라우저를 통하여 웹앱을 실행하는 단계, 가상 브라우저 상에서 표시된 웹앱의 화면 변화를 기설정된 주기로 모니터링하는 단계, 가상 브라우저 상에 표시된 화면을 캡쳐하는 단계 및 캡쳐된 화면을 셋톱박스로 전송하는 단계를 포함하는, 동적 세션 관리 방법을 제공할 수 있다.
상술한 과제 해결 수단은 단지 예시적인 것으로서, 본 발명을 제한하려는 의도로 해석되지 않아야 한다. 상술한 예시적인 실시예 외에도, 도면 및 발명의 상세한 설명에 기재된 추가적인 실시예가 존재할 수 있다.
동적으로 세션을 관리하는 방법을 제공함으로써, 서버 당 세션 비율을 동적으로 조정할 수 있는 동적 세션 할당 방법, 동적 세션 관리 방법 및 시스템을 제공할 수 있다.
도 1은 본 발명의 일 실시예에 따른 동적으로 세션을 관리하는 시스템에 대해 나타낸 구성도이다.
도 2는 본 발명의 일 실시예에 따른 세션 브로커 서버에서 동적으로 세션을 할당하는 방법을 나타낸 순서도이다.
도 3은 본 발명의 일 실시예에 따른 세션 브로커 서버에서 가상화 서버 및 세션을 선정하는 방법을 나타낸 순서도이다.
도 4는 본 발명의 일 실시예에 따른 가상화 서버에서 동적으로 세션을 관리하는 방법에 대해 나타낸 순서도이다.
도 5는 본 발명의 일 실시예에 따른 가상화 서버에서 가상화 브라우저 상에서 표시된 웹앱을 모니터링하는 방법에 대해 나타낸 순서도이다.
아래에서는 첨부한 도면을 참조하여 본 발명이 속하는 기술 분야에서 통상의 지식을 가진 자가 용이하게 실시할 수 있도록 본 발명의 실시예를 상세히 설명한다. 그러나 본 발명은 여러 가지 상이한 형태로 구현될 수 있으며 여기에서 설명하는 실시예에 한정되지 않는다. 그리고 도면에서 본 발명을 명확하게 설명하기 위해서 설명과 관계없는 부분은 생략하였으며, 명세서 전체를 통하여 유사한 부분에 대해서는 유사한 도면 부호를 붙였다.
명세서 전체에서, 어떤 부분이 다른 부분과 "연결"되어 있다고 할 때, 이는 "직접적으로 연결"되어 있는 경우뿐 아니라, 그 중간에 다른 소자를 사이에 두고 "전기적으로 연결"되어 있는 경우도 포함한다. 또한 어떤 부분이 어떤 구성요소를 "포함"한다고 할 때, 이는 특별히 반대되는 기재가 없는 한 다른 구성요소를 제외하는 것이 아니라 다른 구성요소를 더 포함할 수 있는 것을 의미하며, 하나 또는 그 이상의 다른 특징이나 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.
본 명세서에 있어서 '부(部)'란, 하드웨어에 의해 실현되는 유닛(unit), 소프트웨어에 의해 실현되는 유닛, 양방을 이용하여 실현되는 유닛을 포함한다. 또한, 1 개의 유닛이 2 개 이상의 하드웨어를 이용하여 실현되어도 되고, 2 개 이상의 유닛이 1 개의 하드웨어에 의해 실현되어도 된다.
본 명세서에 있어서 단말 또는 디바이스가 수행하는 것으로 기술된 동작이나 기능 중 일부는 해당 단말 또는 디바이스와 연결된 서버에서 대신 수행될 수도 있다. 이와 마찬가지로, 서버가 수행하는 것으로 기술된 동작이나 기능 중 일부도 해당 서버와 연결된 단말 또는 디바이스에서 수행될 수도 있다.
이하 첨부된 도면을 참고하여 본 발명의 일 실시예를 상세히 설명하기로 한다.
도 1은 본 발명의 일 실시예에 따른 동적으로 세션을 관리하는 시스템에 대해 나타낸 구성도이다.
도 1을 참조하면, 세션 관리 시스템(1)은 세션 브로커 서버(100), 가상화 서버(110) 및 셋톱박스(120)를 포함할 수 있다. 도 1에 도시된 세션 브로커 서버(100), 가상화 서버(110) 및 셋톱박스(120)는 세션 관리 시스템(1)에 의하여 제어될 수 있는 구성요소들을 예시적으로 도시한 것이다.
도 1의 세션 관리 시스템(1)의 각 구성요소들은 일반적으로 네트워크(network)를 통해 연결된다. 예를 들어, 도 1에 도시된 바와 같이, 세션 브로커 서버(100)는 네트워크를 통하여 가상화 서버(110)와 연결될 수 있다.
네트워크는 단말들 및 서버들과 같은 각각의 노드 상호 간에 정보 교환이 가능한 연결 구조를 의미하는 것으로, 이러한 네트워크의 일 예는, Wi-Fi, 블루투스(Bluetooth), 인터넷(Internet), LAN(Local Area Network), Wireless LAN(Wireless Local Area Network), WAN(Wide Area Network), PAN(Personal Area Network), 3G, 4G, LTE 등이 포함되나 이에 한정되지는 않는다.
세션 브로커 서버(100)는 셋톱박스(120)로부터 세션에 대한 할당을 요청받고, 이에 대해 복수의 가상화 서버(110) 중 최적의 가상화 서버 및 세션을 선정하여 동적으로 할당하도록 구성될 수 있다.
구체적으로, 세션 브로커 서버(100)는 복수의 가상화 서버(110)로부터 기설정된 주기로 서버 상태 정보를 수신하고, 셋톱박스(120)로부터 세션에 대한 할당을 요청받고, 서버 상태 정보에 기초하여 복수의 가상화 서버(110) 중 하나를 선정하고, 셋톱박스(120)에 선정된 가상화 서버 및 세션을 할당할 수 있다.
가상화 서버(110)는 가상화 웹앱을 실행하고, 처리된 화면을 셋톱박스에 전송하도록 구성될 수 있다. 또한, 가상화 서버(110)는 웹앱 실행 시 화면 변화 및 키 입력에 대한 여부를 체크하여 동적으로 세션을 관리하도록 구성될 수 있다.
구체적으로, 가상화 서버(110)는 셋톱박스(120)로부터 웹앱에 대한 실행을 요청받고, 가상 브라우저를 통하여 웹앱을 실행하고, 가상 브라우저 상에서 표시된 웹앱의 화면 변화를 기설정된 주기로 모니터링하고, 가상 브라우저 상에 표시된 화면을 캡쳐하고, 캡쳐된 화면을 셋톱박스로 전송할 수 있다.
셋톱박스(120)는 세션 브로커 서버(100)에 세션에 대한 할당을 요청하고, 이에 대한 응답으로, 선정된 가상화 서버(120) 및 세션을 할당받도록 구성될 수 있다.
셋톱박스(120)는 가상화 서버(110)에 웹앱에 대한 실행을 요청하고, 이에 대한 응답으로, 가상 브라우저 상 표시된 웹앱의 화면을 전송받도록 구성될 수 있다.
도 2는 본 발명의 일 실시예에 따른 세션 브로커 서버에서 동적으로 세션을 할당하는 방법을 나타낸 순서도이다.
단계 S200에서 세션 브로커 서버(100)는 복수의 가상화 서버(110)로부터 기설정된 주기로 서버 상태 정보를 수신할 수 있다. 이 때, 서버 상태 정보는 가상화 서버(110)의 CPU 사용률, 메모리 사용률 및 세션 사용률을 포함할 수 있다.
단계 S210에서 세션 브로커 서버(100)는 셋톱박스(120)로부터 세션에 대한 할당을 요청받을 수 있다. 단계 S220에서 세션 브로커 서버(100)는 서버 상태 정보에 기초하여 상기 복수의 가상화 서버(110) 중 하나를 선정할 수 있다. 단계 S230에서 세션 브로커 서버(100)는 셋톱박스(120)에 선정된 가상화 서버(110) 및 세션을 할당할 수 있다.
상술한 설명에서, 단계 S200 내지 S230은 본 발명의 구현예에 따라서, 추가적인 단계들로 더 분할되거나, 더 적은 단계들로 조합될 수 있다. 또한, 일부 단계는 필요에 따라 생략될 수도 있고, 단계 간의 순서가 변경될 수도 있다.
도 3은 본 발명의 일 실시예에 따른 세션 브로커 서버에서 가상화 서버 및 세션을 선정하는 방법을 나타낸 순서도이다. 도 3을 참조하면, 세션 브로커 서버(100)는 셋톱박스(120)로부터 세션에 대한 할당을 요청받을 수 있고, 가상화 서버(110) 및 세션을 할당하기 위해 복수의 가상화 서버(110)로부터 수신한 서버 상태 정보에 기초하여 복수의 가상화 서버(110) 중 하나를 선정할 수 있다.
단계 S300에서 세션 브로커 서버(100)는 복수의 가상화 서버(110) 각각의 CPU 사용률이 기설정된 기준값을 초과하는지 판단할 수 있다. 예를 들어, 세션 브로커 서버(100)는 복수의 가상화 서버(110) 각각의 CPU 사용률이 50%를 초과하는지 판단할 수 있다.
단계 S310에서 세션 브로커 서버(100)는 복수의 가상화 서버(110)의 CPU 사용률이 기설정된 기준값을 초과하지 않는 경우, 복수의 가상화 서버(110) 각각의 메모리 사용률이 기설정된 기준값을 초과하는지 판단할 수 있다. 예를 들어, 세션 브로커 서버(100)는 복수의 가상화 서버(110) 모두의 CPU 사용률이 50%를 초과하지 않은 경우, 복수의 가상화 서버(110) 각각의 메모리 사용률이 50%를 초과하는지 판단할 수 있다.
단계 S320에서 세션 브로커 서버(100)는 복수의 가상화 서버(110)의 메모리 사용률이 기설정된 기준값을 초과하지 않는 경우, 복수의 가상화 서버(110) 각각의 세션 사용률이 세션 허용 기준값을 초과하는지 판단할 수 있다. 예를 들어, 세션 브로커 서버(100)는 복수의 가상화 서버(110) 모두의 메모리 사용률이 50%를 초과하지 않은 경우, 복수의 가상화 서버(110) 각각의 세션 사용률이 세션 허용 기준값인 50%를 초과하는지 판단할 수 있다. 아래의 수식은 세션 허용 기준값을 산출하는 수식에 대한 예시이다.
세션 허용 기준값 = 최대 허용 세션 기준치*(1+일시 정지 세션 비율*N%)
상술한 단계 S300 내지 S320은 그 판단 순서를 달리할 수 있다. 예를 들어, 메모리 사용률을 먼저 판단한 후, CPU 사용률을 판단할 수도 있고, 세션 사용률은 제일 먼저 판단할 수도 있다.
단계 S330에서 세션 브로커 서버(100)는 복수의 가상화 서버(110)의 세션 사용률이 기설정된 세션 허용 기준값을 초과하지 않는 경우, 서버 상태 정보에 기초하여 복수의 가상화 서버(110) 중 하나를 선정할 수 있다. 예를 들어, 세션 브로커 서버(100)는 서버 할당 조건에 기초하여 복수의 가상화 서버(110) 중 하나를 선정할 수 있는데, 서버 할당 조건은 단계 S300 내지 단계 S320에서 판단한 서버 상태 정보에 기초하여 낮은 CPU 사용률 > 낮은 메모리 사용률 > 낮은 세션 사용률 순으로 우선 조건을 둘 수 있다.
단계 S340에서 세션 브로커 서버(100)는 셋톱박스(120)에 선정된 가상화 서버 및 세션을 할당할 수 있다.
단계 S350에서 세션 브로커 서버(100)는 셋톱박스(120)에 서비스 접속 불가 메시지를 전송할 수 있다. 예를 들어, 세션 브로커 서버(100)는 단계 S300에서 복수의 가상화 서버(110) 모두의 CPU 사용률이 기설정된 기준값을 초과하거나, 단계 S310에서 복수의 가상화 서버(110) 모두의 메모리 사용률이 기설정된 기준값을 초과하거나 또는 단계 S320에서 복수의 가상화 서버(110) 모두의 세션 사용률이 기설정된 세션 허용 기준값을 초과하는 경우, 셋톱박스(120)에 서비스 접속 불가 메시지를 전송할 수 있다.
상술한 설명에서, 단계 S300 내지 S350은 본 발명의 구현예에 따라서, 추가적인 단계들로 더 분할되거나, 더 적은 단계들로 조합될 수 있다. 또한, 일부 단계는 필요에 따라 생략될 수도 있고, 단계 간의 순서가 변경될 수도 있다.
도 4는 본 발명의 일 실시예에 따른 가상화 서버에서 동적으로 세션을 관리하는 방법에 대해 나타낸 순서도이다.
단계 S400에서 가상화 서버(110)는 셋톱박스(120)로부터 웹앱에 대한 실행을 요청받을 수 있다. 단계 S410에서 가상화 서버(110)는 가상 브라우저를 통하여 웹앱을 실행할 수 있다. 단계 S420에서 가상화 서버(110)는 가상 브라우저 상에서 표시된 웹앱의 화면 변화를 기설정된 주기로 모니터링할 수 있다. 단계 S430에서 가상화 서버(110)는 가상 브라우저 상에 표시된 화면을 캡쳐할 수 있다. 단계 S440에서 가상화 서버(110)는 캡쳐된 화면을 셋톱박스(120)로 전송할 수 있다.
단계 S450에서 가상화 서버(110)는 셋톱박스(120)로부터 웹앱에 대한 종료를 요청받을 수 있다. 예를 들어, 가상화 서버(110)는 셋톱박스(120)로부터 웹앱에 대한 종료를 요청받지 않은 경우, 다시 단계 S420으로 돌아갈 수 있다. 또 다른 예를 들어, 단계 S460에서 가상화 서버(110)는 셋톱박스(120)로부터 웹앱에 대한 종료를 요청받은 경우, 세션을 종료할 수 있다.
상술한 설명에서, 단계 S400 내지 S460은 본 발명의 구현예에 따라서, 추가적인 단계들로 더 분할되거나, 더 적은 단계들로 조합될 수 있다. 또한, 일부 단계는 필요에 따라 생략될 수도 있고, 단계 간의 순서가 변경될 수도 있다.
도 5는 본 발명의 일 실시예에 따른 가상화 서버에서 가상화 브라우저 상에서 표시된 웹앱을 모니터링하는 방법에 대해 나타낸 순서도이다.
단계 S500에서 가상화 서버(110)는 가상 브라우저 상에서 표시된 웹앱의 화면 변화 여부를 판단할 수 있다. 예를 들어, 가상화 서버(110)는 가상 브라우저 상에서 표시된 웹앱의 화면 변화가 있다고 판단한 경우, 가상화 브라우저 상에서 표시된 웹앱을 모니터링하는 단계를 종료할 수 있다.
단계 S510에서 가상화 서버(110)는 가상 브라우저 상에서 표시된 웹앱의 화면 변화가 없다고 판단한 경우, 셋톱박스(120)로부터의 키 입력 여부를 판단할 수 있다.
단계 S520에서 가상화 서버(110)는 셋톱박스(120)로부터의 키 입력이 있다고 판단한 경우, 가상 브라우저 및 화면 전송 프로세스 실행 여부 판단할 수 있다. 이 때, 화면 전송 프로세스는 웹앱의 실행을 통해 브라우저 상에 표시된 화면을 캡쳐하여 셋톱박스(120)로 전송하는 프로세스일 수 있다.
예를 들어, 가상화 서버(110)는 가상 브라우저 및 화면 전송 프로세스가 실행 중이라고 판단한 경우, 가상화 브라우저 상에서 표시된 웹앱을 모니터링하는 단계를 종료할 수 있다. 다른 예를 들어, 가상화 서버(110)는 가상 브라우저 및 화면 전송 프로세스가 실행 중이 아니라고 판단한 경우, 단계 S530에서 가상 브라우저 및 화면 전송 프로세스를 재실행할 수 있다.
단계 S540에서 가상화 서버(110)는 셋톱박스(120)로부터의 키 입력이 없다고 판단한 경우, 기설정된 시간 동안의 키 입력 여부를 판단할 수 있다. 예를 들어, 가상화 서버(110)는 키 입력 여부를 판단하는 기설정된 시간이 경과하지 않았다고 판단한 경우, 다시 단계 S510으로 돌아갈 수 있다.
단계 S550에서 가상화 서버(110)는 기설정된 시간 동안의 키 입력이 없다고 판단한 경우, 가상 브라우저 및 화면 전송 프로세스 실행 여부를 판단할 수 있다. 예를 들어, 가상화 서버(110)는 가상 브라우저 및 화면 전송 프로세스가 실행 중이 아니라고 판단한 경우, 다시 단계 S510으로 돌아갈 수 있다.
단계 S560에서 가상화 서버(110)는 가상 브라우저 및 화면 전송 프로세스가 실행 중이라고 판단한 경우, 가상 브라우저 및 화면 전송 프로세스를 일시 정지하고, 다시 단계 S510으로 돌아갈 수 있다.
상술한 설명에서, 단계 S500 내지 S560은 본 발명의 구현예에 따라서, 추가적인 단계들로 더 분할되거나, 더 적은 단계들로 조합될 수 있다. 또한, 일부 단계는 필요에 따라 생략될 수도 있고, 단계 간의 순서가 변경될 수도 있다.
도 1을 통해 세션 관리 시스템은 컴퓨터에 의해 실행되는 프로그램 모듈과 같은 컴퓨터에 의해 실행 가능한 명령어를 포함하는 기록 매체의 형태로도 구현될 수 있다. 컴퓨터 판독 가능 매체는 컴퓨터에 의해 액세스될 수 있는 임의의 가용 매체일 수 있고, 휘발성 및 비휘발성 매체, 분리형 및 비분리형 매체를 모두 포함한다. 또한, 컴퓨터 판독가능 매체는 컴퓨터 저장 매체 및 통신 매체를 모두 포함할 수 있다. 컴퓨터 저장 매체는 컴퓨터 판독가능 명령어, 데이터 구조, 프로그램 모듈 또는 기타 데이터와 같은 정보의 저장을 위한 임의의 방법 또는 기술로 구현된 휘발성 및 비휘발성, 분리형 및 비분리형 매체를 모두 포함한다. 통신 매체는 전형적으로 컴퓨터 판독가능 명령어, 데이터 구조, 프로그램 모듈, 또는 반송파와 같은 변조된 데이터 신호의 기타 데이터, 또는 기타 전송 메커니즘을 포함하며, 임의의 정보 전달 매체를 포함한다.
전술한 본 발명의 설명은 예시를 위한 것이며, 본 발명이 속하는 기술분야의 통상의 지식을 가진 자는 본 발명의 기술적 사상이나 필수적인 특징을 변경하지 않고서 다른 구체적인 형태로 쉽게 변형이 가능하다는 것을 이해할 수 있을 것이다. 그러므로 이상에서 기술한 실시예들은 모든 면에서 예시적인 것이며 한정적이 아닌 것으로 이해해야만 한다. 예를 들어, 단일형으로 설명되어 있는 각 구성 요소는 분산되어 실시될 수도 있으며, 마찬가지로 분산된 것으로 설명되어 있는 구성 요소들도 결합된 형태로 실시될 수 있다.
본 발명의 범위는 상기 상세한 설명보다는 후술하는 특허청구범위에 의하여 나타내어지며, 특허청구범위의 의미 및 범위 그리고 그 균등 개념으로부터 도출되는 모든 변경 또는 변형된 형태가 본 발명의 범위에 포함되는 것으로 해석되어야 한다.
100: 세션 브로커 서버
110: 가상화 서버
120: 셋톱박스

Claims (19)

  1. 세션 관리 시스템에 있어서,
    세션 브로커 서버;
    가상화 서버; 및
    셋톱박스
    를 포함하되,
    상기 세션 브로커 서버는,
    복수의 가상화 서버로부터 기설정된 주기로 서버 상태 정보를 수신하고,
    상기 셋톱박스로부터 세션에 대한 할당을 요청받고,
    상기 서버 상태 정보에 기초하여 상기 복수의 가상화 서버 중 하나를 선정하고,
    상기 셋톱박스에 상기 선정된 가상화 서버 및 세션을 할당하도록 구성되고,
    상기 가상화 서버는,
    상기 셋톱박스로부터 웹앱에 대한 실행을 요청받고,
    가상 브라우저를 통하여 상기 웹앱을 실행하고,
    상기 가상 브라우저 상에서 표시된 상기 웹앱의 화면 변화를 기설정된 주기로 모니터링하고,
    상기 가상 브라우저 상에 표시된 화면을 캡쳐하고,
    상기 캡쳐된 화면을 상기 셋톱박스로 전송하고,
    상기 셋톱박스는 상기 할당된 세션 및 상기 가상화 서버를 통해 상기 캡쳐된 화면을 수신하여 출력하도록 구성된, 세션 관리 시스템.
  2. 제 1 항에 있어서,
    상기 서버 상태 정보는,
    상기 가상화 서버의 CPU 사용률, 메모리 사용률 및 세션 사용률을 포함하는 것인, 세션 관리 시스템.
  3. 제 2 항에 있어서,
    상기 세션 브로커 서버는,
    상기 복수의 가상화 서버의 상기 CPU 사용률이 기설정된 기준값을 초과하는지 여부를 판단하도록 구성되는 것인, 세션 관리 시스템.
  4. 제 3 항에 있어서,
    상기 세션 브로커 서버는,
    상기 CPU 사용률이 기설정된 기준값을 초과하지 않는 경우,
    상기 복수의 가상화 서버에 대한 상기 메모리 사용률이 기설정된 기준값을 초과하는지 여부를 판단하도록 구성되는 것인, 세션 관리 시스템.
  5. 제 4 항에 있어서,
    상기 세션 브로커 서버는,
    상기 메모리 사용률이 기설정된 기준값을 초과하지 않는 경우,
    상기 복수의 가상화 서버에 대한 상기 세션 사용률이 세션 허용 기준값을 초과하는지 여부를 판단하도록 구성되고,
    상기 세션 허용 기준값은 기설정된 최대 세션 허용 값에 기초하여 도출되는 것인, 세션 관리 시스템.
  6. 제 1 항에 있어서,
    상기 가상화 서버는,
    상기 모니터링하는 단계에서, 상기 화면 변화가 없다고 판단된 경우,
    상기 셋톱박스로부터의 키 입력 여부를 판단하도록 구성되는 것인, 세션 관리 시스템.
  7. 제 6 항에 있어서,
    상기 가상화 서버는,
    기설정된 시간 동안의 상기 키 입력 여부를 판단하는 것인, 세션 관리 시스템.
  8. 제 6 항에 있어서,
    상기 가상화 서버는,
    상기 키 입력 여부 상기 가상 브라우저 및 화면 전송 프로세스의 실행 중 여부에 기초하여 상기 가상 브라우저 및 상기 화면 전송 프로세스를 정지 또는 실행하도록 구성되고,
    상기 화면 전송 프로세스는 상기 웹앱의 실행을 통해 상기 브라우저 상에 표시된 화면을 캡쳐하여 상기 셋톱박스로 전송하는 것인, 세션 관리 시스템.
  9. 제 1 항에 있어서,
    상기 가상화 서버는,
    상기 셋톱박스로부터 상기 웹앱에 대한 종료를 요청받으면, 상기 세션을 종료하도록 구성되는, 세션 관리 시스템.
  10. 세션 브로커 서버에서 동적으로 세션을 할당하는 방법에 있어서,
    복수의 가상화 서버로부터 기설정된 주기로 서버 상태 정보를 수신하는 단계;
    셋톱박스로부터 세션에 대한 할당을 요청받는 단계;
    상기 서버 상태 정보에 기초하여 상기 복수의 가상화 서버 중 하나를 선정하는 단계; 및
    상기 셋톱박스에 상기 선정된 가상화 서버 및 세션을 할당하는 단계
    를 포함하고,
    상기 셋톱박스는 상기 할당된 세션 및 상기 가상화 서버를 통해 가상 브라우저 상에서 표시된 웹앱의 캡쳐된 화면을 수신하여 출력하도록 구성되는 것인, 동적 세션 할당 방법.
  11. 제 10 항에 있어서,
    상기 서버 상태 정보는,
    상기 가상화 서버의 CPU 사용률, 메모리 사용률 및 세션 사용률을 포함하는 것인, 동적 세션 할당 방법.
  12. 제 11 항에 있어서,
    상기 가상화 서버를 선정하는 단계는,
    상기 가상화 서버의 상기 CPU 사용률이 기설정된 기준값을 초과하는지 판단하는 단계
    를 포함하는 것인, 동적 세션 할당 방법.
  13. 제 12 항에 있어서,
    상기 가상화 서버를 선정하는 단계는,
    상기 CPU 사용률이 기설정된 기준값을 초과하지 않는 경우,
    상기 가상화 서버의 상기 메모리 사용률이 기설정된 기준값을 초과하는지 판단하는 단계
    를 더 포함하는 것인, 동적 세션 할당 방법.
  14. 제 13 항에 있어서,
    상기 가상화 서버를 선정하는 단계는,
    상기 메모리 사용률이 기설정된 기준값을 초과하지 않는 경우,
    상기 가상화 서버의 상기 세션 사용률이 세션 허용 기준값을 초과하는지 판단하는 단계
    를 더 포함하고,
    상기 세션 허용 기준값은 기설정된 최대 세션 허용 값에 기초하여 도출되는 것인, 동적 세션 할당 방법.
  15. 가상화 서버에서 동적으로 세션을 관리하는 방법에 있어서,
    셋톱박스로부터 웹앱에 대한 실행을 요청받는 단계;
    가상 브라우저를 통하여 상기 웹앱을 실행하는 단계;
    상기 가상 브라우저 상에서 표시된 상기 웹앱의 화면 변화를 기설정된 주기로 모니터링하는 단계;
    상기 가상 브라우저 상에 표시된 화면을 캡쳐하는 단계; 및
    상기 캡쳐된 화면을 상기 셋톱박스로 전송하는 단계
    를 포함하고,
    상기 셋톱박스는 세션 브로커 서버에 의해 할당된 세션 및 상기 가상화 서버를 통해 상기 캡쳐된 화면을 수신하여 출력하도록 구성되는, 동적 세션 관리 방법.
  16. 제 15 항에 있어서,
    상기 모니터링하는 단계에서, 상기 화면 변화가 없다고 판단된 경우,
    상기 셋톱박스로부터의 키 입력 여부를 판단하는 단계
    를 더 포함하는 것인, 동적 세션 관리 방법.
  17. 제 16 항에 있어서,
    상기 키 입력 여부를 판단하는 단계는,
    기설정된 시간 동안의 상기 키 입력 여부를 판단하는 것인, 동적 세션 관리 방법.
  18. 제 16 항에 있어서,
    상기 키 입력 여부, 상기 가상 브라우저 및 화면 전송 프로세스의 실행 중 여부에 기초하여 상기 가상 브라우저 및 화면 전송 프로세스를 정지 또는 실행하는 단계
    를 더 포함하고,
    상기 화면 전송 프로세스는 상기 웹앱의 실행을 통해 상기 브라우저 상에 표시된 화면을 캡쳐하여 상기 셋톱박스로 전송하는 것인, 동적 세션 관리 방법.
  19. 제 15 항에 있어서,
    상기 셋톱박스로부터 상기 웹앱에 대한 종료를 요청받는 단계; 및
    상기 세션을 종료하는 단계
    를 더 포함하는, 동적 세션 관리 방법.
KR1020140168389A 2014-11-28 2014-11-28 동적 세션 할당 방법, 동적 세션 관리 방법 및 시스템 KR101625159B1 (ko)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020140168389A KR101625159B1 (ko) 2014-11-28 2014-11-28 동적 세션 할당 방법, 동적 세션 관리 방법 및 시스템

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020140168389A KR101625159B1 (ko) 2014-11-28 2014-11-28 동적 세션 할당 방법, 동적 세션 관리 방법 및 시스템

Publications (1)

Publication Number Publication Date
KR101625159B1 true KR101625159B1 (ko) 2016-05-27

Family

ID=56106230

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020140168389A KR101625159B1 (ko) 2014-11-28 2014-11-28 동적 세션 할당 방법, 동적 세션 관리 방법 및 시스템

Country Status (1)

Country Link
KR (1) KR101625159B1 (ko)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20180073154A (ko) * 2016-12-22 2018-07-02 경희대학교 산학협력단 사물인터넷 환경에서 클라이언트 식별자를 이용하여 클라이언트 노드들을 논리적으로 그룹화하는 장치 및 방법

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20180073154A (ko) * 2016-12-22 2018-07-02 경희대학교 산학협력단 사물인터넷 환경에서 클라이언트 식별자를 이용하여 클라이언트 노드들을 논리적으로 그룹화하는 장치 및 방법
KR102004160B1 (ko) * 2016-12-22 2019-07-26 경희대학교 산학협력단 사물인터넷 환경에서 클라이언트 식별자를 이용하여 클라이언트 노드들을 논리적으로 그룹화하는 장치 및 방법
US10826979B2 (en) 2016-12-22 2020-11-03 University-Industry Cooperation Group Of Kyung-Hee University Apparatus and method for logically grouping client nodes in an IoT environment using client identifiers

Similar Documents

Publication Publication Date Title
US11777790B2 (en) Communications methods and apparatus for migrating a network interface and/or IP address from one Pod to another Pod in a Kubernetes system
US11546644B2 (en) Bandwidth control method and apparatus, and device
JP4984169B2 (ja) 負荷分散プログラム、負荷分散方法、負荷分散装置およびそれを含むシステム
US20110087783A1 (en) Allocating resources of a node in a server farm
US20160203024A1 (en) Apparatus and method for allocating resources of distributed data processing system in consideration of virtualization platform
KR20150085376A (ko) 클라우드 게이밍 환경에서 렌더링 서비스를 위한 부하 분산 시스템 및 이의 부하 분산 방법
RU2016103796A (ru) Система и способ управления полосой пропускания данных
US20150113156A1 (en) Prioritized blocking of on-demand requests
CN105721552B (zh) 一种基于dns实现动态负载均衡的方法及dns系统
CN104243609B (zh) 一种信息业务推送方法和装置
KR101686073B1 (ko) 클라이언트 단말이 제공받고자 하는 서비스 특성에 따라 네트워크 토폴로지를 적응적으로 변형하여 서비스를 제공받도록 지원하는 방법, 관리 서버 및 컴퓨터 판독 가능한 기록매체
CN109428926B (zh) 一种调度任务节点的方法和装置
CN110336888B (zh) 一种服务器分配方法、装置、系统及介质
CN109818977B (zh) 一种接入服务器通信优化方法、接入服务器以及通信系统
CN106686635B (zh) 基于无线接入点的控制和配置协议的数据传输方法和装置
CN113840330B (zh) 建立连接的方法、网关设备、网络系统及调度中心
CN109413117B (zh) 分布式数据计算方法、装置、服务器及计算机存储介质
KR101625159B1 (ko) 동적 세션 할당 방법, 동적 세션 관리 방법 및 시스템
CN110502343B (zh) 一种资源分配方法、系统、装置及计算机可读存储介质
KR101262849B1 (ko) 가상화 시스템 상에서 영상장치를 할당 및 해제하기 위한 장치 및 방법
US20190319901A1 (en) Scalable, real-time messaging system
KR101251630B1 (ko) 푸쉬 서비스 제공 시스템 및 방법
JP4743904B2 (ja) リソース過分配防止システム
CN106375372B (zh) 一种大数据资源分配方法和装置
CN113923206A (zh) 数据传输方法、装置及系统

Legal Events

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

Payment date: 20190502

Year of fee payment: 4