KR20130047438A - 모니터링 및 미터링 장치 및 방법 - Google Patents

모니터링 및 미터링 장치 및 방법 Download PDF

Info

Publication number
KR20130047438A
KR20130047438A KR1020110112467A KR20110112467A KR20130047438A KR 20130047438 A KR20130047438 A KR 20130047438A KR 1020110112467 A KR1020110112467 A KR 1020110112467A KR 20110112467 A KR20110112467 A KR 20110112467A KR 20130047438 A KR20130047438 A KR 20130047438A
Authority
KR
South Korea
Prior art keywords
monitoring
information
data
metering data
metering
Prior art date
Application number
KR1020110112467A
Other languages
English (en)
Other versions
KR101296413B1 (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 KR1020110112467A priority Critical patent/KR101296413B1/ko
Publication of KR20130047438A publication Critical patent/KR20130047438A/ko
Application granted granted Critical
Publication of KR101296413B1 publication Critical patent/KR101296413B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • G06F17/40Data acquisition and logging
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Abstract

모니터링 및 미터링 장치 및 방법이 제공된다. 모니터링 및 미터링 장치의 수집부는 멀티 테넌시 환경에서 발생되는 모니터링 및 미터링 데이터를 수집하고, 제1저장부는 수집된 모니터링 및 미터링 데이터를 설명하는 적어도 하나의 속성정보를 대표하는 제1메타정보 ID와, 수집된 모니터링/미터링 데이터를 매핑하여 저장한다.

Description

모니터링 및 미터링 장치 및 방법{Apparatus and Method for Monitoring and Metering}
본 발명은 모니터링 및 미터링 장치 및 방법에 관한 것이다.
하드웨어, 운영체제, 미들웨어, 어플리케이션 등과 같은 소프트웨어를 서비스 제공자의 데이터센터에 설치하고, 인터넷을 통해 데이터센터에 서비스의 형태(As a Service)로 접속하여 각종 소프트웨어를 임대 형태로 사용하는 Cloud Computing이 각광받고 있다. Cloud Computing의 가장 큰 장점은 비용 절감이며, 이러한 비용 절감을 위하여 여러 테넌트들은 하나의 통합된 IT 자원을 공유하는 Multi-tenancy 환경을 배경으로 작동한다. 이로써, 개별 테넌트가 부담하는 IT 자원 사용 비용이 줄어들게 된다.
그러나, 여러 테넌트들이 IT 자원을 공유하게 되면, Multi-SaaS 플랫폼은 특정 테넌트의 서비스 상태나 사용량을 분리하여 확인할 수 있으나, Multi-SaaS 플랫폼 외의 장치(예를 들어, 서비스 제공자)는 이를 분리하여 확인하기 어렵다. 특히, 멀티 테넌시를 지원하지 않는 어플리케이션에서 테넌트 별로 모니터링 및 미터링 데이터를 저장 및 조회하기 위해서는 기존 어플리케이션을 변경해야 한다.
본 발명적 개념의 예시적 실시예에 따르면, 다수의 테넌트가 각종 IT 자원을 공유하는 멀티 테넌시 환경에서 수집되는 모니터링 및 미터링 정보를 테넌트 별로 분류하여 저장하고 조회할 수 있는 모니터링 및 미터링 장치 및 방법을 제공된다.
본 발명적 개념의 다른 예시적 실시 예에 따르면, 멀티 테넌시 환경에서 발생되는 모니터링 및 미터링 데이터를 수집하는 수집부; 및 상기 수집된 모니터링 및 미터링 데이터의 속성을 설명하는 제1설명정보를 대표하는 제1메타정보 ID와, 상기 수집된 모니터링/미터링 데이터를 매핑하여 저장하는 제1저장부;를 포함하는 모니터링 및 미터링 장치가 제공될 수 있다.
서로 다른 속성정보들로 이루어진 복수 개의 설명정보들과, 상기 복수 개의 설명정보들에 할당되는 복수 개의 메타정보 ID들을 서로 매핑하여 저장하는 제2저장부; 및 적어도 하나의 속성정보로 이루어진 제1설명정보를 대표하는 제1메타정보 ID가 상기 제2저장부에 저장되어 있는지를 확인하고, 저장되어 있는 경우, 상기 제2저장부에 저장된 제1메타정보 ID와 상기 수집된 모니터링 및 미터링 데이터를 매핑하여 상기 제1저장부에 저장하는 컨트롤러;를 더 포함할 수 있다.
상기 컨트롤러는, 상기 제2저장부에 상기 제1메타정보 ID가 저장되어 있지 않은 것으로 확인되면, 상기 수집된 모니터링 및 미터링 데이터에 상기 제1메타정보 ID를 새로 부여하고, 상기 새로 부여된 제1메타정보 ID와 상기 수집된 모니터링 및 미터링 데이터를 매핑하여 상기 제1저장부에 저장할 수 있다.
복수의 사용자들의 ID와 상기 복수의 사용자들이 속한 테넌트들의 ID를 서로 매핑하여 저장하는 제3저장부; 및 상기 수집부가 제1사용자의 ID가 속한 제1테넌트의 ID를 요청하는 경우, 상기 제1사용자의 ID에 매핑되어 저장된 제1테넌트의 ID를 상기 제3저장부로부터 확인하여 상기 수집부에게 제공하는 컨트롤러;를 더 포함하며, 상기 제1사용자의 ID는 상기 모니터링 및 미터링 데이터와 관련된 서비스를 사용한 사용자의 ID로서 상기 수집부에 의해 상기 모니터링 및 미터링 데이터로부터 추출된 것일 수 있다.
상기 수집부는 상기 수집부의 초기 구동을 위한 에이전트 실행 시 세션 내 속성값, 브라우저의 쿠키값 및 요청 파라미터의 값 각각으로부터 사용자의 ID를 나타내는 값을 미리 확인 및 로딩하여 메모리에 저장하고, 상기 미리 확인된 값을 이용하여 상기 수집된 모니터링 및 미터링 데이터로부터 상기 제1사용자의 ID를 추출할 수 있다.
상기 수집부는 상기 수집부의 초기 구동을 위한 에이전트 실행 시 로그데이터 저장부에 저장된 로그 DB 중 사용자의 ID를 나타내는 칼럼을 미리 확인 및 로딩하여 메모리에 저장하고, 상기 로그 DB로부터 상기 모니터링 및 미터링 데이터를 수집하고, 상기 미리 확인된 칼럼을 이용하여 상기 로그 DB로부터 상기 제1사용자의 ID를 추출할 수 있다.
상기 수집부는 상기 수집부의 초기 구동을 위한 에이전트 실행 시 로그데이터 저장부에 저장된 로그 파일 중 사용자의 ID를 나타내는 필드를 미리 확인 및 로딩하여 메모리에 저장하고, 상기 로그파일로부터 상기 모니터링 및 미터링 데이터를 수집하고, 상기 미리 확인된 필드를 이용하여 상기 로그 파일로부터 상기 제1사용자의 ID를 추출할 수 있다.
상기 모니터링 및 미터링 데이터의 제1설명정보는, 테넌트가 사용하는 서비스의 ID, 상기 서비스를 사용하는 테넌트의 ID, 상기 수집된 모니터링 및 미터링 데이터의 종류를 나타내는 데이터 타입, 상기 수집된 모니터링 및 미터링 데이터가 수행되고 있는 가상 머신의 ID 및 상기 모니터링 및 미터링 데이터를 생성한 소프트웨어 서버의 ID 중 적어도 하나를 포함하며, 상기 메타정보 ID는 상기 서비스의 ID, 테넌트의 ID, 데이터 타입, 가상 머신의 ID 및 소프트웨어 서버의 ID 중 적어도 하나를 대표하는 ID일 수 있다.
외부로부터 적어도 하나의 속성정보 및 모니터링 및 미터링 데이터의 조회를 요청하는 신호가 수신되면, 상기 수신된 적어도 하나의 속성정보에 매핑되어 저장된 모니터링 및 미터링 데이터를 상기 제1저장부로부터 조회하는 조회부;를 더 포함할 수 있다.
상기 조회부는 상기 외부로부터 수신되는 적어도 하나의 속성정보에 해당하는 상기 제1메타정보 ID를 상기 제2저장부로부터 확인하고, 상기 확인된 제1메타정보 ID를 이용하여 상기 제1저장부를 조회할 수 있다.
상기 모니터링 및 미터링 데이터가 상기 수집부에 의해 수집된 시각정보를 상기 제1메타정보 ID와 더 매핑하여 상기 제1저장부에 저장하는 컨트롤러;를 더 포함할 수 있다.
한편, 본 발명적 개념의 다른 예시적 실시 예에 따르면, 테넌트들이 사용한 서비스들의 모니터링 및 미터링 데이터, 상기 모니터링 및 미터링 데이터가 수집된 시각 및 상기 수집된 모니터링 및 미터링 데이터의 속성정보들을 통합하는 메타정보 ID를 저장하는 모니터링 및 미터링 데이터 저장부; 및 외부로부터 수신되는 상기 속성정보들 중 적어도 하나와 수집시각 범위를 고려하여, 상기 모니터링 및 미터링 데이터 저장부에 저장된 모니터링 및 미터링 데이터를 조회하는 조회부;를 포함하는 모니터링 및 미터링 장치가 제공될 수 있다.
복수 개의 메타정보 ID들에 매핑되는 속성정보들을 저장하는 메타정보 저장부;를 더 포함하며, 상기 조회부는 상기 외부로부터 수신된 상기 속성정보들 중 적어도 하나에 매핑되는 상기 메타정보 ID를 상기 메타정보 저장부로부터 확인하고, 상기 확인된 메타정보 ID와 상기 수집시각 범위를 이용하여 상기 모니터링 및 미터링 데이터 저장부를 조회할 수 있다.
한편, 본 발명적 개념의 다른 예시적 실시 예에 따르면, 멀티 테넌시 환경에서 발생되는 모니터링 및 미터링 데이터를 수집하는 단계; 및 상기 수집된 모니터링 및 미터링 데이터의 속성을 설명하는 제1설명정보를 대표하는 제1메타정보 ID와, 상기 수집된 모니터링/미터링 데이터를 매핑하여 저장하는 단계;를 포함하는 모니터링 및 미터링 방법이 제공될 수 있다.
서로 다른 속성정보들로 이루어진 복수 개의 설명정보들과, 상기 복수 개의 설명정보들에 할당되는 복수 개의 메타정보 ID들이 서로 매핑되어 저장되는 단계; 및 상기 제1설명정보를 대표하는 제1메타정보 ID가 상기 저장되는 단계에서 저장되었는지를 확인하는 단계;를 더 포함하며, 저장되어 있는 것으로 확인된 경우, 상기 제1메타정보 ID와, 상기 수집된 모니터링/미터링 데이터를 매핑하여 저장하는 단계는, 상기 확인된 제1메타정보 ID와 상기 수집된 모니터링 및 미터링 데이터를 매핑하여 저장할 수 있다.
상기 제1설명정보를 대표하는 제1메타정보 ID가 상기 저장되는 단계에서 저장되지 않은 것으로 확인되면, 상기 수집된 모니터링 및 미터링 데이터에 상기 제1메타정보 ID를 새로 부여하는 단계;를 더 포함하며, 상기 제1메타정보 ID와, 상기 수집된 모니터링/미터링 데이터를 매핑하여 저장하는 단계는, 상기 새로 부여된 제1메타정보 ID와 상기 수집된 모니터링 및 미터링 데이터를 매핑하여 저장할 수 있다.
상기 수집하는 단계에서 수집된 상기 모니터링 및 미터링 데이터로부터 상기 모니터링 및 미터링 데이터와 관련된 서비스를 사용한 제1사용자의 ID를 추출하는 단계; 및 상기 추출된 제1사용자의 ID가 속한 제1테넌트의 ID를 확인하는 단계;를 더 포함할 수 있다.
상기 모니터링 및 미터링 데이터의 수집을 위해 에이전트를 초기 실행하는 단계; 및 세션 내 속성값, 브라우저의 쿠키값 및 요청 파라미터의 값 각각으로부터 사용자의 ID를 나타내는 값을 미리 확인 및 로딩하여 저장하는 단계;를 더 포함하며, 상기 제1사용자의 ID를 추출하는 단계는, 상기 미리 확인된 값을 이용하여 상기 수집된 모니터링 및 미터링 데이터로부터 상기 제1사용자의 ID를 추출할 수 있다.
상기 모니터링 및 미터링 데이터의 수집을 위해 에이전트를 초기 실행하는 단계; 및 상기 멀티 테넌시 환경에서 발생하는 로그 DB 중 사용자의 ID를 나타내는 칼럼을 미리 확인 및 로딩하여 저장하는 단계;를 더 포함하며, 상기 제1사용자의 ID를 추출하는 단계는, 상기 미리 확인된 칼럼을 이용하여 상기 로그 DB로부터 상기 제1사용자의 ID를 추출할 수 있다.
상기 모니터링 및 미터링 데이터의 수집을 위해 에이전트를 초기 실행하는 단계; 및 상기 멀티 테넌시 환경에서 발생하는 로그 파일 중 사용자의 ID를 나타내는 필드를 미리 확인 및 로딩하여 저장하는 단계;를 더 포함하며, 상기 제1사용자의 ID를 추출하는 단계는, 상기 미리 확인된 필드를 이용하여 상기 로그 파일로부터 상기 제1사용자의 ID를 추출할 수 있다.
외부로부터 적어도 하나의 속성정보 및 모니터링 및 미터링 데이터의 조회를 요청하는 신호가 수신되면, 상기 외부로부터 수신되는 적어도 하나의 속성정보에 해당하는 상기 제1메타정보 ID를 확인하는 단계; 및 상기 수신된 적어도 하나의 속성정보와 상기 확인된 제1메타정보 ID에 매핑되어 저장된 모니터링 및 미터링 데이터를 조회하는 단계;를 더 포함할 수 있다.
본 발명적 개념의 하나 이상의 예시적 실시 예에 따르면, 멀티 테넌트가 다양한 IT 자원을 공유하는 멀티 테넌시 환경에서, 모니터링 및 미터링 데이터를 어플리케이션의 변경 없이 수집하고, 또한, 어플리케이션의 변경 없이 테넌트 별로 분류, 저장 및 조회할 수 있다. 따라서, 기존의 어플리케이션을 이용하여 모니터링 및 미터링 서비스를 제공함으로써, 기존의 어플리케이션을 클라우드 컴퓨팅 서비스 형태로 전환하는 데 필요한 시간, 인력 및 비용을 최소화하면서 모니터링 및 미터링 서비스를 제공할 수 있다.
도 1은 본 발명적 개념의 예시적 제1실시 예에 따른 모니터링 및 미터링 장치를 포함하는 모니터링 및 미터링 시스템을 도시한 도면,
도 2는 본 발명적 개념의 예시적 제2실시 예에 따른 모니터링 및 미터링 장치를 포함하는 모니터링 및 미터링 시스템을 도시한 도면,
도 3은 본 발명적 개념의 예시적 제1실시 예에 따른 모니터링 및 미터링 방법을 설명하기 위한 흐름도,
도 4는 본 발명적 개념의 예시적 실시 예에 따른 모니터링 및 미터링 방법 중 조회 방법을 설명하기 위한 흐름도, 그리고,
도 5는 본 발명적 개념의 예시적 제2실시 예에 따른 모니터링 및 미터링 방법을 설명하기 위한 흐름도이다.
이상의 본 발명의 목적들, 다른 목적들, 특징들 및 이점들은 첨부된 도면과 관련된 이하의 바람직한 실시예들을 통해서 쉽게 이해될 것이다. 그러나 본 발명은 여기서 설명되는 실시예들에 한정되지 않고 다른 형태로 구체화될 수도 있다. 오히려, 여기서 소개되는 실시예들은 개시된 내용이 철저하고 완전해질 수 있도록 그리고 당업자에게 본 발명의 사상이 충분히 전달될 수 있도록 하기 위해 제공되는 것이다.
본 명세서에서, 어떤 구성요소가 다른 구성요소 상에 있다고 언급되는 경우에 그것은 다른 구성요소 상에 직접 형성될 수 있거나 또는 그들 사이에 제 3의 구성요소가 개재될 수도 있다는 것을 의미한다.
본 명세서에서 제1, 제2 등의 용어가 구성요소들을 기술하기 위해서 사용된 경우, 이들 구성요소들이 이 같은 용어들에 의해서 한정되어서는 안 된다. 이들 용어들은 단지 어느 구성요소를 다른 구성요소와 구별시키기 위해서 사용되었을 뿐이다. 여기에 설명되고 예시되는 실시예들은 그것의 상보적인 실시예들도 포함한다.
또한, 제1 엘리먼트 (또는 구성요소)가 제2 엘리먼트(또는 구성요소) 상(ON)에서 동작 또는 실행된다고 언급될 때, 제1 엘리먼트(또는 구성요소)는 제2 엘리먼트(또는 구성요소)가 동작 또는 실행되는 환경에서 동작 또는 실행되거나 또는 제2 엘리먼트(또는 구성요소)와 직접 또는 간접적으로 상호 작용을 통해서 동작 또는 실행되는 것으로 이해되어야 할 것이다.
어떤 엘리먼트, 구성요소, 장치, 또는 시스템이 프로그램 또는 소프트웨어로 이루어진 구성요소를 포함한다고 언급되는 경우, 명시적인 언급이 없더라도, 그 엘리먼트, 구성요소, 장치, 또는 시스템은 그 프로그램 또는 소프트웨어가 실행 또는 동작하는데 필요한 하드웨어(예를 들면, 메모리, CPU 등)나 다른 프로그램 또는 소프트웨어(예를 들면 운영체제나 하드웨어를 구동하는데 필요한 드라이버 등)를 포함하는 것으로 이해되어야 할 것이다.
또한 어떤 엘리먼트(또는 구성요소)가 구현됨에 있어서 특별한 언급이 없다면, 그 엘리먼트(또는 구성요소)는 소프트웨어, 하드웨어, 또는 소프트웨어 및 하드웨어 어떤 형태로도 구현될 수 있는 것으로 이해되어야 할 것이다.
본 명세서에서 사용된 용어는 실시예들을 설명하기 위한 것이며 본 발명을 제한하고자 하는 것은 아니다. 본 명세서에서, 단수형은 문구에서 특별히 언급하지 않는 한 복수형도 포함한다. 명세서에서 사용되는 '포함한다(comprises)' 및/또는 '포함하는(comprising)'은 언급된 구성요소는 하나 이상의 다른 구성요소의 존재 또는 추가를 배제하지 않는다.
이하, 도면을 참조하여 본 발명적 개념을 상세히 설명하도록 한다. 아래의 특정 실시예들을 기술하는데 있어서, 여러 가지의 특정적인 내용들은 발명적 개념을 더 구체적으로 설명하고 이해를 돕기 위해 작성되었다. 하지만 본 발명적 개념을 이해할 수 있을 정도로 이 분야의 지식을 갖고 있는 독자는 이러한 여러 가지의 특정적인 내용들이 없어도 사용될 수 있다는 것을 인지할 수 있다. 어떤 경우에는, 발명적 개념을 기술하는 데 있어서 흔히 알려졌으면서 발명과 크게 관련 없는 부분들은 본 발명적 개념을 설명하는 데 있어 별 이유 없이 혼돈이 오는 것을 막기 위해 기술하지 않음을 미리 언급해 둔다.
도 1은 본 발명적 개념의 예시적 제1실시 예에 따른 모니터링 및 미터링 장치(100)를 포함하는 모니터링 및 미터링 시스템을 도시한 도면이다.
도 1에 예시적으로 도시된 모니터링 및 미터링 시스템은 WAS(Web Application Server)(10), 로그데이터 저장부(20), 조회 요청부(30) 및 모니터링 및 미터링 장치(100)를 포함할 수 있다.
본 실시예에서 WAS(10)와 로그데이터 저장부(20)는 멀티 테넌트에게 서비스가 제공됨에 따라서 기록되는 모니터링 및 미터링 데이터를 가지고 있거나, 또는 모니터링 및 미터링 데이터를 수집할 수 있는 대상이 될 수 있다.
WAS(10)는 멀티 테넌시 환경에서 제공되는 서비스와 관련된 웹 어플리케이션이 구동되는 서버이다. WAS(10)는 웹 어플리케이션 구동 시 요청 건수, 요청에 대한 응답 시간, 요청에 대한 수행 내용, 어플리케이션이 데이터베이스에 질의한 내용 및 질의에 수행된 시간 등을 수집할 수 있다. '요청 건수'는 WAS(10)에서 제공하는 서비스의 실제 사용자(즉, 테넌트에 속하는 구성원)가 3RD party 서비스를 사용하는 과정에서 WAS(10)에게 보낸 서비스의 사용 요청 회수이다.
일반적으로 WAS는 웹 서버와 기업의 기간 시스템 사이에 위치하면서, 웹 기반 분산 시스템 개발을 돕고, 안정적인 트랜잭션 처리를 보장하는 일종의 미들웨어 소프트웨어 서버이다. 즉, WAS는 3계층 웹 컴퓨팅 환경에서 기존 클라이언트와 서버 환경의 어플리케이션 서버와 유사한 역할을 하며, 클라이언트와 서버 환경에서 트랜잭션 처리 및 관리와 다른 기존 시스템 간의 어플리케이션 연동 등을 주된 기능으로 제공하고 있다.
로그데이터 저장부(20)는 어플리케이션을 테넌트의 사용자들이 사용함에 따라 기록된 로그 데이터를 저장할 수 있다. 로그데이터 저장부(20)는 로그 데이터를 로그 DB(Database) 형태로 수집하여 저장하거나 로그 파일 형태로 수집하여 저장할 수 있다.
조회 요청부(30)는 모니터링 및 미터링 장치(100)에서 수집된 모니터링 및 미터링 데이터의 조회를 모니터링 및 미터링 장치(100)에게 요청할 수 있다. 조회 요청부(30)의 자세한 동작은 후술한다.
본 발명적 개념의 예시적 실시예에 따르면, 모니터링 및 미터링 장치(100)는 테넌트 ID(Identification) 저장부(110), 메타정보 저장부(120), 모니터링 및 미터링(M/M: Monitoring and Metering) 데이터 저장부(130), 메모리(140), 수집부(150), 컨트롤러(160), 및 조회부(170)를 포함할 수 있다.
테넌트 ID 저장부(110)는 멀티 테넌시 환경에서 SaaS 플랫폼의 서비스를 사용하는 모든 사용자들의 ID와, 사용자들이 속한 테넌트들의 ID를 서로 매핑하여 저장할 수 있다. [표 1]은 테넌트 ID 저장부(110)에 저장된 테이블의 일 예를 보여준다.
사용자의 ID(UID) 테넌트의 ID(TID)
1 제1UID 제1TID
2 제2UID 제2TID
3 제3UID 제3TID
4 제4UID 제4TID
n 제nUID 제nTID
멀티 테넌시 환경에서 테넌트가 추가 또는 삭제되거나, 각 테넌트의 구성원들이 추가 또는 삭제되면, 테넌트 ID 저장부(110)도 업데이트될 수 있다.
메타정보 저장부(120)는 서로 다른 속성정보들로 이루어진 복수 개의 설명정보들과, 복수 개의 설명정보들에 할당되는 복수 개의 메타정보 ID들을 서로 매핑하여 저장할 수 있다. 속성정보, 설명정보 및 메타정보 ID에 대한 자세한 설명은 제1수집부(151)를 참조하여 후술한다. [표 2]는 메타정보 저장부(120)에 저장된 테이블의 일 예를 보여준다.
설명정보 메타정보 ID(MID)
1 제1설명정보([제1서비스 ID, 제1TID, 제1데이터 타입, 제1머신 ID, 제1SW 서버 ID]) 제1MID
2 제2설명정보([제2서비스 ID, 제1TID, 제2데이터 타입, 제2머신 ID, 제2SW 서버 ID]) 제2MID
3 제3설명정보([제3서비스 ID, 제3TID, 제3데이터 타입, 제3머신 ID, 제3SW 서버 ID]) 제3MID
n 제n설명정보([제n서비스 ID, 제nTID, 제n데이터 타입, 제n머신 ID, 제nSW 서버 ID]) 제nMID
[표 2]를 참조하면, 제1설명정보를 이루는 속성정보들은 제1서비스 ID, 제1TID, 제1데이터 타입, 제1머신 ID 및 제1SW 서버 ID를 포함하며, 제1설명정보는 제1메타정보 ID(제1MID)에 매핑되어 있다. 또한, 제1설명정보와 제2설명정보의 속성정보들 중 테넌트의 ID는 제1TID로서 동일하며, 그 외의 속성정보들은 서로 다름을 알 수 있다. 이는, 복수 개의 설명정보들을 이루는 속성정보들은 일부는 동일할 수도 있음을 의미한다. 멀티 테넌시 환경에서 서비스 제공자 또는 테넌트와 같은 구성요소들이 추가 또는 삭제되면, 메타정보 저장부(120)도 업데이트될 수 있다.
M/M 데이터 저장부(130)는 후술할 수집부(150)에 의해 수집된 M/M 데이터와, M/M 데이터를 설명하는 적어도 하나의 속성정보(즉, 설명정보)를 대표하는 메타정보 ID를 매핑하여 저장할 수 있다. [표 3]은 M/M 데이터 저장부(130)에 저장된 테이블의 일 예를 보여준다.
메타정보 ID(MID) 수집시각 M/M 데이터(수집데이터)
1 제1MID AM 10:00~AM 10:15 제1M/M 데이터
2 제2MID PM 2:20~PM 2:50 제2M/M 데이터
3 제3MID PM 3:10~PM 3:30 제3M/M 데이터
[표 3]을 참조하면, M/M 데이터 저장부(130)에는 [MID, 수집시각, M/M 데이터] 형태로 M/M 데이터가 저장 및 관리되는 것을 알 수 있다. 수집시각은 M/M 데이터가 수집부(150)에 의해 수집된 시각을 나타낸다.
메모리(140)는 수집부(150)에 포함되어 있을 수 있으며, 수집부(150)와 연동할 수 있다. 메모리(140)는 제1수집부(151) 및 제2수집부(153)에서 초기 로딩된 복수 개의 설명정보들, 사용자의 ID를 나타내는 값 또는 칼럼 또는 필드를 저장할 수 있다.
또한, 메모리(140)는 [표 4]와 같이 사용자의 ID와 사용자가 속한 테넌트의 ID를 서로 매핑하여 저장할 수 있다.
사용자의 ID(UID) 테넌트의 ID(TID)
1 제1UID 제1TID
2 제2UID 제2TID
3 제5UID 제5TID
또한, 메모리(140)는 [표 5]와 같이 복수 개의 설명정보들을 대표하는 메타정보 ID들을 서로 매핑하여 저장할 수 있다.
설명정보 메타정보 ID(MID)
1 제1설명정보([제1서비스 ID, 제1TID, 제1데이터 타입, 제1머신 ID, 제1SW 서버 ID]) 제1MID
2 제2설명정보([제2서비스 ID, 제1TID, 제2데이터 타입, 제2머신 ID, 제2SW 서버 ID]) 제2MID
3 제5설명정보([제5서비스 ID, 제5TID, 제5데이터 타입, 제5머신 ID, 제5SW 서버 ID]) 제5MID
[표 5]를 참조하면, 메모리(140)에는 제3설명정보와 제4설명정보에 할당된 메타정보 ID가 저장되어 있지 않음을 알 수 있다.
수집부(150)는 멀티 테넌시 환경에서 발생되는 모니터링 및 미터링 데이터를 수집할 수 있다. 수집부(150)는 WAS(10) 또는 로그데이터 저장부(20)로부터 모니터링 및 미터링 데이터를 수집할 수 있다. 이를 위해, 수집부(150)는 제1수집부(151) 및 제2수집부(153)를 포함할 수 있다. 제1수집부(151)와 제2수집부(153)에서 수집된 제1M/M 데이터와 제2M/M 데이터는 하드웨어에 대한 모니터링과 WAS(10)와 같은 기업용 미들웨어에 대하여 가용성, 응답시간, 지연시간 및 처리량 등의 모니터링 결과를 파악하고, 특정 가상 머신에 할당된 CPU, 메모리 사용량, 네트워크 트래픽량 등의 미터링 결과를 파악하는데 사용될 수 있다.
한편, 모니터링 및 미터링 장치(100)는 M/M 데이터를 수집하기 위해, 에이전트의 초기 구동 동작, 데이터 수집 및 저장 동작, 그리고, 데이터 조회 동작을 수행할 수 있다. 이하에서는 초기 구동 동작, 데이터 수집 및 저장 동작, 그리고, 데이터 조회 동작을 구분하여 설명한다.
1. 초기 구동 동작
제1수집부(151)는 WAS 에이전트의 실행에 의해 동작하며, 제1M/M 데이터를 수집하기 이전에, 제1수집부(151)는 WAS 에이전트의 초기 실행 시 초기 로드 동작을 수행할 수 있다. 제1수집부(151)는 WAS 에이전트의 실행에 의해 동작하거나, 다르게는(alternatively) WAS 에이전트가 제1수집부(151)에 통합되어 초기 로드 동작이 수행될 수 있다. 여기서, WAS 에이전트가 제1수집부(151)와 별도로 구현되는 경우, WAS 에이전트는 모니터링 및 미터링 장치가 구비하는 저장부(미도시)에 실행 가능한 형태로 저장되어 있다가 메모리(140) 또는 별도로 마련된 메모리(미도시)에 로딩되어 실행될 수 있다.
본 발명적 개념의 예시적 실시예에 따르면, 제1수집부(151)는 서비스 ID, 가상머신 ID, SW 서버 ID, 데이터 타입 등의 속성정보들로 이루어진 복수 개의 설명정보들을 WAS 에이전트의 설정 파일로부터 로드하거나, 실행 변수(실행 파라미터)로 지정하여 메모리(140)에 저장할 수 있다.
로딩되는 하나의 설명정보는 M/M 데이터를 설명하는 속성정보들로 이루어지며, 속성정보들은 서비스 ID, 가상머신 ID, 데이터 타입 및 SW 서버 ID 중 적어도 하나를 포함할 수 있다. 즉, 하나의 설명정보는 ‘서비스 ID, 가상머신 ID, SW 서버 ID, 데이터 타입’ 중 적어도 하나로 이루어진 하나의 세트일 수 있으며, 제1수집부(151)는 사전에 알고 있는 복수 개의 설명정보들을 로딩할 수 있다. 이때, 복수 개의 설명정보들을 이루는 속성정보들은 일부가 동일하거나 서로 다를 수 있다.
M/M 데이터의 설명정보를 이루는 속성정보에 대해 설명하면, 서비스 ID는 테넌트가 사용한 서비스의 ID, 가상머신 ID는 M/M 데이터가 수행되고 있는 가상 머신의 ID, 데이터 타입은 수집된 M/M 데이터의 종류, SW 서버 ID는 M/M 데이터를 생성한 소프트웨어 서버의 ID를 의미한다. 이하에서는, 설명의 목적을 위해서, 용어 "설명정보"는 "적어도 하나의 속성정보" 또는 “서비스 ID, 가상머신 ID, 데이터 타입 및 SW 서버 ID”를 의미하며, 혼용될 수 있다.
제1수집부(151)는 제1수집부(151)의 초기 구동을 위한 WAS 에이전트 실행 시, 세션 내 속성값, 브라우저의 쿠키값 및 요청 파라미터의 값 각각으로부터 사용자의 ID를 나타내는 값을 미리 확인 및 로딩하여 메모리(140)에 저장할 수 있다. 제1수집부(151)는 메모리(140)에 로딩된 값을 이용하여 수집된 제1M/M 데이터로부터 제1사용자의 ID를 추출할 수 있다. ‘제1사용자’는 제1M/M 데이터와 관련된 서비스를 사용한 사용자이다.
제2수집부(153)는 로그 데이터로부터 제2M/M 데이터를 수집하기 위한 어플리케이션 에이전트의 실행에 의해 동작하며, 제2M/M 데이터를 수집하기 이전에, 어플리케이션 에이전트의 초기 실행 시 초기 로드 동작을 수행할 수 있다. 제2수집부(153)를 실행시키는 에이전트는, 제2수집부(153)와 통합되어 구현되거나, 또는 별도로 구현될 수 있으며, 모니터링 및 미터링 장치가 구비하는 저장부(미도시)에 실행가능한 형태로 저장되어 있다가 메모리(140) 또는 별도로 마련되는 메모리(미도시)에 로딩되어 실행될 수 있다. 한편, 제1수집부(151)를 실행시키는 에이전트와 제2수집부(153)를 실행시키는 에이전트는 하나의 에이전트로 통합되어 구현되거나 또는 각각 별도로 구현될 수도 있다.
제2수집부(153)는 서비스 ID, 가상머신 ID, SW 서버 ID, 데이터 타입 등의 속성정보들로 이루어진 복수 개의 설명정보들을 WAS 에이전트의 설정 파일로부터 로드하거나 실행 파라미터로 지정하여 메모리(140)에 저장할 수 있다. 복수 개의 설명정보들과 속성정보들은 제1수집부(151)에서 자세히 설명하였으므로 생략한다.
제2수집부(153)는 제2수집부(153)의 초기 구동을 위한 에이전트 실행 시 로그데이터 저장부(20)에 로그데이터가 로그 DB 형태로 저장된 경우를 고려하여, 로그 DB 중 사용자의 ID를 나타내는 칼럼을 미리 확인 및 로딩하여 메모리(140)에 저장할 수 있다. 제2수집부(153)는 로그데이터로부터 제2M/M 데이터를 수집하고, 메모리(140)에 로딩된 사용자의 ID를 나타내는 칼럼을 이용하여 로그 DB로부터 제1사용자의 ID를 추출할 수 있다.
또한, 제2수집부(153)는 제2수집부(153)의 초기 구동을 위한 에이전트 실행 시 로그데이터 저장부(20)에 로그데이터가 로그 파일로 저장된 경우를 고려하여, 로그 파일 중 사용자의 ID를 나타내는 필드를 미리 확인 및 로딩하여 메모리(140)에 저장할 수 있다. 즉, 제2수집부(153)는 로그 파일을 처리하기 위한 변환 규칙을 미리 정하고, 변환 규칙으로 처리된 결과 중 어느 필드가 사용자의 ID를 나타내는지를 미리 확인 및 로딩할 수 있다. 제2수집부(153)는 로그데이터로부터 제2M/M 데이터를 수집하고, 미리 확인된 필드를 이용하여 로그 파일로부터 제1사용자의 ID를 추출할 수 있다. 물론, 제2M/M 데이터를 사용한 사용자가 제2사용자인 경우 제2수집부(153)는 제2사용자의 ID를 추출하나, 본 실시 예에서는 제1M/M 데이터와 제2M/M데이터를 사용한 사용자가 동일한 제1사용자인 경우를 예로 들어 설명한다.
2. 데이터 수집 및 저장 동작
초기 로드 동작이 완료되면, 제1수집부(151)는 WAS(10)를 대상으로 제1M/M 데이터를 수집할 수 있다. 제1M/M 데이터는 요청 건수, 요청에 대한 응답 시간, 요청에 대한 수행 내용, 테넌트에게 서비스로서 제공된 어플리케이션이 데이터베이스에 질의한 내용 및 질의에 수행된 시간을 포함할 수 있다. 제1수집부(151)가 WAS(10)를 대상으로 제1M/M 데이터를 수집하는 동안, WAS(10)는 제1M/M 데이터를 설명하는 적어도 하나의 속성정보(즉, 제1속성정보)를 제1M/M 데이터와 함께 제1수집부(151)에게 제공하거나, 별도로 알려줄 수 있다.
제1수집부(151)는 수집된 제1M/M 데이터로부터 제1사용자의 ID(제1UID)를 추출할 수 있다. 자세히 설명하면, 제1수집부(151)는 메모리(140)에 미리 로딩되어 저장된 세션 내 속성값, 브라우저의 쿠키값 및 요청 파라미터의 값 중 적어도 하나로부터 사용자의 ID를 나타내는 값을 확인할 수 있다. 그리고, 제1수집부(151)는 수집된 제1M/M 데이터 중 확인된 값에 대응하는 ID를 제1사용자의 ID로서 추출할 수 있다.
또한, 초기 로드 동작이 완료되면, 제2수집부(153)는 로그데이터 저장부(20)에 저장된 다양한 소프트웨어의 로그 데이터로부터 제2M/M 데이터를 수집할 수 있다. 제2M/M 데이터는 로그 DB 또는 로그 파일 형태를 가지며, 제2수집부(153)는 수집된 제2M/M 데이터를 미리 정의된 형태로 가공할 수 있다. 제2수집부(153)가 로그데이터 저장부(20)를 대상으로 제2M/M 데이터를 수집하는 동안, 로그데이터 저장부(20)는 제2M/M 데이터를 설명하는 적어도 하나의 속성정보(즉, 제2속성정보)를 제2M/M 데이터와 함께 제2수집부(153)에게 제공하거나, 별도로 알려줄 수 있다.
제2수집부(153)는 수집된 제2M/M 데이터로부터 제1사용자의 ID를 추출할 수 있다. 자세히 설명하면, 제2수집부(153)는 메모리(140)에 미리 로딩되어 저장된 사용자의 ID를 나타내는 칼럼 또는 사용자의 ID를 나타내는 필드를 확인할 수 있다. 그리고, 제2수집부(153)는 수집된 제2M/M 데이터 중 확인된 칼럼 또는 필드에 대응하는 ID를 제1사용자의 ID로서 추출할 수 있다. 제2수집부(153)는 초기 로딩 과정 시, 로그 DB 조회 결과 중 어느 칼럼이 해당 로그를 발생시킨 사용자의 ID를 나타내는지를 미리 지정하였으므로, 해당하는 칼럼에서 사용자의 ID를 추출할 수 있다. 필드의 경우, 제2수집부(153)는 로그 파일의 변환 처리 결과 중 어느 부분이 해당 로그를 발생시킨 사용자의 ID를 나타내는지를 미리 지정하였으므로, 해당 필드로부터 사용자의 ID를 추출할 수 있다.
제1사용자의 ID가 추출되면, 모니터링 및 미터링 장치(100)는 제1수집부(151)와 제2수집부(153)에서 추출된 제1사용자의 ID에 대응하는 제1테넌트의 ID를 확인하고, 제1설명정보, 제1메타정보 ID 및 제1M/M 데이터와 제2M/M 데이터를 저장할 수 있다.
이러한 동작 수행 중, 제1수집부(151)와 제2수집부(153)의 동작은 동일하다. 따라서, 이하에서는 제1수집부(151)와 제1M/M 데이터를 예로 들어 설명하고, 제1M/M 데이터를 설명하는 설명정보를 ‘제1설명정보’라 하고, 제1설명정보를 이루는 적어도 하나의 속성정보를 ‘제1속성정보들’이라 한다.
제1수집부(151)는 수집된 제1M/M 데이터로부터 제1사용자의 ID가 추출되면, 제1사용자가 소속된 테넌트를 알기 위해, 제1사용자가 속한 제1테넌트의 ID(제1TID)가 메모리(140)에 저장되어 있는지 확인할 수 있다. 제1사용자의 ID에 매핑된 제1테넌트의 ID가 메모리(140)에 저장되어 있지 않으면, 제1수집부(151)는 추출한 제1사용자의 ID를 컨트롤러(160)에게 제공하면서 제1테넌트의 ID를 요청할 수 있다.
컨트롤러(160)는 제1수집부(151)의 요청에 의해 제1사용자의 ID에 매핑되어 저장된 제1테넌트의 ID를 테넌트 ID 저장부(110)로부터 확인할 수 있다. 컨트롤러(160)는 [표 1]로부터 제1사용자의 ID에 매핑된 제1테넌트의 ID를 확인할 수 있다. 컨트롤러(160)는 확인된 제1테넌트의 ID를 [제1UID, 제1TID] 형태의 응답 메시지로 작성하여 제1수집부(151)에게 제공할 수 있다.
제1수집부(151)는 컨트롤러(160)로부터 수신한 제1테넌트의 ID인 제1TID를 제1사용자의 ID인 제1UID와 매핑하여 메모리(140)에 저장할 수 있다. 이는, 추후 제1사용자의 ID가 다시 추출되는 경우, 제1테넌트의 ID를 메모리(140)로부터 쉽게 확인하기 위함이다.
제1테넌트의 ID가 메모리(140)에 저장되어 있거나, 컨트롤러(160)로부터 제공되면, 제1수집부(151)는 제1설명정보를 대표하는 제1메타정보 ID(제1MID)가 메모리(140)에 저장되어 있는지 확인할 수 있다. 제1메타정보 ID가 메모리(140)에 저장되어 있지 않으면, 제1수집부(151)는 제1설명정보를 컨트롤러(160)에게 제공하면서 제1설명정보에 대한 제1메타정보 ID를 요청할 수 있다. 컨트롤러(160)에게 제공되는 제1설명정보는 WAS(10)로부터 수신한 제1속성정보들인 ‘제1서비스 ID, 제1데이터 타입, 제1머신 ID, 제1SW 서버 ID’와 컨트롤러(160)에서 제공되거나 메모리(140)에서 확인된 제1테넌트의 ID를 포함할 수 있다.
컨트롤러(160)는 제1수집부(151)의 요청에 의해 제1설명정보를 대표하는 제1메타정보 ID가 메타정보 저장부(120)에 저장되어 있는지를 확인할 수 있다. 컨트롤러(160)는 [표 2]로부터 제1설명정보에 매핑된 제1메타정보 ID를 확인할 수 있다. 컨트롤러(160)는 확인된 제1메타정보 ID를 [제1설명정보, 제1MID]=[제1서비스 ID, 제1TID, 제1데이터 타입, 제1머신 ID, 제1SW 서버 ID, 제1MID] 형태의 응답 메시지로 작성하여 제1수집부(151)에게 제공할 수 있다.
또한, 컨트롤러(160)는 제1설명정보를 대표하는 제1메타정보 ID가 메타정보 저장부(120)에 저장되어 있지 않으면, 제1설명정보에 새로운 메타정보 ID를 부여할 수 있다. 부여된 메타정보 ID가 제1메타정보 ID인 경우, 컨트롤러(160)는 [제1서비스 ID, 제1TID, 제1데이터 타입, 제1머신 ID, 제1SW 서버 ID, 제1MID] 형태의 응답 메시지로 작성하여 제1수집부(151)에게 제공할 수 있다.
제1수집부(151)는 컨트롤러(160)에 의해 확인되거나 새로 부여된 제1메타정보 ID를 제1설명정보(즉, 제1속성정보들)와 매핑하여 메모리(140)에 저장할 수 있다. 이는, 추후 제1설명정보의 메타정보 ID가 필요한 경우, 메모리(140)로부터 쉽게 확인하기 위함이다.
제1메타정보 ID가 메모리(140)에 저장되어 있거나, 컨트롤러(160)로부터 제공되면, 제1수집부(151)는 제1메타정보 ID와 수집된 제1M/M 데이터를 결합하여 [제1MID, 제1M/M 데이터]를 컨트롤러(160)에게 전송할 수 있다. 컨트롤러(160)는 제1수집부(151)로부터 수신된 [제1MID, 제1M/M 데이터]를 M/M 데이터 저장부(130)에 저장할 수 있다. 이로써, 제1MID와 제1M/M 데이터는 서로 매핑되어 저장될 수 있다.
또는, 제1수집부(151)는 제1M/M 데이터가 수집된 시각 정보인 수집 시각을 [제1MID, 제1M/M 데이터]와 결합하여 컨트롤러(160)에게 전송할 수 있다. 이러한 경우, 컨트롤러(160)는 수신된 [제1MID, 수집시각, 제1M/M 데이터]를 M/M 데이터 저장부(130)에 저장할 수 있다. 이로써, 제1MID, 수집시각 및 제1M/M 데이터는 [표 3]과 같이 서로 매핑되어 저장될 수 있다.
3. 데이터 조회 동작
조회부(170)는 조회 요청부(30)와 같은 외부로부터 적어도 하나의 속성정보(즉, 설명정보)와, M/M 데이터의 조회를 요청하는 신호가 수신되면, 수신된 설명정보에 매핑되어 저장된 M/M 데이터를 M/M 데이터 저장부(130)로부터 조회할 수 있다. 조회 요청부(30)로부터 수신되는 적어도 하나의 속성정보는 테넌트 ID, 서비스 ID, 가상머신 ID, 데이터 타입 및 SW 서버 ID 중 적어도 하나를 포함하며, 경우에 따라 일부 속성정보는 생략될 수 있다.
조회부(170)는 조회 요청부(30)로부터 수신된 정보에 메타정보 ID가 포함되어 있지 않은 경우, 설명정보를 대표하는 메타정보 ID를 메타정보 저장부(120)로부터 확인할 수 있다. 그리고, 조회부(170)는 확인된 메타정보 ID가 제1메타정보 ID이면, 제1메타정보 ID에 매핑된 M/M 데이터를 M/M 데이터 저장부(130)로부터 조회할 수 있다.
조회 요청부(30)가 데이터의 수집 시각 범위를 설명정보와 함께 전송한 경우, 조회부(170)는 확인된 제1메타정보 ID뿐만 아니라 수집시각 범위에 매핑되는 M/M 데이터를 조회할 수 있다.
상술한 실시 예에 의하면, 조회 요청부(30)가 속성정보로서 테넌트의 ID를 전송하면서 조회를 요청한 경우, 조회 요청부(30)는 M/M 데이터 저장부(130)에 저장된 M/M 데이터를 테넌트 별로 조회할 수 있으며, 그에 대한 과금을 수행할 수 있다.
도 2는 본 발명적 개념의 예시적 제2실시 예에 따른 모니터링 및 미터링 장치(200)를 포함하는 모니터링 및 미터링 시스템을 도시한 도면이다.
도 2에 예시적으로 도시된 모니터링 및 미터링 시스템은 멀티 테넌트 SaaS 플랫폼으로서, 서비스 제공부(40), 로그데이터 저장부(50), 조회 요청부(60) 및 모니터링 및 미터링 장치(200)를 포함할 수 있다. 즉, 클라우드 컴퓨팅 서비스를 제공하기 위해 하드웨어와 소프트웨어 인프라를 운영 및 제공하는 멀티 테넌트 SaaS 플랫폼에서도 본 실시 예에 따른 테넌트-어웨어 모니터링 및 미터링이 가능하다.
서비스 제공부(40)는 서비스 제공자의 서비스를 구동하며, 수집부(250)와 연동하여 M/M 데이터를 제공할 수 있다. 서비스 제공자는 SaaS 플랫폼의 인프라를 기반으로 최종 사용자가 사용하는 서비스를 제공할 수 있다.
서비스 제공부(40)는 WAS(41), 제1소프트웨어(SW)(43), 및 제2SW(35)를 포함할 수 있다. WAS(41)는 도 1을 참조하여 설명한 WAS(10)와 동일하다. 제1SW(43)와 제2SW(45)는 서비스 제공을 위한 소프트웨어이다.
모니터링 및 미터링 장치(200)는 테넌트 ID 저장부(210), 메타정보 저장부(220), M/M 데이터 저장부(230), 메모리(240), 수집부(250), 컨트롤러(260) 및 조회부(270)를 포함할 수 있다.
로그데이터 저장부(50), 조회 요청부(60) 및 모니터링 및 미터링 장치(200)는 도 1을 참조하여 설명한 로그데이터 저장부(20), 조회 요청부(30) 및 모니터링 및 미터링 장치(100)와 유사하게 동작하므로 상세한 설명은 생략한다.
다만, 수집부(250)는 서비스 제공부(40)와 연동되어 모니터링과 미터링에 필요한 데이터를 수집할 수 있다.
또한, 로그데이터 저장부(50)는 제1SW(43)와 제2SW(45)로부터 로그데이터를 수집하고, 제2수집부(250)는 로그데이터 저장부(50)로부터 로그데이터를 제공받아 M/M 데이터를 수집할 수 있다.
테넌트 ID 저장부(210)에는 각 사용자의 ID와 각 사용자가 어느 테넌트에 속하는지를 나타내는 테넌트 ID가 저장될 수 있다. 사용자 또는 테넌트의 추가, 삭제 또는 변경이 발생하는 경우, 변경된 사용자 또는 테넌트의 ID는 테넌트 ID 저장부(210)에 지속적으로 업데이트될 수 있다.
조회 요청부(60)는 M/M 데이터 저장부(230)에 저장된 M/M 데이터를 테넌트 별로 조회하여 서비스 사용량을 미터링하고, 조회 서비스에 대한 과금을 수행하며, SLA(Service Level Agreement) 모니터링 및 리포팅 등을 처리할 수 있다.
도 3은 본 발명적 개념의 예시적 제1실시 예에 따른 모니터링 및 미터링 방법을 설명하기 위한 흐름도이다.
도 3을 참조하여 설명할 모니터링 및 미터링 방법을 수행하는 장치는 도 1을 참조하여 설명한 모니터링 및 미터링 장치(100)일 수 있다.
도 3을 참조하면, 멀티 테넌시 환경에서 발생하는 모니터링 및 미터링 데이터(이하 ‘M/M 데이터’라 한다)를 수집하는데 필요한 에이전트, 즉, 어플리케이션이 구동될 수 있다(S310).
장치의 에이전트는 직접 또는 수집부를 실행시켜서 WAS로부터 M/M 데이터를 수집하거나, 소프트웨어를 사용함으로써 남은 로그데이터로부터 M/M 데이터를 수집할 수 있다(S320). S320단계에서, 에이전트는 M/M 데이터를 수집할 뿐만 아니라, M/M 데이터를 설명하는 속성정보들, 즉, 설명정보를 더 획득할 수 있다.
에이전트는 수집된 M/M 데이터로부터 서비스를 사용한 제1사용자의 ID를 추출할 수 있다(S330). S330단계에서, 에이전트는 사용자의 ID를 나타내는 파라미터 값, 칼럼 또는 필드로부터 제1사용자의 ID를 추출할 수 있다.
에이전트는 S330단계에서 추출된 제1사용자가 소속된 테넌트인 제1테넌트의 ID를 확인할 수 있다(S340). S340단계에서, 에이전트는 에이전트와 연동하는 메모리 또는 별도의 테넌트 ID 저장부로부터 제1테넌트의 ID를 확인할 수 있다.
장치는 S320단계에서 획득된 속성정보들을 대표하는 ID인 제1메타정보 ID를 메타정보 저장부로부터 확인하거나 새롭게 부여할 수 있다(S350).
장치는 S350단계에서 확인되거나 부여된 제1메타정보 ID, M/M 데이터가 수집된 시각 및 수집된 M/M 데이터를 서로 매핑하여 저장할 수 있다(S360). S360단계에서 저장된 [제1메타정보 ID, M/M 데이터가 수집된 시각, 수집된 M/M 데이터]는 서비스 제공자와 같은 외부에서 속성정보 별로(예를 들어, 테넌트 별로) 모니터링 및 미터링을 하고자 할 때 이용될 수 있다.
도 4는 본 발명적 개념의 예시적 실시 예에 따른 모니터링 및 미터링 방법 중 조회 방법을 설명하기 위한 흐름도이다.
도 4를 참조하여 설명할 모니터링 및 미터링 데이터의 조회 방법을 수행하는 장치는 도 1을 참조하여 설명한 모니터링 및 미터링 장치(100)일 수 있다.
도 4를 참조하면, 외부로부터 모니터링 및 미터링할 대상의 속성정보들 및 수집시각 범위가 수신되어, M/M 데이터의 조회가 요청될 수 있다(S410).
장치는 S410단계에서 수신된 속성정보들의 메타정보 ID인 제1메타정보 ID를 메타정보 저장부로부터 확인할 수 있다(S420).
장치는 S420단계에서 확인된 제1메타정보 ID와 S410단계에서 수신된 수집시각 범위에 해당하는 M/M 데이터를 M/M 데이터 저장부로부터 조회할 수 있다(S430).
장치는 S430단계에서 조회된 M/M 데이터는 조회를 요청한 외부로 제공할 수 있다.
도 5는 본 발명적 개념의 예시적 제2실시 예에 따른 모니터링 및 미터링 방법을 설명하기 위한 흐름도이다.
도 5를 참조하여 설명할 모니터링 및 미터링 방법은 도 3의 각 단계를 구체화한 일 예일 수 있다. 도 5에 예시적으로 도시된 WAS, 로그데이터 저장부, 수집부, 컨트롤러, 테넌트 ID 저장부, 메타정보 저장부 및 모니터링 및 미터링 데이터 저장부는 도 1을 참조하여 설명한 WAS(10), 로그데이터 저장부(20), 수집부(150), 컨트롤러(160), 테넌트 ID 저장부(110), 메타정보 저장부(120) 및 M/M 데이터 저장부(130)일 수 있다.
도 5를 참조하면, 수집부는 WAS 에이전트 또는 웹 어플리케이션 에이전트에 의해 실행되어, 복수 개의 설명정보들과 사용자의 ID(UID)를 추출하기 위한 정보를 로딩하여 저장할 수 있다(S505). 서비스 ID, 가상머신 ID, SW 서버 ID, 데이터 타입 등의 속성정보들로 이루어진 복수 개의 설명정보들은 WAS 에이전트 또는 웹 어플리케이션 에이전트의 설정 파일로부터 로드하거나, 실행 변수(실행 파라미터)로 지정될 수 있다. 사용자의 ID를 추출하기 위한 정보는 M/M 데이터를 수집하기 위한 로그데이터가 로그 DB 형태인 경우, 로그 DB 중 사용자의 ID를 나타내는 칼럼이며, 로그데이터가 로그 파일 형태인 경우, 로그 파일 중 사용자의 ID를 나타내는 필드일 수 있다.
S505단계의 초기 로드 동작이 완료되면, 수집부는 로그데이터 저장부와 WAS에게 M/M데이터를 요청할 수 있다(S510, 515).
로그데이터 저장부와 WAS는 M/M 데이터를 수집부에게 전송하며(S520, S525), 수집부는 수신된 M/M 데이터를 수집 및 저장할 수 있다(S530). S520단계 및 S525단계에서, 로그데이터 저장부와 WAS는 M/M 데이터를 설명하는 속성정보들(즉, 제1속성정보들=제1설명정보)를 M/M 데이터와 함께 전송할 수 있다.
수집부는 S530단계에서 수집된 M/M 데이터로부터 제1사용자의 ID(제1UID)를 추출할 수 있다(S535). S535단계는, S505단계에서 미리 로딩되어 저장된 사용자의 ID를 추출하기 위한 정보를 이용하여 M/M 데이터로부터 제1사용자의 ID를 추출할 수 있다.
수집부는 S535단계에서 추출된 제1사용자의 ID를 이용하여, 제1사용자가 속한 테넌트의 ID, 즉, 제1테넌트의 ID(제1TID)가 메모리에 존재하는지 확인할 수 있다(S540).
메모리에 제1테넌트의 ID가 존재하지 않으면(S540-N), 수집부는 제1사용자의 ID를 컨트롤러에게 제공하면서 제1테넌트의 ID를 요청할 수 있다(S545).
컨트롤러는 수집부의 요청에 의해 제1사용자의 ID에 매핑되어 저장된 제1테넌트의 ID를 테넌트 ID 저장부를 조회하여 획득할 수 있다(S550, S555). S550단계에서, 컨트롤러는 [표 1]과 같은 테넌트 ID 저장부를 조회하여 제1사용자의 ID에 매핑된 제1테넌트의 ID를 확인할 수 있다.
컨트롤러는 S555단계에서 획득된 제1테넌트의 ID를 [제1UID, 제1TID] 형태의 응답 메시지로 작성하여 수집부에게 제공할 수 있다(S560).
수집부는 S560단계에서 수신한 제1테넌트의 ID인 제1TID를 제1사용자의 ID인 제1UID와 매핑하여 메모리에 저장할 수 있다(S565). 이는, 추후 제1사용자의 ID가 다시 추출되는 경우, 제1테넌트의 ID를 메모리로부터 쉽게 확인하기 위함이다.
그리고, 수집부는 M/M 데이터를 설명하는 제1설명정보를 대표하는 제1메타정보 ID(제1MID)가 메모리에 저장되어 있는지 확인할 수 있다(S570).
제1메타정보 ID가 메모리에 저장되어 있지 않으면(S570-N), 수집부는 제1설명정보를 컨트롤러에게 제공하면서 제1설명정보에 대한 제1메타정보 ID를 요청할 수 있다(S575). S575단계에서 컨트롤러에게 제공되는 제1설명정보는 S520단계 또는 S525단계에서 수신한 제1설명정보인 ‘제1서비스 ID, 제1TID, 제1데이터 타입, 제1머신 ID, 제1SW 서버 ID’와, S540단계에서 확인되거나 S560단계에서 컨트롤러로부터 제공된 제1테넌트의 ID를 포함할 수 있다.
컨트롤러는 S575단계의 요청에 의해 메타정보 저장부를 조회하여 제1메타정보 ID가 저장되어 있는지 확인할 수 있다(S580).
메타정보 저장부에 제1설명정보에 매핑된 제1메타정보 ID가 저장되어 있으면(S585-Y), 컨트롤러는 제1메타정보 ID를 획득할 수 있다(S590).
반면, 메타정보 저장부에 제1설명정보에 매핑된 제1메타정보 ID가 저장되어 있지 않으면(S585-N), 컨트롤러는 제1설명정보에 새로운 제1메타정보 ID를 부여할 수 있다(S595).
컨트롤러는 S590단계에서 획득된 제1메타정보 ID 또는 S595단계에서 부여된 제1메타정보 ID를 [제1서비스 ID, 제1TID, 제1데이터 타입, 제1머신 ID, 제1SW 서버 ID, 제1MID] 형태의 응답 메시지로 작성하여 수집부에게 제공할 수 있다(S600). [제1서비스 ID, 제1TID, 제1데이터 타입, 제1머신 ID, 제1SW 서버 ID, 제1MID] 중 ‘제1서비스 ID, 제1TID, 제1데이터 타입, 제1머신 ID, 제1SW 서버 ID’는 제1설명정보이다.
수집부는 S600단계에서 제공받은 제1메타정보 ID를 제1설명정보와 매핑하여 메모리에 저장할 수 있다(S605). 이는, 추후 제1설명정보의 메타정보 ID가 필요한 경우, 메모리로부터 쉽게 확인하기 위함이다.
그리고, 수집부는 S600단계에서 제공받은 제1메타정보 ID와 S530단계에서 수집된 M/M 데이터를 결합하여 [제1MID, M/M 데이터]를 컨트롤러에게 전송하면서 저장을 요청할 수 있다(S610). S610단계에서, 수집부는 M/M 데이터가 수집된 시각을 더 결합하여 컨트롤러에게 전송할 수 있다.
컨트롤러는 S610단계에서 수신된 [제1MID, 수집시각, 제1M/M 데이터]를 M/M 데이터 저장부에 저장할 수 있다(S615). 이로써, 제1MID, 수집시각 및 제1M/M 데이터는 [표 3]과 같이 서로 매핑되어 저장될 수 있다.
한편, 제1테넌트의 ID가 메모리에 저장되어 있으면(S540-Y), 수집부는 메모리로부터 제1테넌트의 ID를 확인할 수 있다(S625). 그리고, 수집부는 S570단계부터 동작을 수행할 수 있다.
또한, 제1메타정보 ID가 메모리에 저장되어 있으면(S570-Y), 수집부는 메모리로부터 제1메타정보 ID를 확인할 수 있다(S630). 그리고, 수집부는 S610단계부터 동작을 수행할 수 있다.
상술한 실시예들에서, 수집부, 컨트롤러, 조회부, 및 조회 요청부 등은 각각의 기능을 수행하도록 소프트웨어로 구현되거나, 또는 각각의 기능을 수행하는 소프트웨어 및 이러한 소프트웨어를 저장하고 실행시키는데 필요한 적어도 하나 이상의 하드웨어로 구현될 수 있다.
상기와 같이 본 발명은 비록 한정된 실시 예와 도면에 의해 설명되었으나, 본 발명은 상기의 실시 예에 한정되는 것은 아니며, 본 발명이 속하는 분야에서 통상의 지식을 가진 자라면 이러한 기재로부터 다양한 수정 및 변형이 가능하다. 그러므로, 본 발명의 범위는 설명된 실시 예에 국한되어 정해져서는 아니 되며, 후술하는 특허청구범위뿐 아니라 이 특허청구범위와 균등한 것들에 의해 정해져야 한다.
10: Web Application Server 20: 로그데이터 저장부
30: 조회 요청부 100: 모니터링 및 미터링 장치
110: 테넌트 ID 저장부 120: 메타정보 저장부
130: 모니터링 및 미터링 데이터 저장부 140: 메모리
150: 수집부 160: 컨트롤러
170: 조회부

Claims (25)

  1. 멀티 테넌시 환경에서 발생되는 모니터링 및 미터링 데이터를 수집하는 수집부; 및
    상기 수집된 모니터링 및 미터링 데이터의 속성을 설명하는 제1설명정보를 대표하는 제1메타정보 ID와, 상기 수집된 모니터링/미터링 데이터를 매핑하여 저장하는 제1저장부;를 포함하는 모니터링 및 미터링 장치.
  2. 제1항에 있어서,
    서로 다른 속성정보들로 이루어진 복수 개의 설명정보들과, 상기 복수 개의 설명정보들에 할당되는 복수 개의 메타정보 ID들을 서로 매핑하여 저장하는 제2저장부; 및
    적어도 하나의 속성정보로 이루어진 상기 제1설명정보를 대표하는 제1메타정보 ID가 상기 제2저장부에 저장되어 있는지를 확인하고, 저장되어 있는 경우, 상기 제2저장부에 저장된 제1메타정보 ID와 상기 수집된 모니터링 및 미터링 데이터를 매핑하여 상기 제1저장부에 저장하는 컨트롤러;를 더 포함하는 것을 특징으로 하는 모니터링 및 미터링 장치.
  3. 제2항에 있어서,
    상기 컨트롤러는, 상기 제2저장부에 상기 제1메타정보 ID가 저장되어 있지 않은 것으로 확인되면, 상기 수집된 모니터링 및 미터링 데이터에 상기 제1메타정보 ID를 새로 부여하고, 상기 새로 부여된 제1메타정보 ID와 상기 수집된 모니터링 및 미터링 데이터를 매핑하여 상기 제1저장부에 저장하는 것을 특징으로 하는 모니터링 및 미터링 장치.
  4. 제1항에 있어서,
    복수의 사용자들의 ID와 상기 복수의 사용자들이 속한 테넌트들의 ID를 서로 매핑하여 저장하는 제3저장부; 및
    상기 수집부가 제1사용자의 ID가 속한 제1테넌트의 ID를 요청하는 경우, 상기 제1사용자의 ID에 매핑되어 저장된 제1테넌트의 ID를 상기 제3저장부로부터 확인하여 상기 수집부에게 제공하는 컨트롤러;를 더 포함하며,
    상기 제1사용자의 ID는 상기 모니터링 및 미터링 데이터와 관련된 서비스를 사용한 사용자 ID로서 상기 수집부에 의해 상기 모니터링 및 미터링 데이터로부터 추출된 것임을 특징으로 하는 모니터링 및 미터링 장치.
  5. 제4항에 있어서,
    상기 수집부는 상기 수집부의 초기 구동을 위한 에이전트 실행 시 세션 내 속성값, 브라우저의 쿠키값 및 요청 파라미터의 값 각각으로부터 사용자의 ID를 나타내는 값을 미리 확인 및 로딩하여 메모리에 저장하고, 상기 미리 확인된 값을 이용하여 상기 수집된 모니터링 및 미터링 데이터로부터 상기 제1사용자의 ID를 추출하는 것을 특징으로 하는 모니터링 및 미터링 장치.
  6. 제4항에 있어서,
    상기 수집부는 상기 수집부의 초기 구동을 위한 에이전트 실행 시 로그데이터 저장부에 저장된 로그 DB 중 사용자의 ID를 나타내는 칼럼을 미리 확인 및 로딩하여 메모리에 저장하고, 상기 로그 DB로부터 상기 모니터링 및 미터링 데이터를 수집하고, 상기 미리 확인된 칼럼을 이용하여 상기 로그 DB로부터 상기 제1사용자의 ID를 추출하는 것을 특징으로 하는 모니터링 및 미터링 장치.
  7. 제4항에 있어서,
    상기 수집부는 상기 수집부의 초기 구동을 위한 에이전트 실행 시 로그데이터 저장부에 저장된 로그 파일 중 사용자의 ID를 나타내는 필드를 미리 확인 및 로딩하여 메모리에 저장하고, 상기 로그파일로부터 상기 모니터링 및 미터링 데이터를 수집하고, 상기 미리 확인된 필드를 이용하여 상기 로그 파일로부터 상기 제1사용자의 ID를 추출하는 것을 특징으로 하는 모니터링 및 미터링 장치.
  8. 제1항에 있어서,
    상기 모니터링 및 미터링 데이터의 제1설명정보는, 테넌트가 사용하는 서비스의 ID, 상기 서비스를 사용하는 테넌트의 ID, 상기 수집된 모니터링 및 미터링 데이터의 종류를 나타내는 데이터 타입, 상기 수집된 모니터링 및 미터링 데이터가 수행되고 있는 가상 머신의 ID 및 상기 모니터링 및 미터링 데이터를 생성한 소프트웨어 서버의 ID 중 적어도 하나를 포함하며,
    상기 메타정보 ID는 상기 서비스의 ID, 테넌트의 ID, 데이터 타입, 가상 머신의 ID 및 소프트웨어 서버의 ID 중 적어도 하나를 대표하는 ID인 것을 특징으로 하는 모니터링 및 미터링 장치.
  9. 제2항 또는 제3항에 있어서,
    외부로부터 적어도 하나의 속성정보 및 모니터링 및 미터링 데이터의 조회를 요청하는 신호가 수신되면, 상기 수신된 적어도 하나의 속성정보에 매핑되어 저장된 모니터링 및 미터링 데이터를 상기 제1저장부로부터 조회하는 조회부;를 더 포함하는 것을 특징으로 하는 모니터링 및 미터링 장치.
  10. 제9항에 있어서,
    상기 조회부는 상기 외부로부터 수신되는 적어도 하나의 속성정보에 해당하는 상기 제1메타정보 ID를 상기 제2저장부로부터 확인하고, 상기 확인된 제1메타정보 ID를 이용하여 상기 제1저장부를 조회하는 것을 특징으로 하는 모니터링 및 미터링 장치.
  11. 제1항에 있어서,
    상기 모니터링 및 미터링 데이터가 상기 수집부에 의해 수집된 시각정보를 상기 제1메타정보 ID와 더 매핑하여 상기 제1저장부에 저장하는 컨트롤러;를 더 포함하는 것을 특징으로 하는 모니터링 및 미터링 장치.
  12. 테넌트들이 사용한 서비스들의 모니터링 및 미터링 데이터, 상기 모니터링 및 미터링 데이터가 수집된 시각 및 상기 수집된 모니터링 및 미터링 데이터의 속성정보들을 통합하는 메타정보 ID를 저장하는 모니터링 및 미터링 데이터 저장부; 및
    외부로부터 수신되는 상기 속성정보들 중 적어도 하나와 수집시각 범위를 고려하여, 상기 모니터링 및 미터링 데이터 저장부에 저장된 모니터링 및 미터링 데이터를 조회하는 조회부;를 포함하는 모니터링 및 미터링 장치.
  13. 제12항에 있어서,
    복수 개의 메타정보 ID들에 매핑되는 속성정보들을 저장하는 메타정보 저장부;를 더 포함하며,
    상기 조회부는 상기 외부로부터 수신된 상기 속성정보들 중 적어도 하나에 매핑되는 상기 메타정보 ID를 상기 메타정보 저장부로부터 확인하고, 상기 확인된 메타정보 ID와 상기 수집시각 범위를 이용하여 상기 모니터링 및 미터링 데이터 저장부를 조회하는 것을 특징으로 하는 모니터링 및 미터링 장치.
  14. 제12항에 있어서,
    상기 모니터링 및 미터링 데이터의 속성정보들은, 테넌트가 사용하는 서비스의 ID, 상기 서비스를 사용하는 테넌트의 ID, 상기 수집된 모니터링 및 미터링 데이터의 종류를 나타내는 데이터 타입, 상기 수집된 모니터링 및 미터링 데이터가 수행되고 있는 가상 머신의 ID 및 상기 모니터링 데이터를 생성한 소프트웨어 서버의 ID 중 적어도 하나를 포함하며,
    상기 메타정보 ID는 상기 서비스의 ID, 테넌트의 ID, 데이터 타입, 가상 머신의 ID 및 소프트웨어 서버의 ID 중 적어도 하나를 통합한 정보인 메타정보를 식별하기 위한 ID인 것을 특징으로 하는 모니터링 및 미터링 장치.
  15. 멀티 테넌시 환경에서 발생되는 모니터링 및 미터링 데이터를 수집하는 단계; 및
    상기 수집된 모니터링 및 미터링 데이터의 속성을 설명하는 제1정보를 대표하는 제1메타정보 ID와, 상기 수집된 모니터링/미터링 데이터를 매핑하여 저장하는 단계;를 포함하는 모니터링 및 미터링 방법.
  16. 제15항에 있어서,
    서로 다른 속성정보들로 이루어진 복수 개의 설명정보들과, 상기 복수 개의 설명정보들에 할당되는 복수 개의 메타정보 ID들이 서로 매핑되어 저장되는 단계; 및
    적어도 하나의 속성정보로 이루어진 상기 제1설명정보를 대표하는 제1메타정보 ID가 상기 저장되는 단계에서 저장되었는지를 확인하는 단계;를 더 포함하며,
    저장되어 있는 것으로 확인된 경우, 상기 제1메타정보 ID와, 상기 수집된 모니터링/미터링 데이터를 매핑하여 저장하는 단계는, 상기 확인된 제1메타정보 ID와 상기 수집된 모니터링 및 미터링 데이터를 매핑하여 저장하는 것을 특징으로 하는 모니터링 및 미터링 방법.
  17. 제16항에 있어서,
    상기 제1설명정보를 대표하는 제1메타정보 ID가 상기 저장되는 단계에서 저장되지 않은 것으로 확인되면, 상기 수집된 모니터링 및 미터링 데이터에 상기 제1메타정보 ID를 새로 부여하는 단계;를 더 포함하며,
    상기 제1메타정보 ID와, 상기 수집된 모니터링/미터링 데이터를 매핑하여 저장하는 단계는, 상기 새로 부여된 제1메타정보 ID와 상기 수집된 모니터링 및 미터링 데이터를 매핑하여 저장하는 것을 특징으로 하는 모니터링 및 미터링 방법.
  18. 제15항에 있어서,
    상기 수집하는 단계에서 수집된 상기 모니터링 및 미터링 데이터로부터 상기 모니터링 및 미터링 데이터와 관련된 서비스를 사용한 제1사용자의 ID를 추출하는 단계; 및
    상기 추출된 제1사용자의 ID가 속한 제1테넌트의 ID를 확인하는 단계;를 더 포함하는 것을 특징으로 하는 모니터링 및 미터링 방법.
  19. 제18항에 있어서,
    상기 모니터링 및 미터링 데이터의 수집을 위해 에이전트를 초기 실행하는 단계; 및
    세션 내 속성값, 브라우저의 쿠키값 및 요청 파라미터의 값 각각으로부터 사용자의 ID를 나타내는 값을 미리 확인 및 로딩하여 저장하는 단계;를 더 포함하며,
    상기 제1사용자의 ID를 추출하는 단계는, 상기 미리 확인된 값을 이용하여 상기 수집된 모니터링 및 미터링 데이터로부터 상기 제1사용자의 ID를 추출하는 것을 특징으로 하는 모니터링 및 미터링 방법.
  20. 제18항에 있어서,
    상기 모니터링 및 미터링 데이터의 수집을 위해 에이전트를 초기 실행하는 단계; 및
    상기 멀티 테넌시 환경에서 발생하는 로그 DB 중 사용자의 ID를 나타내는 칼럼을 미리 확인 및 로딩하여 저장하는 단계;를 더 포함하며,
    상기 제1사용자의 ID를 추출하는 단계는, 상기 미리 확인된 칼럼을 이용하여 상기 로그 DB로부터 상기 제1사용자의 ID를 추출하는 것을 특징으로 하는 모니터링 및 미터링 방법.
  21. 제18항에 있어서,
    상기 모니터링 및 미터링 데이터의 수집을 위해 에이전트를 초기 실행하는 단계; 및
    상기 멀티 테넌시 환경에서 발생하는 로그 파일 중 사용자의 ID를 나타내는 필드를 미리 확인 및 로딩하여 저장하는 단계;를 더 포함하며,
    상기 제1사용자의 ID를 추출하는 단계는, 상기 미리 확인된 필드를 이용하여 상기 로그 파일로부터 상기 제1사용자의 ID를 추출하는 것을 특징으로 하는 모니터링 및 미터링 방법.
  22. 제15항에 있어서,
    상기 모니터링 및 미터링 데이터의 제1설명정보는, 테넌트가 사용하는 서비스의 ID, 상기 서비스를 사용하는 테넌트의 ID, 상기 수집된 모니터링 및 미터링 데이터의 종류를 나타내는 데이터 타입, 상기 수집된 모니터링 및 미터링 데이터가 수행되고 있는 가상 머신의 ID 및 상기 모니터링 및 미터링 데이터를 생성한 소프트웨어 서버의 ID 중 적어도 하나를 포함하며,
    상기 메타정보 ID는 상기 서비스의 ID, 테넌트의 ID, 데이터 타입, 가상 머신의 ID 및 소프트웨어 서버의 ID 중 적어도 하나를 대표하는 ID인 것을 특징으로 하는 모니터링 및 미터링 방법.
  23. 제16항 또는 제17항에 있어서,
    외부로부터 적어도 하나의 속성정보 및 모니터링 및 미터링 데이터의 조회를 요청하는 신호가 수신되면, 상기 수신된 적어도 하나의 속성정보에 매핑되어 저장된 모니터링 및 미터링 데이터를 조회하는 단계;를 더 포함하는 것을 특징으로 하는 모니터링 및 미터링 방법.
  24. 제23항에 있어서,
    상기 외부로부터 수신되는 적어도 하나의 속성정보에 해당하는 상기 제1메타정보 ID를 확인하는 단계;를 더 포함하며,
    상기 조회하는 단계는, 상기 확인된 제1메타정보 ID를 이용하여 상기 모니터링 및 미터링 데이터를 조회하는 것을 특징으로 하는 모니터링 및 미터링 방법.
  25. 제15항에 있어서,
    제1메타정보 ID와, 상기 수집된 모니터링/미터링 데이터를 매핑하여 저장하는 단계는, 상기 모니터링 및 미터링 데이터가 수집된 시각정보를 상기 제1메타정보 ID와 더 매핑하여 저장하는 것을 특징으로 하는 모니터링 및 미터링 방법.
KR1020110112467A 2011-10-31 2011-10-31 모니터링 및 미터링 장치 및 방법 KR101296413B1 (ko)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020110112467A KR101296413B1 (ko) 2011-10-31 2011-10-31 모니터링 및 미터링 장치 및 방법

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020110112467A KR101296413B1 (ko) 2011-10-31 2011-10-31 모니터링 및 미터링 장치 및 방법

Publications (2)

Publication Number Publication Date
KR20130047438A true KR20130047438A (ko) 2013-05-08
KR101296413B1 KR101296413B1 (ko) 2013-08-13

Family

ID=48658930

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020110112467A KR101296413B1 (ko) 2011-10-31 2011-10-31 모니터링 및 미터링 장치 및 방법

Country Status (1)

Country Link
KR (1) KR101296413B1 (ko)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10216503B2 (en) 2013-03-13 2019-02-26 Elasticbox Inc. Deploying, monitoring, and controlling multiple components of an application

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8615400B2 (en) * 2008-08-19 2013-12-24 International Business Machines Corporation Mapping portal applications in multi-tenant environment

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10216503B2 (en) 2013-03-13 2019-02-26 Elasticbox Inc. Deploying, monitoring, and controlling multiple components of an application

Also Published As

Publication number Publication date
KR101296413B1 (ko) 2013-08-13

Similar Documents

Publication Publication Date Title
US11017368B2 (en) Systems and methods for automatically collection of performance data in a multi-tenant database system environment
US9110976B2 (en) Supporting compliance in a cloud environment
Schopf et al. Monitoring and discovery in a web services framework: Functionality and performance of the globus toolkit’s mds4
US20150067019A1 (en) Method and system for using arbitrary computing devices for distributed data processing
JP6440571B2 (ja) SaaS間データ連携支援システムおよびSaaS間データ連携支援方法
US20130275475A1 (en) Monitoring System for Optimizing Integrated Business Processes to Work Flow
US10354255B2 (en) Client access license tracking mechanism
US20080235141A1 (en) License manager and schema
CN103038788A (zh) 提供多个网络资源
JP2006511884A5 (ko)
JP6252570B2 (ja) 情報処理システム、アクセス制御方法、情報処理装置およびその制御方法と制御プログラム
US7721295B2 (en) Execution multiplicity control system, and method and program for controlling the same
US20180248772A1 (en) Managing intelligent microservices in a data streaming ecosystem
EP2808792A1 (en) Method and system for using arbitrary computing devices for distributed data processing
US9413811B2 (en) Establishing upload channels to a cloud data distribution service
KR101296413B1 (ko) 모니터링 및 미터링 장치 및 방법
US9785711B2 (en) Online location sharing through an internet service search engine
WO2018218058A1 (en) Systems and methods for providing real-time discrepancies between disparate execution platforms
US10732852B1 (en) Telemetry service
KR101624898B1 (ko) 데이터 서비스 성능 통합 관리방법
CN104320457A (zh) 一种基于分布式管理的网络发票系统
US9406073B2 (en) System and method for facilitating the exchange of user traffic between web sites
JP5249368B2 (ja) ネットワーク装置
US20230267474A1 (en) Managing user consent for purpose document
Aiftimiei et al. Recent evolutions of GridICE: a monitoring tool for grid systems

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant
FPAY Annual fee payment

Payment date: 20160701

Year of fee payment: 4

FPAY Annual fee payment

Payment date: 20170629

Year of fee payment: 5

FPAY Annual fee payment

Payment date: 20180625

Year of fee payment: 6

FPAY Annual fee payment

Payment date: 20190701

Year of fee payment: 7