KR102275179B1 - 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치 - Google Patents

클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치 Download PDF

Info

Publication number
KR102275179B1
KR102275179B1 KR1020150057982A KR20150057982A KR102275179B1 KR 102275179 B1 KR102275179 B1 KR 102275179B1 KR 1020150057982 A KR1020150057982 A KR 1020150057982A KR 20150057982 A KR20150057982 A KR 20150057982A KR 102275179 B1 KR102275179 B1 KR 102275179B1
Authority
KR
South Korea
Prior art keywords
web server
index file
cloud streaming
screens
status code
Prior art date
Application number
KR1020150057982A
Other languages
English (en)
Other versions
KR20160126655A (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
Application filed by 에스케이플래닛 주식회사 filed Critical 에스케이플래닛 주식회사
Priority to KR1020150057982A priority Critical patent/KR102275179B1/ko
Publication of KR20160126655A publication Critical patent/KR20160126655A/ko
Priority to KR1020210087380A priority patent/KR102336604B1/ko
Application granted granted Critical
Publication of KR102275179B1 publication Critical patent/KR102275179B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3003Monitoring arrangements specially adapted to the computing system or computing system component being monitored
    • G06F11/3006Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system is distributed, e.g. networked systems, clusters, multiprocessor systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/0766Error or fault reporting or storing
    • 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
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor

Abstract

클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치가 개시된다. 웹 서버에 상응하는 인덱스 파일을 획득하고, 인덱스 파일을 웹 서버가 정상 동작할 때 획득된 원본 인덱스 파일과 비교하여 웹 서버의 정상 동작 여부를 판단하고, 웹 서버가 정상 동작하지 않는 경우에 에러 로그를 생성하여 클라우드 스트리밍 서비스 시스템에 기록할 수 있다. 클라우드 스트리밍 서비스 시 웹 서버에서 발생하는 오류를 신속하게 감지하여 처리함으로써 보다 시스템을 원활하게 운용하는 것이 가능하다.

Description

클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치{METHOD FOR MONITORING WEB SERVER BASED ON CLOUD STREAMING SERVICE AND APPARATUS FOR THE SAME}
본 발명은 클라우드 스트리밍 서비스 시 어플리케이션을 실행하는 웹 서버를 인덱스 파일을 이용하여 모니터링 할 수 있는 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치에 관한 것이다.
인터넷의 급속한 발달은 개인의 통신 속도를 급격히 향상시키는 결과를 가져왔으며, 이러한 통신 속도의 향상은 원격지에 위치한 컴퓨터에 접속하여 대용량의 데이터를 다운로드 또는 업로드 하거나, 원격지 컴퓨터 제어 프로그램을 사용하여 마치 원격지 컴퓨터에 로컬 로그인한 것과 같이 원격지 컴퓨터를 이용할 수 있는 환경을 제공하고 있다.
또한, 스마트폰과 같은 이동통신 단말에서 구동되는 어플리케이션이 다양하게 개발되면서, 비교적 낮은 성능의 사용자 단말에서 높은 성능을 필요로 하는 어플리케이션을 구동하기 위한 가상화 기술들이 많이 제안되고 있다.
그 중에서 어플리케이션을 웹 서버에서 구동시키고 구동화면은 비디오 인코딩(Encoding)을 통해 압축하여 클라이언트로 전송하고, 클라이언트는 전송된 비디오를 재생하여 마치 자신의 단말에서 어플리케이션이 구동되는 것과 같은 효과를 내는 화면 가상화 기반의 클라우드 스트리밍 서비스가 각광받고 있는 추세이다.
클라우드 스트리밍 서비스 시스템은 웹 서버에서 실행되는 어플리케이션의 구동화면을 이용하기 때문에 지속적으로 웹 서버의 상태를 모니터링 할 필요가 있다. 그러나, 별도의 비용을 들여서 웹 서버를 모니터링 하는 것은 클라우드 스트리밍 서비스를 제공하는 제공자 입장에서 매우 큰 부담으로 작용할 수 있다.
또한, 기존의 모니터링 도구들은 단순히 서비스되고 있는 웹 서버의 http protocol 감시를 수행하는 정도로 웹 서버의 상태를 체크하는 것이 어렵다.
따라서, 웹 서버의 상태와 더불어 최종 렌더링 이미지까지 자동 검수할 수 있는 새로운 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법이 절실하게 대두된다.
한국 등록 특허 제10-1408037호, 2014년 06월 10일 공개 (명칭: 클라우드 시스템에서의 가상 머신 통합 모니터링 장치 및 방법)
본 발명의 목적은, 클라우드 스트리밍 서비스를 제공하기 위한 웹 서버의 상태를 주기적으로 체크하여 신속하게 웹 서버의 오류를 감지하고, 감지된 오류를 처리함으로써 보다 원활한 클라우드 스트리밍 서비스를 제공하는 것이다.
또한, 본 발명의 목적은 웹 서버에서 발생한 오류 정보를 로그 기록에 상응하는 형태로 클라우드 스트리밍 시스템에 제공함으로써 웹 서버의 에러 발생상황을 클라우드 스트리밍 서버에서 보다 빠르게 감지하도록 하는 것이다.
또한, 본 발명의 목적은 웹 서버에서 제공되는 인덱스 파일을 기반으로 웹 서버 모니터링 장치를 통해 웹 서버의 오류를 감지함으로써, 관리자를 통해 웹 서버를 모니터링 할 때보다 모니터링에 필요한 비용을 절약하는 것이다.
상기한 목적을 달성하기 위한 본 발명에 따른 웹 서버 모니터링 장치는, 웹 서버에 상응하는 인덱스 파일을 획득하는 인덱스 파일 획득부; 상기 인덱스 파일을 상기 웹 서버가 정상 동작할 때 획득된 원본 인덱스 파일과 비교하여 상기 웹 서버의 정상 동작 여부를 판단하는 판단부; 및 상기 웹 서버가 정상 동작하지 않는 경우에 에러 로그를 생성하고, 클라우드 스트리밍 서비스 시스템에 상기 에러 로그를 기록하는 로그 기록부를 포함한다.
이 때, 판단부는 상기 인덱스 파일과 상기 원본 인덱스 파일이 일치하지 않는 경우에 상기 웹 서버가 정상 동작하지 않는 것으로 판단할 수 있다.
이 때, 판단부는 상기 인덱스 파일을 획득할 때 HTTP 메시지의 헤더를 기반으로 상태 코드(Status Code)를 획득하고, 상기 상태 코드가 적어도 하나 이상의 기설정된 정상 코드에 상응하지 않는 경우에 상기 웹 서버가 정상 동작하지 않는 것으로 판단할 수 있다.
이 때, 판단부는 상기 인덱스 파일과 상기 원본 인덱스 파일을 비교하기 전에, 상기 상태 코드를 이용하여 상기 웹 서버의 정상 동작 여부를 판단할 수 있다.
이 때, 웹 서버 모니터링 장치는 상기 웹 서버에서 제공되는 메뉴 정보를 기반으로 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득하는 서브 타이틀 화면 획득부를 더 포함할 수 있다.
이 때, 판단부는 상기 웹 서버가 정상 동작할 때 획득된 상기 적어도 둘 이상의 연속적 서브 타이틀 화면에 상응하는 적어도 둘 이상의 비교화면을 이용하여 상기 웹 서버의 정상 동작 여부를 판단할 수 있다.
이 때, 판단부는 상기 적어도 둘 이상의 연속적 서브 타이틀 화면과 상기 적어도 둘 이상의 비교화면이 일치하지 않는 경우에 상기 웹 서버가 정상 동작하지 않는 것으로 판단할 수 있다.
이 때, 인덱스 파일 획득부는 기설정된 주기마다 상기 인덱스 파일을 획득할 수 있다.
이 때, 웹 서버 모니터링 장치는 상기 원본 인덱스 파일, 상기 적어도 둘 이상의 비교화면 및 상기 적어도 하나의 기설정된 정상 코드 중 적어도 하나를 포함하는 데이터베이스를 더 포함할 수 있다.
또한, 본 발명에 따른 웹 서버 모니터링 방법은, 웹 서버에 상응하는 인덱스 파일을 획득하는 단계; 상기 인덱스 파일을 상기 웹 서버가 정상 동작할 때 획득한 원본 인덱스 파일과 비교하여 상기 웹 서버의 정상 동작 여부를 판단하는 단계; 및 상기 웹 서버가 정상 동작하지 않는 경우에 에러 로그를 생성하고, 클라우드 스트리밍 서비스 시스템에 상기 에러 로그를 기록하는 단계를 포함한다.
이 때, 판단하는 단계는 상기 인덱스 파일과 상기 원본 인덱스 파일이 일치하지 않는 경우에 상기 웹 서버가 정상 동작하지 않는 것으로 판단할 수 있다.
이 때, 판단하는 단계는 상기 인덱스 파일을 획득할 때 HTTP 메시지의 헤더를 기반으로 상태 코드(Status Code)를 획득하고, 상기 상태 코드가 적어도 하나 이상의 기설정된 정상 코드에 상응하지 않는 경우에 상기 웹 서버가 정상 동작하지 않을 수 있다.
이 때, 판단하는 단계는 상기 인덱스 파일과 상기 원본 인덱스 파일을 비교하기 전에, 상기 상태 코드를 이용하여 상기 웹 서버의 정상 동작 여부를 판단할 수 있다.
이 때, 웹 서버 모니터링 방법은 상기 웹 서버에서 제공되는 메뉴 정보를 기반으로 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득하는 단계를 더 포함할 수 있다.
이 때, 판단하는 단계는 상기 웹 서버가 정상 동작할 때 획득된 상기 적어도 둘 이상의 연속적 서브 타이틀 화면에 상응하는 적어도 둘 이상의 비교화면을 이용하여 상기 웹 서버의 정상 동작 여부를 판단할 수 있다.
이 때, 판단하는 단계는 상기 적어도 둘 이상의 연속적 서브 타이틀 화면과 상기 적어도 둘 이상의 비교화면이 일치하지 않는 경우에 상기 웹 서버가 정상 동작하지 않을 수 있다.
이 때, 인덱스 파일을 획득하는 단계는 기설정된 주기마다 상기 인덱스 파일을 획득할 수 있다.
이 때, 웹 서버 모니터링 방법은 상기 원본 인덱스 파일, 상기 적어도 둘 이상의 비교화면 및 상기 적어도 하나의 기설정된 정상 코드 중 적어도 하나를 포함하는 단계를 더 포함할 수 있다.
본 발명에 따르면, 클라우드 스트리밍 서비스를 제공하기 위한 웹 서버의 상태를 주기적으로 체크하여 신속하게 웹 서버의 오류를 감지하고, 감지된 오류를 처리함으로써 보다 원활한 클라우드 스트리밍 서비스를 제공할 수 있다.
또한, 본 발명은 웹 서버에서 발생한 오류 정보를 로그 기록에 상응하는 형태로 클라우드 스트리밍 시스템에 제공함으로써 웹 서버의 에러 발생상황을 클라우드 스트리밍 서버에서 보다 빠르게 감지할 수 있다.
또한, 본 발명은 웹 서버에서 제공되는 인덱스 파일을 기반으로 웹 서버 모니터링 장치를 통해 웹 서버의 오류를 감지함으로써, 관리자를 통해 웹 서버를 모니터링 할 때보다 모니터링에 필요한 비용을 절약할 수 있다.
도 1은 본 발명의 일실시예에 따른 웹 서버 모니터링 시스템을 나타낸 블록도이다.
도 2는 도 1에 도시된 웹 서버 모니터링 장치의 일 예를 나타낸 블록도이다.
도 3은 본 발명의 일실시예에 따른 인덱스 파일의 획득 과정을 나타낸 도면이다.
도 4는 본 발명의 일실시예에 따라 데이터베이스에 저장된 상태코드 정보를 나타낸 도면이다.
도 5는 본 발명의 일실시예에 따른 비교화면을 나타낸 도면이다.
도 6은 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법을 나타낸 동작 흐름도이다.
도 7은 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법을 상세하게 나타낸 동작 흐름도이다.
도 8은 본 발명의 일실시예에 따라 인덱스 파일 및 상태코드를 이용하는 웹 서버 모니터링 과정을 나타낸 도면이다.
도 9는 본 발명의 일실시예에 따라 비교화면을 이용하는 웹 서버 모니터링 과정을 나타낸 도면이다.
이하 본 발명의 바람직한 실시예를 첨부한 도면을 참조하여 상세히 설명한다. 다만, 하기의 설명 및 첨부된 도면에서 본 발명의 요지를 흐릴 수 있는 공지 기능 또는 구성에 대한 상세한 설명은 생략한다. 또한, 도면 전체에 걸쳐 동일한 구성 요소들은 가능한 한 동일한 도면 부호로 나타내고 있음에 유의하여야 한다. 본 발명의 실시형태는 당 업계에서 평균적인 지식을 가진 자에게 본 발명을 보다 완전하게 설명하기 위해서 제공되는 것이다. 따라서, 도면에서의 요소들의 형상 및 크기 등은 보다 명확한 설명을 위해 과장될 수 있다.
이하에서 설명되는 본 명세서 및 청구범위에 사용된 용어나 단어는 통상적이거나 사전적인 의미로 한정해서 해석되어서는 아니 되며, 발명자는 그 자신의 발명을 가장 최선의 방법으로 설명하기 위한 용어의 개념으로 적절하게 정의할 수 있다는 원칙에 입각하여 본 발명의 기술적 사상에 부합하는 의미와 개념으로 해석되어야만 한다. 따라서 본 명세서에 기재된 실시예와 도면에 도시된 구성은 본 발명의 가장 바람직한 일 실시예에 불과할 뿐이고, 본 발명의 기술적 사상을 모두 대변하는 것은 아니므로, 본 출원시점에 있어서 이들을 대체할 수 있는 다양한 균등물과 변형 예들이 있을 수 있음을 이해하여야 한다. 또한 제 1, 제 2 등의 용어는 다양한 구성요소들을 설명하기 위해 사용하는 것으로, 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 사용될 뿐, 상기 구성요소들을 한정하기 위해 사용되지 않는다.
도 1은 본 발명의 일실시예에 따른 웹 서버 모니터링 시스템을 나타낸 블록도이다.
도 1을 참조하면, 본 발명의 일실시예에 따른 웹 서버 모니터링 시스템은 웹 서버 모니터링 장치(110), 웹 서버(120-1~ 120-N), 클라우드 스트리밍 서버(130), 단말(140-1~ 140-N) 및 네트워크(150)를 포함한다.
웹 서버 모니터링 장치(110)는 웹 서버(120-1~ 120-N)에 상응하는 인덱스 파일을 획득한다.
규모가 크지 않은 개인 홈페이지나 웹사이트는 하나의 큰 서버에서 일정부분을 할당 받아서 그 영역에 웹 문서와 이미지를 올리고 운영할 수 있다. 이 때, 할당 받은 영역은 호스팅 업체에 따라 다를 수 있으며, 일반적으로 'www'나 'public_html' 또는 'htdocs'등의 이름을 가진 디렉토리로 주어질 수 있다. 그리고 자신의 도메인 주소가 이러한 디렉토리로 연결이 될 수 있다.
인덱스(Index) 파일은 이러한 디렉토리의 대표 문서로서, 웹 브라우저에서 특정 디렉토리에 접속했을 때 자동적으로 보여주는 파일일 수 있다. 만약 디렉토리에 인덱스 파일이 없을 경우에 그 디렉토리에 있는 파일들을 리스트 형식으로 보여주거나 또는 forbidden 메시지가 뜨면서 접근이 금지될 수 있다.
예를 들어, 브라우저에서 'http://yoursite.com/'이라고 입력한다면 public_html 디렉토리에 있는 index.html을 보게 되는 셈이고, 이는 브라우저에 'http://yoursite.com/index.html'을 입력한 것과 같은 결과가 나올 수 있다.
따라서, 본 발명에서는 웹 서버 모니터링 장치(110)가 웹 서버(120-1~ 120-N)에 접속하고, 웹 서버(120-1~ 120-N)에 상응하는 디렉토리로부터 인덱스 파일을 획득할 수 있다.
예를 들어, 웹 서버(120-1~ 120-N)의 public_html 디렉토리에 존재하는 인덱스 파일을 획득할 수 있다.
또한, 인덱스 파일은 사용된 언어에 따라서 index.html, index.htm, index.php, index.shtml 및 index.asp 등이 사용될 수 있다. 만약 하나의 디렉토리에 두 개의 인덱스 파일이 있다면, 보통 html, htm 및 php 등의 파일 순서로 우선 순위를 가질 수 있다.
이 때, 기설정된 주기마다 인덱스 파일을 획득할 수 있다. 즉, 지속적으로 웹 서버(120-1~ 120-N)의 상태를 모니터링 하기 위해 사전에 모니터링 주기를 설정하고, 설정한 주기마다 웹 서버(120-1~ 120-N)를 모니터링 하기 위해 인덱스 파일을 획득할 수 있다.
또한, 웹 서버 모니터링 장치(110)는 웹 서버(120-1~ 120-N)에서 제공되는 메뉴 정보를 기반으로 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득한다.
이 때, 종래의 웹 서버 모니터링 도구는 단순히 웹 서버의 http protocol 감시를 하는 정도였으나, 본 발명에서는 브라우저에서 최종 렌더링된 이미지에 상응하는 적어도 둘 이상의 연속적 서브 타이틀 화면을 이용하여 웹 서버(120-1~ 120-N)가 정상 동작 중인지 여부를 판단할 수 있다.
또한, 웹 서버 모니터링 장치(110)는 인덱스 파일을 웹 서버(120-1~ 120-N)가 정상 동작할 때 획득된 원본 인덱스 파일과 비교하여 웹 서버(120-1~ 120-N)의 정상 동작 여부를 판단한다.
이 때, 인덱스 파일과 원본 인덱스 파일이 일치하지 않는 경우에 웹 서버가 정상 동작하지 않는 것으로 판단할 수 있다. 즉, 원본 인덱스 파일은 웹 서버(120-1~ 120-N)가 정상 동작 할 때 획득하였으므로, 인덱스 파일이 원본 인덱스 파일과 동일하지 않다면 원본 인덱스를 획득한 시점에서의 웹 서버(120-1~ 120-N)는 정상적으로 동작하지 않는 것으로 판단할 수 있다.
이 때, 인덱스 파일을 획득할 때 HTTP 메시지의 헤더를 기반으로 상태 코드(Status Code)를 획득하고, 상태 코드가 적어도 하나 이상의 기설정된 정상 코드에 상응하지 않는 경우에 웹 서버가 정상 동작하지 않는 것으로 판단할 수 있다. 예를 들어, 상태 코드를 확인한 결과 403번에 상응하는 'FORBIDDEN' 이라고 가정한다면, 웹 서버 모니터링 장치(110)가 해당 웹 서버(120-1~ 120-N)에 접근할 수 있는 권한이 없는 상태이므로 현재 웹 서버(120-1~ 120-N)가 오작동하고 있는 것으로 판단할 수 있다.
이 때, 인덱스 파일과 원본 인덱스 파일을 비교하기 전에, 상태 코드를 이용하여 웹 서버의 정상 동작 여부를 판단할 수 있다. 즉, 인덱스 파일과 원본 인덱스 파일이 동일한지 여부에 따라 웹 서버(120-1~ 120-N)의 정상 동작 여부를 판단하는 과정보다 상태 코드를 확인하여 웹 서버(120-1~ 120-N)의 정상 동작 여부를 판단하는 것이 수월할 수 있다. 따라서, 우선 상태 코드를 통한 판단을 수행한 뒤 인덱스 파일과 원본 인덱스 파일을 비교할 수 있다.
또한, 인덱스 파일과 원본 인덱스 파일을 비교하는 과정과 동시에 상태 코드를 확인함으로써, 두 가지 방식의 웹 서버(120-1~ 120-N) 모니터링을 동시에 수행할 수도 있다.
이 때, 웹 서버가 정상 동작할 때 획득된 적어도 둘 이상의 연속적 서브 타이틀 화면에 상응하는 적어도 둘 이상의 비교화면을 이용하여 웹 서버의 정상 동작 여부를 판단할 수 있다. 예를 들어, 정상 동작 중인 웹 서버(120-1~ 120-N)에서 A, B 및 C에 상응하는 메뉴 항목들을 차례로 이동하면서 해당하는 메뉴 항목에 상응하는 비교화면을 캡처하여 저장해둘 수 있다. 이 후, 웹 서버(120-1~ 120-N) 모니터링 과정에서 비교화면과 동일하게 메뉴 항목들을 A, B 및 C의 순서로 이동하며 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득할 수 있다.
이 때, 적어도 둘 이상의 연속적 서브 타이틀 화면과 적어도 둘 이상의 비교 화면이 일치하지 않는 경우에 웹 서버(120-1~ 120-N)가 정상 동작 하지 않는 것으로 판단할 수 있다. 즉, 웹 서버(120-1~ 120-N)가 정상 동작한다면, 같은 메뉴 항목들을 이동하면서 생성된 화면이 동일해야 하기 때문에, 적어도 둘 이상의 연속적 서브 타이틀 화면과 적어도 둘 이상의 비교화면의 일치 여부를 통해 웹 서버(120-1~ 120-N)의 정상 동작 여부를 판단할 수 있다.
또한, 웹 서버 모니터링 장치(110)는 웹 서버(120-1~ 120-N)가 정상 동작하지 않는 경우에 에러 로그를 생성하고, 클라우드 스트리밍 서비스 시스템에 에러 로그를 기록한다.
이 때, 에러 로그는 사전에 설정된 형식에 상응하게 생성될 수 있으며, 클라우드 스트리밍 서비스 시스템에서 인식할 수 있는 형식일 수 있다.
또한, 웹 서버 모니터링 장치(110)는 원본 인덱스 파일, 적어도 둘 이상의 비교화면 및 적어도 하나의 기설정된 정상 코드 중 적어도 하나를 포함한다.
이 때, 적어도 하나의 기설정된 정상 코드에 대한 정보를 포함하는 상태 코드의 정보를 포함할 수 있다. 예를 들어, 상태 코드에 따른 상태 및 설명을 포함하는 테이블을 포함할 수 있다.
웹 서버(120-1~ 120-N)는 단말(140-1~ 140-N)을 통한 사용자의 키 입력에 따라, 어플리케이션을 실행한다.
이 때, 클라우드 스트리밍 서버(130)를 통해 단말(140-1~ 140-N)의 키 입력을 획득할 수 있고, 클라우드 스트리밍 서버(130)의 웹 브라우저를 이용하여 웹 서버(120-1~ 120-N)에서 실행한 어플리케이션을 제공할 수 있다.
또한, 웹 서버(120-1~ 120-N)는 웹 서버 모니터링 장치(110)의 요청에 따라 인덱스 파일을 전달할 수도 있다. 즉, 웹 서버 모니터링 장치(110)가 정상 동작 중인 웹 서버(120-1~ 120-N)에 접속하면, 웹 서버(120-1~ 120-N)는 디렉토리에 포함된 인덱스 파일을 전달할 수 있다.
클라우드 스트리밍 서버(130)는 네트워크(150)를 통해 각각 단말(140-1~ 140-N)과 웹 서버(120-1~ 120-N)의 통신을 수행할 수 있다.
이 때, 단말(140-1~ 140-N)로부터 키 입력을 획득하고, 획득한 키 입력을 웹 서버(120-1~ 120-N)로 전달하여 키 입력에 상응하는 어플리케이션 실행화면을 획득할 수 있다. 이 후, 획득한 어플리케이션 실행화면에 대해 렌더링, 캡처, 인코딩 및 센딩에 상응하는 파이프라인 과정을 수행하여 단말(140-1~ 140-N)에 클라우드 스트리밍 서비스를 제공할 수 있다.
단말(140-1~ 140-N)은 클라우드 스트리밍 서버(130)로부터 클라우드 스트리밍 서비스에 상응하는 어플리케이션 실행화면을 수신하여 사용자에게 제공한다.
또한, 단말(140-1~ 140-N)은 각각 통신망에 연결되어 클라우드 컴퓨팅 시스템 기반으로 어플리케이션을 실행할 수 있는 장치로, 이동통신단말기에 한정된 것이 아니고, 모든 정보통신기기, 멀티미디어 단말, 유선 단말, 고정형 단말 및 IP(Internet Protocol) 단말 등의 다양한 단말일 수 있다. 또한, 단말(140-1~ 140-N)은 각각 휴대폰, PMP(Portable Multimedia Played), MID(Mobile Internet Device), 스마트폰(Smart Phone), 데스크톱(Desktop), 태블릿컴퓨터(Tablet PC), 노트북(Note book), 넷북(Net Book), 개인휴대용 정보단말(Personal Digital Assistant; PDA), 스마트 TV 및 정보통신 기기 등과 같은 다양한 이동통신 사양을 갖는 모바일(Mobile) 단말일 수 있다.
또한, 단말(140-1~ 140-N)은 숫자 및 문자 정보 등의 다양한 정보를 입력 받고, 각종 기능을 설정 및 단말(140-1~ 140-N)의 기능 제어와 관련하여 입력되는 신호를 입력부를 통해 제어부로 전달할 수 있다. 또한, 단말(140-1~ 140-N)의 입력부는 사용자의 터치 또는 조작에 따른 입력 신호를 발생하는 키패드와 터치패드 중 적어도 하나를 포함하여 구성할 수 있다. 이 때, 단말(140-1~ 140-N)의 입력부는 단말(140-1~ 140-N)의 표시부와 함께 하나의 터치패널(또는 터치 스크린(touch screen))의 형태로 구성되어 입력과 표시 기능을 동시에 수행할 수 있다. 또한, 단말(140-1~ 140-N)의 입력부는 키보드, 키패드, 마우스, 조이스틱 등과 같은 입력 장치 외에도 향후 개발될 수 있는 모든 형태의 입력 수단이 사용될 수 있다. 특히, 본 발명에 따른 단말(140-1~ 140-N)의 입력부는 클라우드 컴퓨팅 기반으로 컨텐츠를 업로드 하거나 다운로드 하기 위한 입력 신호를 단말(140-1~ 140-N)의 제어부로 전달할 수 있다.
또한, 단말(140-1~ 140-N)의 표시부는 단말(140-1~ 140-N)의 기능 수행 중에 발생하는 일련의 동작상태 및 동작결과 등에 대한 정보를 표시할 수 있다. 또한, 단말(140-1~ 1420-N)의 표시부는 단말(140-1~ 140-N)의 메뉴 및 사용자가 입력한 사용자 데이터 등을 표시할 수 있다. 여기서, 단말(140-1~ 140-N)의 표시부는 액정표시장치(LCD, Liquid Crystal Display), 초박막 액정표시장치(TFT-LCD, Thin Film Transistor LCD), 발광다이오드(LED, Light Emitting Diode), 유기 발광다이오드(OLED, Organic LED), 능동형 유기발광다이오드(AMOLED, Active Matrix OLED), 레티나 디스플레이(Retina Display), 플렉시블 디스플레이(Flexible display) 및 3차원(3 Dimension) 디스플레이 등으로 구성될 수 있다. 이 때, 단말(140-1~ 140-N)의 표시부가 터치스크린 형태로 구성된 경우, 단말(140-1~ 140-N)의 표시부는 단말(140-1~ 140-N)의 입력부의 기능 중 일부 또는 전부를 수행할 수 있다. 특히, 본 발명에 따른 단말(140-1~ 140-N)의 표시부는 클라우드 컴퓨팅 기반으로 제공되는 컨텐츠의 실행과 관련된 정보를 화면으로 표시할 수 있다.
또한, 단말(140-1~ 140-N)의 저장부는 데이터를 저장하기 위한 장치로, 주 기억장치 및 보조 기억장치를 포함하고, 단말(140-1~ 140-N)의 기능 동작에 필요한 응용 프로그램을 저장할 수 있다. 이러한 단말(140-1~ 140-N)의 저장부는 크게 프로그램 영역과 데이터 영역을 포함할 수 있다. 여기서, 단말(140-1~ 140-N)는 사용자의 요청에 상응하여 각 기능을 활성화하는 경우, 제어부의 제어 하에 해당 응용 프로그램들을 실행하여 각 기능을 제공하게 된다. 특히, 본 발명에 따른 단말(140-1~ 140-N)의 저장부는 단말(140-1~ 140-N)를 부팅시키는 운영체제, 클라우드 컴퓨팅 기반으로 컨텐츠를 업로드 하거나 다운로드하기 위한 프로그램 등을 저장할 수 있다. 또한, 단말(140-1~ 140-N)의 저장부는 다수의 컨텐츠를 저장하는 컨텐츠 DB와 단말(140-1~ 140-N)의 정보를 저장할 수 있다. 이 때, 컨텐츠 DB는 컨텐츠를 실행하기 위한 실행 데이터와 컨텐츠에 대한 속성 정보를 포함하고, 컨텐츠 실행에 따른 컨텐츠 사용 정보 등이 저장될 수 있다. 그리고, 단말(140-1~ 140-N)의 정보는 단말 사양 정보를 포함할 수 있다.
또한, 단말(140-1~ 140-N)의 통신부는 클라우드 스트리밍 서버(130)와 네트워크(150)을 통해 데이터를 송수신하기 위한 기능을 수행할 수 있다. 여기서 단말(140-1~ 140-N)의 통신부는 송신되는 신호의 주파수를 상승 변환 및 증폭하는 RF 송신 수단과 수신되는 신호를 저잡음 증폭하고 주파수를 하강 변환하는 RF 수신 수단 등을 포함할 수 있다. 이러한 단말(140-1~ 140-N)의 통신부는 무선통신 모듈 및 유선통신 모듈 중 적어도 하나를 포함할 수 있다. 그리고, 무선통신 모듈은 무선 통신 방법에 따라 데이터를 송수신하기 위한 구성이며, 단말(140-1~ 140-N)이 무선 통신을 이용하는 경우, 무선망 통신 모듈, 무선랜 통신 모듈 및 무선팬 통신 모듈 중 어느 하나를 이용하여 데이터를 클라우드 스트리밍 서버(130)로 송수신할 수 있다. 또한, 유선통신 모듈은 유선으로 데이터를 송수신하기 위한 것이다. 유선통신 모듈은 유선을 통해 네트워크(150)에 접속하여, 클라우드 스트리밍 서버(130)에 데이터를 송수신할 수 있다. 즉 단말(140-1~ 140-N)은 무선통신 모듈 또는 유선통신 모듈을 이용하여 네트워크(150)에 접속하며, 네트워크(150)을 통해 클라우드 스트리밍 서버(130)와 데이터를 송수신할 수 있다. 특히, 본 발명에 따른 네트워크(150)는 클라우드 스트리밍 서버(130) 또는 다른 단말(140-1~ 140-N)과 통신하여 클라우드 컴퓨팅 기반으로 컨텐츠를 업로드 또는 다운로드 하는데 필요한 데이터를 송수신할 수 있다.
또한, 단말 장치(140-1~ 140-N)의 제어부는 운영 체제((OS, Operation System) 및 각 구성을 구동시키는 프로세스 장치가 될 수 있다. 예를 들어, 제어부는 클라우드 스트리밍 서버(130)에 접속하는 과정 전반을 제어할 수 있다. 별도의 서비스 어플리케이션을 통해 클라우드 스트리밍 서버(130)에 접속하는 경우, 사용자의 요청에 따라 서비스 어플리케이션을 실행되는 과정 전반을 제어할 수 있으며, 실행과 동시에 클라우드 스트리밍 서버(130)로 서비스 이용 요청이 전송되도록 제어할 수 있으며, 이때 사용자 인증에 필요한 단말(140-1~ 140-N)의 정보가 함께 전송되도록 제어할 수 있다.
또한, 단말(140-1~ 140-N)의 제어부는 사용자의 요청에 따라 단말(140-1~ 140-N)의 저장부에 저장된 특정 컨텐츠를 실행할 수 있다. 이때, 제어부는 컨텐츠 실행에 따른 컨텐츠 사용 이력을 컨텐츠 사용 정보로 저장할 수 있다.
또한, 단말(140-1~ 140-N)의 제어부는 컨텐츠를 실행하기 위한 실행 데이터와, 컨텐츠에 대한 속성 정보를 포함하는 컨텐츠 정보와, 컨텐츠 사용 이력에 따른 정보인 컨텐츠 사용 정보를 함께 클라우드 스트리밍 서버(130)로 전송하여 업로드 할 수 있다. 이후, 제어부는 클라우드 스트리밍 서버(130)에 전송하여 업로드된 컨텐츠에 대해서는 사용자의 요청에 따라 단말(140-1~ 140-N)의 저장부에서 삭제할 수 있으며, 클라우드 스트리밍 서버(130)에 접속하여 클라우드 스트리밍 서버(130)를 통해 컨텐츠를 실행하여 이용할 수도 있다.
또한, 단말(140-1~ 140-N)의 제어부는 클라우드 스트리밍 서버(130)에 접속하여 다른 단말(140-1~ 140-N)로부터 컨텐츠를 다운로드한 후 저장부에 저장되도록 제어할 수도 있으며, 클라우드 스트리밍 서버(130)를 통해 컨텐츠 실행 시, 실행에 필요한 데이터만을 수신한 후 컨텐츠가 실행되도록 제어할 수도 있다.
네트워크(150)는 웹 서버 모니터링 장치(110)와 웹 서버(120-1~ 120-N), 웹 서버(120-1~ 120-N)와 클라우드 스트리밍 서버(130) 및 클라우드 스트리밍 서버(130)와 단말(140-1~ 140-N) 사이에 데이터를 전달하는 통로를 제공하는 것으로서, 기존에 이용되는 네트워크 및 향후 개발 가능한 네트워크를 모두 포괄하는 개념이다. 예를 들어, 네트워크(150)는 한정된 지역 내에서 각종 정보장치들의 통신을 제공하는 유무선근거리 통신망, 이동체 상호 간 및 이동체와 이동체 외부와의 통신을 제공하는 이동통신망, 위성을 이용해 지구국과 지구국간 통신을 제공하는 위성통신망이거나 유무선 통신망 중에서 어느 하나이거나, 둘 이상의 결합으로 이루어질 수 있다. 한편, 네트워크(150)의 전송 방식 표준은, 기존의 전송 방식 표준에 한정되는 것은 아니며, 향후 개발될 모든 전송 방식 표준을 포함할 수 있다.
도 2는 도 1에 도시된 웹 서버 모니터링 장치의 일 예를 나타낸 블록도이다.
도 2를 참조하면, 도 1에 도시된 웹 서버 모니터링 장치(110)는 인덱스 파일 획득부(210), 서브 타이틀 화면 획득부(220), 판단부(230), 로그 기록부(240) 및 데이터베이스(250)를 포함한다.
인덱스 파일 획득부(210)는 웹 서버에 상응하는 인덱스 파일을 획득한다.
이 때, 웹 서버는 사용자가 단말을 통해 입력한 키 입력에 상응하게 어플리케이션을 실행시키는 서버에 상응할 수 있다. 즉, 웹 서버에서 문제가 발생하는 경우에는 클라우드 스트리밍 서비스 시스템 전체적으로 지연 또는 오류가 발생할 수 있기 때문에 웹 서버에 대한 모니터링은 필수적일 수 있다.
따라서, 본 발명에서는 웹 서버를 모니터링 하기 위해 웹 서버에 상응하는 인덱스 파일을 이용할 수 있다.
이 때, 인덱스 파일은 웹 서버에 접속하였을 때 제공되는 대표 문서로서, 클라우드 스트리밍 서버의 웹 브라우저에서 웹 서버의 특정 디렉토리에 접속했을 때 자동적으로 보여주는 파일일 수 있다.
규모가 크지 않은 개인 홈페이지나 웹사이트는 하나의 큰 서버에서 일정부분을 할당 받아서 그 영역에 웹 문서와 이미지를 올리고 운영할 수 있다. 이 때, 할당 받은 영역은 호스팅 업체에 따라 다를 수 있으며, 일반적으로 'www'나 'public_html' 또는 'htdocs'등의 이름을 가진 디렉토리로 주어질 수 있다. 그리고 자신의 도메인 주소가 이러한 디렉토리로 연결이 될 수 있다.
만약 디렉토리에 인덱스 파일이 없을 경우에 그 디렉토리에 있는 파일들을 리스트 형식으로 보여주거나 또는 forbidden 메시지가 뜨면서 접근이 금지될 수 있다. 예를 들어, 브라우저에서 'http://yoursite.com/'이라고 입력한다면 public_html 디렉토리에 있는 index.html을 보게 되는 셈이고, 이는 브라우저에 'http://yoursite.com/index.html'을 입력한 것과 같은 결과가 나올 수 있다.
또한, 인덱스 파일은 사용된 언어에 따라서 index.html, index.htm, index.php, index.shtml 및 index.asp 등이 사용될 수 있다. 만약 하나의 디렉토리에 두 개의 인덱스 파일이 있다면, 보통 html, htm 및 php 등의 파일 순서로 우선 순위를 가질 수 있다.
이 때, 기설정된 주기마다 인덱스 파일을 획득할 수 있다. 클라우드 스트리밍 서비스 시스템이 운용되는 동안에는 지속적으로 웹 서버를 모니터링 할 필요가 있으므로, 사전에 모니터링을 수행할 주기를 설정해두고 설정된 주기에 따라 웹 서버에 상응하는 인덱스 파일을 획득할 수 있다.
또한, 인덱스 파일을 획득하기 위한 주기를 너무 짧게 설정한다면 웹 서버 모니터링 장치(110)와 웹 서버에서 불필요한 부하가 많이 발생할 수 있다. 따라서, 웹 서버가 원활하게 어플리케이션 실행하는데 문제가 발생하지 않도록 주기를 설정할 수 있다.
서브 타이틀 화면 획득부(220)는 웹 서버에서 제공되는 메뉴 정보를 기반으로 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득한다.
이 때, 종래의 웹 서버 모니터링 도구는 단순히 웹 서버의 http protocol 감시를 하는 정도였으나, 본 발명에서는 브라우저에서 최종 렌더링된 이미지에 상응하는 적어도 둘 이상의 연속적 서브 타이틀 화면을 이용하여 웹 서버가 정상 동작 중인지 여부를 판단할 수 있다.
예를 들어, 클라우드 스트리밍 서버의 웹 브라우저를 통해 웹 서버에 접속할 수 있다. 또한, 웹 브라우저를 통해 웹 서버에 접속한 후 자동으로 메뉴 항목을 참고하여 적어도 둘 이상의 서브 타이틀 화면을 이동하면서 해당 화면의 이미지를 캡처하여 저장할 수 있다.
이 때, 서브 타이틀 화면을 획득하기 위한 이동 방식은 웹 서버의 메뉴 항목이나 웹 서버의 종류에 따라 다양하게 설정될 수 있다. 또한, 이러한 이동 방식은 적어도 둘 이상의 비교화면을 획득할 때의 이동 방식과 동일할 수 있다. 즉, 사전에 적어도 둘 이상의 비교화면을 저장하기 위해 이동했던 방식과 동일하게 적어도 둘 이상의 서브 타이틀 화면을 획득할 수 있다.
이 때, 인덱스 파일과 마찬가지로 기설정된 주기마다 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득할 수 있다. 또한, 인덱스 파일을 획득하는 주기와는 별개로 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득하기 위한 주기를 생성하여 사용할 수도 있다.
이 때, 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득하여 웹 서버의 정상 동작 여부를 판단하는 과정은 인덱스 파일을 원본 인덱스 파일과 비교하여 정상 동작 여부를 판단하는 과정보다 많은 리소스를 사용할 수 있다.
따라서, 너무 빈번하게 서브 타이틀 화면을 획득하여 웹 서버의 정상 동작 여부를 판단하는 경우, 웹 서버 모니터링 장치(110)에 발생하는 부하량이 커져서 시스템 오작동이 발생하거나 처리가 지연되는 문제가 발생할 수 있으므로 적절한 주기를 설정하여 서브 타이틀을 획득할 수 있다.
예를 들어, 인덱스 파일을 획득하는 주기가 5분이라고 가정한다면, 서브 타이틀 화면을 획득하는 주기는 인덱스 파일을 획득하는 주기보다 길게 10분에서 15분으로 설정함으로써 웹 서버 및 웹 서버 모니터링 장치(110)의 부하량을 조절할 수 있다.
판단부(230)는 인덱스 파일을 웹 서버가 정상 동작할 때 획득된 원본 인덱스 파일과 비교하여 웹 서버의 정상 동작 여부를 판단한다.
이 때, 원본 인덱스 파일은 웹 서버 모니터링 장치(110)를 통해 웹 서버의 모니터링을 수행하기 전에, 웹 서버가 정상 동작인 것을 확인하고 획득한 인덱스 파일에 상응할 수 있다. 즉, 웹 서버가 정상일 때의 인덱스 파일을 저장해두었다가 모니터링 시점에 획득한 인덱스 파일과 비교함으로써 웹 서버의 정상 동작 여부를 판단할 수 있다.
이 때, 인덱스 파일과 원본 인덱스 파일이 일치하지 않는 경우에 웹 서버가 정상 동작하지 않는 것으로 판단할 수 있다. 또한, 일치하지 않는 부분이 어느 부분인지 체크하여 추후에 에러 로그를 생성하는데 사용할 수도 있다.
이 때, 인덱스 파일을 획득할 때 HTTP 메시지의 헤더를 기반으로 상태 코드(Status Code)를 획득하고, 상태 코드가 적어도 하나 이상의 기설정된 정상 코드에 상응하지 않는 경우에 웹 서버가 정상 동작하지 않는 것으로 판단할 수 있다.
이 때, 상태 코드는 특정 요청에 대한 응답 상태 코드에 상응할 수 있다. 즉, 본 발명에 실시예에 따른 HTTP 상태 코드는 HTTP 응답상태코드에 상응하며, 1xx, 2xx, 3xx, 4xx, 5xx로 구성될 수 있고, 각각의 구성마다 카테고리를 보유한다. 1xx는 조건부 응답, 2xx는 성공, 3xx는 리다이렉션 완료, 4xx는 요청 오류, 5xx는 응답 오류에 상응할 수 있다.
예를 들어, 웹 서버의 인덱스 파일에 상응하는 index.html을 http 프로토콜을 사용하여 획득할 수 있다. 이 때, 웹 서버로부터 수신한 HTTP 메시지에 상응하는 http response 메시지의 헤더 중 상태 코드에 상응하는 http status 값을 획득할 수 있다. 이와 같이 획득한 http status 값이 여러 가지 상태 코드의 값들 중 정상에 상응하는 값인지 확인할 수 있다. 즉, 상태 코드가 'Request complete'에 상응하는 200번 또는 ' If-modified-since was not modified'에 상응하는 304번에 상응한다면, 웹 서버가 정상적으로 동작하고 있는 것으로 판단할 수 있다. 또는 상태 코드가 'Invalid syntax'에 상응하는 400번, 'Request forbidden'에 상응하는 403번 또는 'Object not found'에 상응하는 404번 등에 상응한다면, 웹 서버가 정상적으로 동작하고 있지 않은 것으로 판단할 수 있다.
이 때, 인덱스 파일과 원본 인덱스 파일을 비교하기 전에, 상태 코드를 이용하여 웹 서버의 정상 동작여부를 판단할 수 있다. 즉, 인덱스 파일과 원본 인덱스 파일을 비교하는 동작이 상태 코드를 확인하는 동작보다 많은 시간과 리소스를 사용할 수 있기 때문에, 먼저 상태 코드를 확인하여 웹 서버의 정상 동작 여부를 판단할 수 있다.
또한, 인덱스 파일과 원본 인덱스 파일을 비교하는 과정과 상태 코드를 확인하는 과정을 동시에 수행할 수도 있다.
이 때, 웹 서버가 정상 동작할 때 획득된 적어도 둘 이상의 연속적 서브 타이틀 화면에 상응하는 적어도 둘 이상의 비교화면을 이용하여 웹 서버의 정상 동작 여부를 판단할 수 있다. 예를 들어, 웹 서버가 정상 동작할 때 웹 서버의 메뉴 중 A1, A2, A3를 순서대로 이동하며 비교화면을 획득할 수 있다. 이 후, 웹 서버를 모니터링 하기 위한 연속적 서브 타이틀 화면을 획득하기 위해서는, 비교화면을 획득할 때와 동일하게 A1, A2, A3의 메뉴 순서대로 이동하면서 서브 타이틀 화면을 획득할 수 있다. 이렇게 획득한 비교화면과 서브 타이틀 화면이 일치하는지 여부를 확인하여 웹 서버의 정상 동작 여부를 판단할 수 있다.
또한, 비교화면과 서브 타이틀 화면의 일치 여부는 이미지를 서로 비교할 수 있는 이미지 비교 방법들을 이용하여 확인할 수 있다. 예를 들어, 웹 서버로부터 획득한 적어도 둘 이상의 비교화면과 적어도 둘 이상의 서브 타이틀 화면의 픽셀들을 비교하여 두 화면이 동일한지 여부를 판단할 수도 있다.
이 때, 적어도 둘 이상의 연속적 서브 타이틀 화면과 적어도 둘 이상의 비교화면이 일치하지 않는 경우에 웹 서버가 정상 동작하지 않는 것으로 판단할 수 있다. 즉, 웹 서버가 정상 동작한다면, 같은 메뉴 항목들을 이동하면서 생성된 화면이 동일해야 하기 때문에, 적어도 둘 이상의 연속적 서브 타이틀 화면과 적어도 둘 이상의 비교화면이 일치하지 않는다면 웹 서버에서 오류가 발생한 것으로 판단할 수 있다.
로그 기록부(240)는 웹 서버가 정상 동작하지 않는 경우에 에러 로그를 생성하고, 클라우드 스트리밍 서비스 시스템에 에러 로그를 기록한다.
이 때, 클라우드 스트리밍 서비스 시스템은 클라우드 스트리밍 서버에 상응할 수 있으며, 에러 로그를 클라우드 스트리밍 서버에 기록함으로써 클라우드 스트리밍 서버가 웹 서버를 복구하도록 제어할 수 있다.
이 때, 에러 로그는 클라우드 스트리밍 서비스 시스템에서 인지할 수 있도록 사전에 설정된 형식에 상응하게 생성될 수 있다. 즉, 시스템 메시지 또는 시스템 상태 코드에 상응하는 형태일 수 있다.
또한, 에러 로그는 웹 서버에서 에러를 감지한 방식에 따라 별도의 감지 정보를 포함할 수 있다. 예를 들어, 상태 코드를 이용하여 에러를 감지한 경우에는 에러 로그와 함께 획득한 상태 코드의 정보를 포함시킬 수 있다. 또한, 인덱스 파일과 원본 인덱스 파일이 일치하지 않는 경우에는 에러 로그와 함께 인덱스 파일과 원본 인덱스 파일이 일치하지 않는 부분을 포함시킬 수도 있다.
이와 같이 에러 로그와 함께 관련된 정보를 함께 기록함으로써, 클라우드 스트리밍 서비스 시스템의 관리자가 보다 수월하게 오류상황을 파악할 수 있다.
데이터베이스(250)는 원본 인덱스 파일, 적어도 둘 이상의 비교화면 및 적어도 하나의 기설정된 정상 코드 중 적어도 하나를 포함한다.
예를 들어, 모니터링을 수행하기 전에 웹 서버에 접속하여 원본 인덱스 파일과 적어도 둘 이상의 비교화면을 획득하여 저장해둘 수 있다. 또한 복수 개의 상태 코드 중에서 적어도 하나의 정상 코드를 설정하여 별도로 저장해 둘 수 있다. 이와 같이 적어도 하나의 정상 코드를 사전에 설정하여 별도로 저장해 둠으로써, 후에 모니터링을 수행하여 획득한 상태 코드가 정상 코드에 해당하는지 여부를 신속하게 판단할 수 있다.
또한, 데이터베이스(250)는 상술한 바와 같이 본 발명의 실시예에 따른 웹 서버 모니터링 과정에서 발생하는 다양한 정보를 저장할 수 있다.
실시예에 따라, 데이터베이스(250)는 웹 서버 모니터링 장치(110)와 독립적으로 구성되어 웹 서버 모니터링을 위한 기능을 지원할 수 있다. 이 때, 데이터베이스(250)는 별도의 대용량 스토리지로 동작할 수 있고, 동작 수행을 위한 제어 기능을 포함할 수도 있다.
한편, 웹 서버 모니터링 장치(110)는 메모리가 탑재되어 그 장치 내에서 정보를 저장할 수 있다. 일 구현예의 경우, 메모리는 컴퓨터로 판독 가능한 매체이다. 일 구현 예에서, 메모리는 휘발성 메모리 유닛일 수 있으며, 다른 구현예의 경우, 메모리는 비휘발성 메모리 유닛일 수도 있다. 일 구현예의 경우, 저장장치는 컴퓨터로 판독 가능한 매체이다. 다양한 서로 다른 구현 예에서, 저장장치는 예컨대 하드디스크 장치, 광학디스크 장치, 혹은 어떤 다른 대용량 저장장치를 포함할 수도 있다.
이와 같은 웹 서버 모니터링 장치(110)를 통해 클라우드 스트리밍 서비스를 제공하기 위한 웹 서버의 상태를 주기적으로 체크하여 신속하게 웹 서버의 오류를 감지할 수 있다.
또한, 웹 서버에서 발생한 오류를 에러 로그의 형태로 클라우드 스트리밍 서버에 제공함으로써, 클라우드 스트리밍 서버의 제어를 통해 신속하게 웹 서버를 복구할 수 있다.
도 3은 본 발명의 일실시예에 따른 인덱스 파일의 획득 과정을 나타낸 도면이다.
도 3을 참조하면, 본 발명의 일실시예에 따른 인덱스 파일의 획득 과정은 먼저 웹 서버 모니터링 장치(310)가 HTTP 메시지에 상응하는 Request 메시지(311)를 웹 서버(320)로 전송하여 인덱스 파일을 요청할 수 있다.
이 때, Request 메시지(311)에 상응하는 HTTP 메시지는 Request 라인, HTTP 헤더 및 HTTP 본문을 포함할 수 있다.
이 후, 웹 서버(320)에서는 Request 메시지(311)를 수신한 뒤, 웹 서버 모니터링 장치(310)에게 인덱스 파일을 전달하면서 Response 메시지(321)를 전달할 수 있다.
이 때, Response 메시지(321)에 상응하는 HTTP 메시지도 Request 메시지(311)와 마찬가지로 Response 라인, HTTP 헤더 및 HTTP 본문을 포함할 수 있다. 또한, HTTP 헤더 중 http status 값에 상응하는 상태 코드를 획득할 수 있다.
도 4는 본 발명의 일실시예에 따라 데이터베이스에 저장된 상태코드 정보를 나타낸 도면이다.
도 4를 참조하면, 본 발명의 일실시예에 따라 웹 서버의 정상 동작 여부를 판단하기 위한 상태코드 정보(410)를 확인할 수 있다.
이 때, 상태코드 정보(410)는 웹 서버 모니터링 장치에 포함되거나 또는 독립적으로 존재할 수 있는 데이터베이스에 저장될 수 있다.
이 때, 상태코드 정보(410)에는 다양한 종류의 상태 코드가 포함될 수 있다. 예를 들어, 100번대에 상응하는 상태 코드는 정보를 알리거나, Request가 현재 처리되고 있다는 것을 알리는 상태 코드들이 포함될 수 있다. 또한, 200번대에 상응하는 상태 코드는 웹 서버가 Request를 성공적으로 수신하여 처리하였음을 알리는 상태 코드들이 포함될 수 있다. 또한, 300번대에 상응하는 상태 코드는 Request에 따른 정보가 이동하였기 때문에 Request가 수행되지 않은 것을 의미하는 코드들이 포함될 수 있다. 또한, 400번대에 상응하는 상태 코드는 클라이언트 측에서 에러가 발생한 것을 의미하는 코드들이 포함될 수 있다. 또한, 500번대에 상응하는 상태 코드는 웹 서버 측에서 에러가 발생하여 Request에 대한 처리를 못하는 것을 알리는 상태 코드들이 포함될 수 있다.
도 5는 본 발명의 일실시예에 따른 비교화면을 나타낸 도면이다.
도 5를 참조하면, 본 발명의 일실시예에 따른 비교화면(510~540)은 웹 서버의 메뉴 항목을 이동하면서 획득될 수 있다.
예를 들어, 도 5에 나타낸 비교화면(510~540)은 '우리동네 사랑방', '최신 영화관', 'VOD 다시보기' 및 '마이콘텐츠'에 각각 상응하는 메뉴 항목을 통해 획득될 수 있다. 즉, 도 5에 나타낸 순서대로 (A, B, C, D)에 상응하는 순서대로 이동하며 비교화면(510~540)을 획득할 수 있다.
이와 같이 획득한 비교화면(510~540)은 웹 서버 모니터링 장치의 데이터베이스에 저장해 두었다가 후에 웹 서버의 정상 동작 여부를 판단하는데 사용될 수 있다.
따라서, 웹 서버의 정상 동작 여부를 판단하기 위해 웹 서버에서 적어도 둘 이상의 서브 타이틀 화면을 획득할 때에도, 비교화면(510~540)을 획득할 때와 같이 (A, B, C, D)에 상응하는 순서로 메뉴를 이동하며 서브 타이틀 화면을 캡처 및 저장할 수 있다.
도 6은 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법을 나타낸 동작 흐름도이다.
도 6을 참조하면, 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법은 웹 서버에 상응하는 인덱스 파일을 획득한다(S610).
이 때, 웹 서버는 사용자가 단말을 통해 입력한 키 입력에 상응하게 어플리케이션을 실행시키는 서버에 상응할 수 있다. 즉, 웹 서버에서 문제가 발생하는 경우에는 클라우드 스트리밍 서비스 시스템 전체적으로 지연 또는 오류가 발생할 수 있기 때문에 웹 서버에 대한 모니터링은 필수적일 수 있다.
따라서, 본 발명에서는 웹 서버를 모니터링 하기 위해 웹 서버에 상응하는 인덱스 파일을 이용할 수 있다.
이 때, 인덱스 파일은 웹 서버에 접속하였을 때 제공되는 대표 문서로서, 클라우드 스트리밍 서버의 웹 브라우저에서 웹 서버의 특정 디렉토리에 접속했을 때 자동적으로 보여주는 파일일 수 있다.
규모가 크지 않은 개인 홈페이지나 웹사이트는 하나의 큰 서버에서 일정부분을 할당 받아서 그 영역에 웹 문서와 이미지를 올리고 운영할 수 있다. 이 때, 할당 받은 영역은 호스팅 업체에 따라 다를 수 있으며, 일반적으로 'www'나 'public_html' 또는 'htdocs'등의 이름을 가진 디렉토리로 주어질 수 있다. 그리고 자신의 도메인 주소가 이러한 디렉토리로 연결이 될 수 있다.
만약 디렉토리에 인덱스 파일이 없을 경우에 그 디렉토리에 있는 파일들을 리스트 형식으로 보여주거나 또는 forbidden 메시지가 뜨면서 접근이 금지될 수 있다. 예를 들어, 브라우저에서 'http://yoursite.com/'이라고 입력한다면 public_html 디렉토리에 있는 index.html을 보게 되는 셈이고, 이는 브라우저에 'http://yoursite.com/index.html'을 입력한 것과 같은 결과가 나올 수 있다.
또한, 인덱스 파일은 사용된 언어에 따라서 index.html, index.htm, index.php, index.shtml 및 index.asp 등이 사용될 수 있다. 만약 하나의 디렉토리에 두 개의 인덱스 파일이 있다면, 보통 html, htm 및 php 등의 파일 순서로 우선 순위를 가질 수 있다.
이 때, 기설정된 주기마다 인덱스 파일을 획득할 수 있다. 클라우드 스트리밍 서비스 시스템이 운용되는 동안에는 지속적으로 웹 서버를 모니터링 할 필요가 있으므로, 사전에 모니터링을 수행할 주기를 설정해두고 설정된 주기에 따라 웹 서버에 상응하는 인덱스 파일을 획득할 수 있다.
또한, 인덱스 파일을 획득하기 위한 주기를 너무 짧게 설정한다면 웹 서버 모니터링 장치와 웹 서버에서 불필요한 부하가 많이 발생할 수 있다. 따라서, 웹 서버가 원활하게 어플리케이션 실행하는데 문제가 발생하지 않도록 주기를 설정할 수 있다.
또한, 도 6에는 도시하지 아니하였으나, 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법은 웹 서버에서 제공되는 메뉴 정보를 기반으로 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득한다.
이 때, 종래의 웹 서버 모니터링 도구는 단순히 웹 서버의 http protocol 감시를 하는 정도였으나, 본 발명에서는 브라우저에서 최종 렌더링된 이미지에 상응하는 적어도 둘 이상의 연속적 서브 타이틀 화면을 이용하여 웹 서버가 정상 동작 중인지 여부를 판단할 수 있다.
예를 들어, 클라우드 스트리밍 서버의 웹 브라우저를 통해 웹 서버에 접속할 수 있다. 또한, 웹 브라우저를 통해 웹 서버에 접속한 후 자동으로 메뉴 항목을 참고하여 적어도 둘 이상의 서브 타이틀 화면을 이동하면서 해당 화면의 이미지를 캡처하여 저장할 수 있다.
이 때, 서브 타이틀 화면을 획득하기 위한 이동 방식은 웹 서버의 메뉴 항목이나 웹 서버의 종류에 따라 다양하게 설정될 수 있다. 또한, 이러한 이동 방식은 적어도 둘 이상의 비교화면을 획득할 때의 이동 방식과 동일할 수 있다. 즉, 사전에 적어도 둘 이상의 비교화면을 저장하기 위해 이동했던 방식과 동일하게 적어도 둘 이상의 서브 타이틀 화면을 획득할 수 있다.
이 때, 인덱스 파일과 마찬가지로 기설정된 주기마다 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득할 수 있다. 또한, 인덱스 파일을 획득하는 주기와는 별개로 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득하기 위한 주기를 생성하여 사용할 수도 있다.
이 때, 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득하여 웹 서버의 정상 동작 여부를 판단하는 과정은 인덱스 파일을 원본 인덱스 파일과 비교하여 정상 동작 여부를 판단하는 과정보다 많은 리소스를 사용할 수 있다.
따라서, 너무 빈번하게 서브 타이틀 화면을 획득하여 웹 서버의 정상 동작 여부를 판단하는 경우, 웹 서버 모니터링 장치(110)에 발생하는 부하량이 커져서 시스템 오작동이 발생하거나 처리가 지연되는 문제가 발생할 수 있으므로 적절한 주기를 설정하여 서브 타이틀을 획득할 수 있다.
예를 들어, 인덱스 파일을 획득하는 주기가 5분이라고 가정한다면, 서브 타이틀 화면을 획득하는 주기는 인덱스 파일을 획득하는 주기보다 길게 10분에서 15분으로 설정함으로써 웹 서버 및 웹 서버 모니터링 장치의 부하량을 조절할 수 있다.
또한, 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법은 인덱스 파일을 웹 서버가 정상 동작할 때 획득된 원본 인덱스 파일과 비교하여 웹 서버의 정상 동작 여부를 판단한다(S615).
이 때, 원본 인덱스 파일은 웹 서버 모니터링 장치를 통해 웹 서버의 모니터링을 수행하기 전에, 웹 서버가 정상 동작인 것을 확인하고 획득한 인덱스 파일에 상응할 수 있다. 즉, 웹 서버가 정상일 때의 인덱스 파일을 저장해두었다가 모니터링 시점에 획득한 인덱스 파일과 비교함으로써 웹 서버의 정상 동작 여부를 판단할 수 있다.
이 때, 인덱스 파일과 원본 인덱스 파일이 일치하지 않는 경우에 웹 서버가 정상 동작하지 않는 것으로 판단할 수 있다. 또한, 일치하지 않는 부분이 어느 부분인지 체크하여 추후에 에러 로그를 생성하는데 사용할 수도 있다.
이 때, 인덱스 파일을 획득할 때 HTTP 메시지의 헤더를 기반으로 상태 코드(Status Code)를 획득하고, 상태 코드가 적어도 하나 이상의 기설정된 정상 코드에 상응하지 않는 경우에 웹 서버가 정상 동작하지 않는 것으로 판단할 수 있다.
이 때, 상태 코드는 특정 요청에 대한 응답 상태 코드에 상응할 수 있다. 즉, 본 발명에 실시예에 따른 HTTP 상태 코드는 HTTP 응답상태코드에 상응하며, 1xx, 2xx, 3xx, 4xx, 5xx로 구성될 수 있고, 각각의 구성마다 카테고리를 보유한다. 1xx는 조건부 응답, 2xx는 성공, 3xx는 리다이렉션 완료, 4xx는 요청 오류, 5xx는 응답 오류에 상응할 수 있다.
예를 들어, 웹 서버의 인덱스 파일에 상응하는 index.html을 http 프로토콜을 사용하여 획득할 수 있다. 이 때, 웹 서버로부터 수신한 HTTP 메시지에 상응하는 http response 메시지의 헤더 중 상태 코드에 상응하는 http status 값을 획득할 수 있다. 이와 같이 획득한 http status 값이 여러 가지 상태 코드의 값들 중 정상에 상응하는 값인지 확인할 수 있다. 즉, 상태 코드가 'Request complete'에 상응하는 200번 또는 ' If-modified-since was not modified'에 상응하는 304번에 상응한다면, 웹 서버가 정상적으로 동작하고 있는 것으로 판단할 수 있다. 또는 상태 코드가 'Invalid syntax'에 상응하는 400번, 'Request forbidden'에 상응하는 403번 또는 'Object not found'에 상응하는 404번 등에 상응한다면, 웹 서버가 정상적으로 동작하고 있지 않은 것으로 판단할 수 있다.
이 때, 인덱스 파일과 원본 인덱스 파일을 비교하기 전에, 상태 코드를 이용하여 웹 서버의 정상 동작여부를 판단할 수 있다. 즉, 인덱스 파일과 원본 인덱스 파일을 비교하는 동작이 상태 코드를 확인하는 동작보다 많은 시간과 리소스를 사용할 수 있기 때문에, 먼저 상태 코드를 확인하여 웹 서버의 정상 동작 여부를 판단할 수 있다.
또한, 인덱스 파일과 원본 인덱스 파일을 비교하는 과정과 상태 코드를 확인하는 과정을 동시에 수행할 수도 있다.
이 때, 웹 서버가 정상 동작할 때 획득된 적어도 둘 이상의 연속적 서브 타이틀 화면에 상응하는 적어도 둘 이상의 비교화면을 이용하여 웹 서버의 정상 동작 여부를 판단할 수 있다. 예를 들어, 웹 서버가 정상 동작할 때 웹 서버의 메뉴 중 A1, A2, A3를 순서대로 이동하며 비교화면을 획득할 수 있다. 이 후, 웹 서버를 모니터링 하기 위한 연속적 서브 타이틀 화면을 획득하기 위해서는, 비교화면을 획득할 때와 동일하게 A1, A2, A3의 메뉴 순서대로 이동하면서 서브 타이틀 화면을 획득할 수 있다. 이렇게 획득한 비교화면과 서브 타이틀 화면이 일치하는지 여부를 확인하여 웹 서버의 정상 동작 여부를 판단할 수 있다.
또한, 비교화면과 서브 타이틀 화면의 일치 여부는 이미지를 서로 비교할 수 있는 이미지 비교 방법들을 이용하여 확인할 수 있다. 예를 들어, 웹 서버로부터 획득한 적어도 둘 이상의 비교화면과 적어도 둘 이상의 서브 타이틀 화면의 픽셀들을 비교하여 두 화면이 동일한지 여부를 판단할 수도 있다.
이 때, 적어도 둘 이상의 연속적 서브 타이틀 화면과 적어도 둘 이상의 비교화면이 일치하지 않는 경우에 웹 서버가 정상 동작하지 않는 것으로 판단할 수 있다. 즉, 웹 서버가 정상 동작한다면, 같은 메뉴 항목들을 이동하면서 생성된 화면이 동일해야 하기 때문에, 적어도 둘 이상의 연속적 서브 타이틀 화면과 적어도 둘 이상의 비교화면이 일치하지 않는다면 웹 서버에서 오류가 발생한 것으로 판단할 수 있다.
또한, 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법은 웹 서버가 정상 동작하지 않는 경우에 에러 로그를 생성하고, 클라우드 스트리밍 서비스 시스템에 에러 로그를 기록한다(S620).
이 때, 클라우드 스트리밍 서비스 시스템은 클라우드 스트리밍 서버에 상응할 수 있으며, 에러 로그를 클라우드 스트리밍 서버에 기록함으로써 클라우드 스트리밍 서버가 웹 서버를 복구하도록 제어할 수 있다.
이 때, 에러 로그는 클라우드 스트리밍 서비스 시스템에서 인지할 수 있도록 사전에 설정된 형식에 상응하게 생성될 수 있다. 즉, 시스템 메시지 또는 시스템 상태 코드에 상응하는 형태일 수 있다.
또한, 에러 로그는 웹 서버에서 에러를 감지한 방식에 따라 별도의 감지 정보를 포함할 수 있다. 예를 들어, 상태 코드를 이용하여 에러를 감지한 경우에는 에러 로그와 함께 획득한 상태 코드의 정보를 포함시킬 수 있다. 또한, 인덱스 파일과 원본 인덱스 파일이 일치하지 않는 경우에는 에러 로그와 함께 인덱스 파일과 원본 인덱스 파일이 일치하지 않는 부분을 포함시킬 수도 있다.
이와 같이 에러 로그와 함께 관련된 정보를 함께 기록함으로써, 클라우드 스트리밍 서비스 시스템의 관리자가 보다 수월하게 오류상황을 파악할 수 있다.
또한, 도 6에는 도시하지 아니하였으나, 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법은 원본 인덱스 파일, 적어도 둘 이상의 비교화면 및 적어도 하나의 기설정된 정상 코드 중 적어도 하나를 데이터베이스에 저장한다.
예를 들어, 모니터링을 수행하기 전에 웹 서버에 접속하여 원본 인덱스 파일과 적어도 둘 이상의 비교화면을 획득하여 저장해둘 수 있다. 또한 복수 개의 상태 코드 중에서 적어도 하나의 정상 코드를 설정하여 별도로 저장해 둘 수 있다. 이와 같이 적어도 하나의 정상 코드를 사전에 설정하여 별도로 저장해 둠으로써, 후에 모니터링을 수행하여 획득한 상태 코드가 정상 코드에 해당하는지 여부를 신속하게 판단할 수 있다.
또한, 데이터베이스는 상술한 바와 같이 본 발명의 실시예에 따른 웹 서버 모니터링 과정에서 발생하는 다양한 정보를 저장할 수 있다.
실시예에 따라, 데이터베이스는 웹 서버 모니터링 장치와 독립적으로 구성되어 웹 서버 모니터링을 위한 기능을 지원할 수 있다. 이 때, 데이터베이스는 별도의 대용량 스토리지로 동작할 수 있고, 동작 수행을 위한 제어 기능을 포함할 수도 있다.
이와 같은 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법을 이용하여 웹 서버의 http 프로토콜뿐만 아니라 웹 서버의 상태를 모니터링 할 수 있다. 또한, 주기적으로 웹 서버의 모니터링을 수행함으로써 웹 서버에서 발생하는 오류를 신속하게 처리할 수 있고, 이에 따라 보다 원활한 클라우드 스트리밍 서비스를 제공할 수 있다.
도 7은 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법을 상세하게 나타낸 동작 흐름도이다.
도 7을 참조하면, 본 발명의 일실시예에 따른 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법은 먼저 웹 서버에 상응하는 인덱스 파일 및 웹 서버에서 제공되는 메뉴 정보를 기반으로 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득한다(S710).
이 때, 인덱스 파일은 웹 서버에 접속하였을 때 제공되는 대표 문서로서, 클라우드 스트리밍 서버의 웹 브라우저에서 웹 서버의 특정 디렉토리에 접속했을 때 자동적으로 보여주는 파일일 수 있다.
또한, 종래의 웹 서버 모니터링 도구는 단순히 웹 서버의 http protocol 감시를 하는 정도였으나, 본 발명에서는 브라우저에서 최종 렌더링된 이미지에 상응하는 적어도 둘 이상의 연속적 서브 타이틀 화면을 이용하여 웹 서버가 정상 동작 중인지 여부를 판단할 수 있다.
이 후, 인덱스 파일을 획득할 때 HTTP 메시지의 헤더를 기반으로 상태 코드(Status Code)를 획득한다(S720).
예를 들어, 웹 서버의 인덱스 파일에 상응하는 index.html을 http 프로토콜을 사용하여 획득할 수 있다. 이 때, 웹 서버로부터 수신한 HTTP 메시지에 상응하는 http response 메시지의 헤더 중 상태 코드에 상응하는 http status 값을 획득할 수 있다.
이 후, 상태 코드가 적어도 하나 이상의 기설정된 정상 코드에 상응하는지 여부를 판단한다(S725). 예를 들어, 상태 코드가 'Request complete'에 상응하는 200번 또는 ' If-modified-since was not modified'에 상응하는 304번에 상응한다면, 웹 서버가 정상적으로 동작하고 있는 것으로 판단할 수 있다. 또는 상태 코드가 'Invalid syntax'에 상응하는 400번, 'Request forbidden'에 상응하는 403번 또는 'Object not found'에 상응한느 404번 등에 상응한다면, 웹 서버가 정상적으로 동작하고 있지 않은 것으로 판단할 수 있다.
단계(S725)의 판단결과 상응하지 않으면, 에러 로그를 생성하여(S730) 클라우드 스트리밍 시스템에 기록한다(S740).
이 때, 에러 로그는 클라우드 스트리밍 서비스 시스템에서 인지할 수 있도록 사전에 설정된 형식에 상응하게 생성될 수 있다. 즉, 시스템 메시지 또는 시스템 상태 코드에 상응하는 형태일 수 있다.
단계(S725)의 판단결과 상응하면, 인덱스 파일과 원본 인덱스 파일이 일치하는지 여부를 판단한다(S735).
단계(S735)의 판단결과 일치하지 않으면, 에러 로그를 생성하여(S730) 클라우드 스트리밍 시스템에 기록한다(S740).
단계(S735)의 판단결과 일치하면, 적어도 둘 이상의 연속적 서브 타이틀 화면과 적어도 둘 이상의 비교화면이 일치하는지 여부를 판단한다(S745).
단계(S745)의 판단결과 일치하지 않으면, 에러 로그를 생성하여(S730) 클라우드 스트리밍 시스템에 기록한다(S740).
단계(S745)의 판단결과 일치하면, 현재 웹 서버에서는 에러가 발생하지 않은 것으로 판단하고 기설정된 주기 동안 대기한다(S750).
이 후, 다시 단계(S710)부터의 과정을 수행함으로써 지속적으로 웹 서버를 모니터링 할 수 있다. 즉, 클라우드 스트리밍 서비스 시스템이 운용되는 동안에는 지속적으로 웹 서버를 모니터링 할 필요가 있으므로, 사전에 모니터링을 수행할 주기를 설정해두고 설정된 주기에 따라 웹 서버에 상응하는 인덱스 파일을 획득할 수 있다.
도 8은 본 발명의 일실시예에 따라 인덱스 파일 및 상태코드를 이용하는 웹 서버 모니터링 과정을 나타낸 도면이다.
도 8을 참조하면, 본 발명의 일실시예에 따라 인덱스 파일 및 상태 코드를 이용하는 웹 서버 모니터링 과정은 먼저 웹 서버 모니터링 장치(810)가 웹 서버(820)에게 인덱스 파일을 요청한다(S802).
이 때, 인덱스 파일은 웹 서버에 접속하였을 때 제공되는 대표 문서로서, 클라우드 스트리밍 서버의 웹 브라우저에서 웹 서버의 특정 디렉토리에 접속했을 때 자동적으로 보여주는 파일일 수 있다.
이 후, 웹 서버 모니터링 장치(810)의 요청을 수신한 웹 서버(820)는 인덱스 파일을 웹 서버 모니터링 장치(810)에게 전송한다(S804).
이 후, 웹 서버 모니터링 장치(810)는 인덱스 파일을 수신하면서 Response 메시지의 헤더에 포함된 상태코드를 획득한다(S806).
이 후, 상태 코드가 적어도 하나 이상의 기설정된 정상 코드에 상응하는지 여부를 판단한다(S808).
단계(S808)의 판단결과 상태 코드가 적어도 하나 이상의 기설정된 정상 코드에 상응하지 않으면, 에러 로그를 생성하여 클라우드 스트리밍 서버(830)로 전달한다(S810).
이 후, 클라우드 스트리밍 서버(830)에서는 수신한 에러 로그를 기록하여(S812) 웹 서버(820)에서 발생한 에러를 감지할 수 있다.
또한, 단계(S808)의 판단결과 상태 코드가 적어도 하나 이상의 기설정된 정상 코드에 상응하면, 인덱스 파일이 웹 서버 모니터링 장치(810)의 데이터베이스에 저장된 원본 인덱스 파일과 일치하는지 여부를 판단한다(S814).
단계(S814)의 판단결과 일치하지 않으면, 에러 로그를 생성하여 클라우드 스트리밍 서버(830)로 전달한다(S816).
이 후, 클라우드 스트리밍 서버(830)에서는 수신한 에러 로그를 기록하여(S818) 웹 서버(820)에서 발생한 에러를 감지할 수 있다.
또한, 단계(S814)의 판단결과 일치하면, 기설정된 주기 동안 대기하였다가(S820), 다시 웹 서버(820)를 모니터링 하기 위한 동작을 수행할 수 있다.
도 9는 본 발명의 일실시예에 따라 비교화면을 이용하는 웹 서버 모니터링 과정을 나타낸 도면이다.
도 9를 참조하면, 본 발명의 일실시예에 따라 비교화면을 이용하여 웹 서버 모니터링 과정은 먼저 웹 서버 모니터링 장치(910)가 웹 서버(920)에게 적어도 둘 이상의 서브 타이틀 화면을 요청한다(S902).
이 후, 요청을 받은 웹 서버(920)는 적어도 둘 이상의 서브 타이틀 화면을 이미지로 캡처하여 웹 서버 모니터링 장치(910)로 전송한다(S904).
이 후, 웹 서버 모니터링 장치(910)는 적어도 둘 이상의 서브 타이틀 화면과 데이터베이스에 저장된 적어도 둘 이상의 비교화면을 비교한다(S906).
이 후, 적어도 둘 이상의 서브 타이틀 화면과 적어도 둘 이상의 비교화면이 일치하는지 판단하여(S908) 일치하지 않으면, 에러 로그를 생성하여 클라우드 스트리밍 서버(930)로 전달한다(S910).
이 후, 클라우드 스트리밍 서버(930) 에서는 수신한 에러 로그를 기록하여(S912) 웹 서버(920)에서 발생한 에러를 감지할 수 있다.
또한, 단계(S908)의 판단결과 일치하면, 웹 서버(920)에서 오류가 발생하지 않은 것으로 판단하고 기설정된 주기 동안 대기한다(S914).
이 때, 기설정된 주기가 지나고 나면 다시 웹 서버(920)를 모니터링 하기 위한 과정을 반복하여 수행할 수 있다.
본 발명에 따른 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법은 다양한 컴퓨터 수단을 통하여 수행될 수 있는 프로그램 명령 형태로 구현되어 컴퓨터 판독 가능 매체에 기록될 수 있다. 상기 컴퓨터 판독 가능 매체는 프로그램 명령, 데이터 파일, 데이터 구조 등을 단독으로 또는 조합하여 포함할 수 있다. 상기 매체에 기록되는 프로그램 명령은 본 발명을 위하여 특별히 설계되고 구성된 것들이거나 컴퓨터 소프트웨어 당업자에게 공지되어 사용 가능한 것일 수도 있다. 컴퓨터 판독 가능 기록 매체의 예에는 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체(magnetic media), CD-ROM, DVD와 같은 광기록 매체(optical media), 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical media), 및 롬(ROM), 램(RAM), 플래시 메모리 등과 같은 프로그램 명령을 저장하고 수행하도록 특별히 구성된 모든 형태의 하드웨어 장치가 포함된다. 프로그램 명령의 예에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함할 수 있다. 이러한 하드웨어 장치는 본 발명의 동작을 수행하기 위해 하나 이상의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지이다.
이상에서와 같이 본 발명에 따른 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치는 상기한 바와 같이 설명된 실시예들의 구성과 방법이 한정되게 적용될 수 있는 것이 아니라, 상기 실시예들은 다양한 변형이 이루어질 수 있도록 각 실시예들의 전부 또는 일부가 선택적으로 조합되어 구성될 수도 있다.
본 발명에 의하면 웹 서버에 상응하는 인덱스 파일을 획득하고, 인덱스 파일을 웹 서버가 정상 동작할 때 획득된 원본 인덱스 파일과 비교하여 웹 서버의 정상 동작 여부를 판단하고, 웹 서버가 정상 동작하지 않는 경우에 에러 로그를 생성하여 클라우드 스트리밍 서비스 시스템에 기록할 수 있다. 나아가, 클라우드 스트리밍 서비스 시 별도의 관리자를 통해 웹 서버를 모니터링 하지 않고도 웹 서버에서 발생하는 오류를 신속하게 감지할 수 있어 효율적인 모니터링 시스템을 구축하는 것이 가능하다.
110, 310: 웹 서버 모니터링 장치
120-1~ 120-N, 320: 웹 서버
130: 클라우드 스트리밍 서버 140-1~ 140-N: 단말
150: 네트워크 210: 인덱스 파일 획득부
220: 서브 타이틀 화면 획득부 230: 판단부
240: 로그 기록부 250: 데이터베이스
311: Request 메시지 321: Response 메시지
410: 상태코드 정보 510~ 540: 비교화면

Claims (10)

  1. 웹 서버에 상응하는 인덱스 파일을 획득하는 인덱스 파일 획득부;
    상기 웹 서버에서 제공되는 메뉴 정보를 기반으로 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득하는 서브 타이틀 화면 획득부;
    상기 인덱스 파일을 상기 웹 서버가 정상 동작할 때 획득된 원본 인덱스 파일과 비교하고, 상기 인덱스 파일과 상기 원본 인덱스 파일이 일치하지 않는 경우에 상기 웹 서버가 정상 동작하지 않는 것으로 판단하는 판단부; 및
    상기 웹 서버가 정상 동작하지 않는 경우에 에러 로그를 생성하고, 클라우드 스트리밍 서비스 시스템에 상기 에러 로그를 기록하는 로그 기록부;를 포함하되,
    상기 판단부는
    상기 적어도 둘 이상의 연속적 서브 타이틀 화면과, 상기 서브 타이틀 화면과 상응하는 적어도 둘 이상의 비교화면에 대한 일치 여부를 더 확인하고, 상기 확인된 결과가 일치하지 않으면 상기 웹 서버가 정상 동작하지 않는 것으로 판단하는 것을 특징으로 하는 웹 서버 모니터링 장치.
  2. 삭제
  3. ◈청구항 3은(는) 설정등록료 납부시 포기되었습니다.◈
    청구항 1에 있어서,
    상기 판단부는
    상기 인덱스 파일을 획득할 때 HTTP 메시지의 헤더를 기반으로 상태 코드(Status Code)를 획득하고, 상기 상태 코드가 적어도 하나 이상의 기설정된 정상 코드에 상응하지 않는 경우에 상기 웹 서버가 정상 동작하지 않는 것으로 판단하는 것을 특징으로 하는 웹 서버 모니터링 장치.
  4. ◈청구항 4은(는) 설정등록료 납부시 포기되었습니다.◈
    청구항 3에 있어서,
    상기 판단부는
    상기 인덱스 파일과 상기 원본 인덱스 파일을 비교하기 전에, 상기 상태 코드를 이용하여 상기 웹 서버의 정상 동작 여부를 판단하는 것을 특징으로 하는 웹 서버 모니터링 장치.
  5. 삭제
  6. 삭제
  7. 삭제
  8. 삭제
  9. 삭제
  10. 웹 서버에 상응하는 인덱스 파일을 획득하는 단계;
    상기 웹 서버에서 제공되는 메뉴 정보를 기반으로 적어도 둘 이상의 연속적 서브 타이틀 화면을 획득하는 단계;
    상기 인덱스 파일을 상기 웹 서버가 정상 동작할 때 획득한 원본 인덱스 파일과 비교하고, 상기 인덱스 파일과 상기 원본 인덱스 파일이 일치하지 않는 경우에 상기 웹 서버가 정상 동작하지 않는 것으로 판단하는 단계; 및
    상기 웹 서버가 정상 동작하지 않는 경우에 에러 로그를 생성하고, 클라우드 스트리밍 서비스 시스템에 상기 에러 로그를 기록하는 단계;를 포함하되,
    상기 판단하는 단계는
    상기 적어도 둘 이상의 연속적 서브 타이틀 화면과, 상기 서브 타이틀 화면과 상응하는 적어도 둘 이상의 비교화면에 대한 일치 여부를 확인하는 단계; 및
    상기 확인된 결과가 일치하지 않으면 상기 웹 서버가 정상 동작하지 않는 것으로 판단하는 단계;
    를 더 포함하는 것을 특징으로 하는 웹 서버 모니터링 방법.
KR1020150057982A 2015-04-24 2015-04-24 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치 KR102275179B1 (ko)

Priority Applications (2)

Application Number Priority Date Filing Date Title
KR1020150057982A KR102275179B1 (ko) 2015-04-24 2015-04-24 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치
KR1020210087380A KR102336604B1 (ko) 2015-04-24 2021-07-02 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020150057982A KR102275179B1 (ko) 2015-04-24 2015-04-24 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치

Related Child Applications (1)

Application Number Title Priority Date Filing Date
KR1020210087380A Division KR102336604B1 (ko) 2015-04-24 2021-07-02 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치

Publications (2)

Publication Number Publication Date
KR20160126655A KR20160126655A (ko) 2016-11-02
KR102275179B1 true KR102275179B1 (ko) 2021-07-08

Family

ID=57518159

Family Applications (2)

Application Number Title Priority Date Filing Date
KR1020150057982A KR102275179B1 (ko) 2015-04-24 2015-04-24 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치
KR1020210087380A KR102336604B1 (ko) 2015-04-24 2021-07-02 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치

Family Applications After (1)

Application Number Title Priority Date Filing Date
KR1020210087380A KR102336604B1 (ko) 2015-04-24 2021-07-02 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치

Country Status (1)

Country Link
KR (2) KR102275179B1 (ko)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102368147B1 (ko) 2021-10-19 2022-02-25 강동원 서버 모니터링 시스템 및 그 구동 방법
KR102399305B1 (ko) 2022-03-02 2022-05-17 최주림 서버 모니터링 시스템 구동 방법

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107370806B (zh) * 2017-07-12 2020-11-24 北京京东尚科信息技术有限公司 Http状态码监控方法、装置、存储介质和电子设备
KR102027823B1 (ko) 2019-04-24 2019-10-02 주식회사 리앙커뮤니케이션즈 플러그 인 방식의 시스템 응답 성능향상 지능형 캐싱 시스템
KR102576226B1 (ko) 2023-02-28 2023-09-06 오병율 인공지능 알고리즘을 통해 서버 과부하 예측 및 해소가 가능한 캐싱 시스템

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100894331B1 (ko) * 2006-11-15 2009-04-24 한국전자통신연구원 웹 로그 상호연관분석을 이용한 웹 애플리케이션 공격의침입 탐지 시스템 및 방법
KR101414994B1 (ko) 2012-11-12 2014-07-04 (주)이공감 관제 대상 서버의 자원 및 웹서비스 모니터링 서버 및 그 방법

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH10293707A (ja) * 1997-04-18 1998-11-04 Hitachi Ltd 大容量読み出し専用記憶媒体を利用した更新データの活用方法
KR101147251B1 (ko) * 2010-07-13 2012-05-18 (주)트리니티소프트 웹 서버의 보안장치
KR101408037B1 (ko) 2012-01-13 2014-06-17 주식회사 케이티 클라우드 시스템에서의 가상 머신 통합 모니터링 장치 및 방법

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100894331B1 (ko) * 2006-11-15 2009-04-24 한국전자통신연구원 웹 로그 상호연관분석을 이용한 웹 애플리케이션 공격의침입 탐지 시스템 및 방법
KR101414994B1 (ko) 2012-11-12 2014-07-04 (주)이공감 관제 대상 서버의 자원 및 웹서비스 모니터링 서버 및 그 방법

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102368147B1 (ko) 2021-10-19 2022-02-25 강동원 서버 모니터링 시스템 및 그 구동 방법
KR102399305B1 (ko) 2022-03-02 2022-05-17 최주림 서버 모니터링 시스템 구동 방법

Also Published As

Publication number Publication date
KR20210084417A (ko) 2021-07-07
KR102336604B1 (ko) 2021-12-06
KR20160126655A (ko) 2016-11-02

Similar Documents

Publication Publication Date Title
KR102336604B1 (ko) 클라우드 스트리밍 서비스 기반의 웹 서버 모니터링 방법 및 이를 위한 장치
US11770429B2 (en) System and method for streaming content from multiple servers
US9374403B2 (en) Media stream fragment request
US9235451B2 (en) Browser kernel switching method
US9342620B2 (en) Loading of web resources
US9247290B2 (en) Seamless transition between display applications using direct device selection
US20130007860A1 (en) Streaming video to cellular phones
CN112312222A (zh) 视频发送方法、装置和电子设备
US8667080B2 (en) Computer-implemented method, a computer program product and an embedded system for increasing the speed of data retrieval by a client on the embedded system
KR102426670B1 (ko) 클라우드 스트리밍 서비스 시스템, 프로세스 단축을 이용한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치
US9043441B1 (en) Methods and systems for providing network content for devices with displays having limited viewing area
KR102442699B1 (ko) 클라우드 스트리밍 서비스 시스템, 공통 캐시를 이용한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치
KR101888846B1 (ko) 클라우드 스트리밍 서비스 시스템, 리시프로컬 캐시를 이용한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치
KR101543295B1 (ko) 클라우드 스트리밍 서비스를 위한 어플리케이션 에러 검출 방법, 이를 위한 장치 및 시스템
US9058405B2 (en) Playback apparatus and playback method
JP6772389B2 (ja) リダイレクトの削減
KR20120082300A (ko) 콘텐츠 제공 장치 및 방법
CN110008423B (zh) 动态网页页面的离线处理方法、输出终端及存储介质
KR101703963B1 (ko) 캐시 서버를 이용한 멀티미디어 서비스를 제공하는 방법 및 시스템
KR102313530B1 (ko) 클라우드 스트리밍 서비스 시스템, 화면 분할을 이용한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치
KR102272358B1 (ko) 클라우드 스트리밍 서비스 시스템, 브라우저의 점유관리를 통한 이미지 클라우드 스트리밍 서비스 방법 및 이를 위한 장치
KR102199276B1 (ko) 클라우드 스트리밍 서비스 시스템, 클라우드 스트리밍 서비스 유형에 따른 서비스 처리 방법 및 이를 위한 장치
CN116708588A (zh) 文件压缩下载方法、装置、设备、介质及程序产品

Legal Events

Date Code Title Description
N231 Notification of change of applicant
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
A107 Divisional application of patent