KR101478902B1 - Method and system for providing service based on profile according to node property in instance hosting environment - Google Patents

Method and system for providing service based on profile according to node property in instance hosting environment Download PDF

Info

Publication number
KR101478902B1
KR101478902B1 KR20130037492A KR20130037492A KR101478902B1 KR 101478902 B1 KR101478902 B1 KR 101478902B1 KR 20130037492 A KR20130037492 A KR 20130037492A KR 20130037492 A KR20130037492 A KR 20130037492A KR 101478902 B1 KR101478902 B1 KR 101478902B1
Authority
KR
South Korea
Prior art keywords
iot
profile
node
developer
instance
Prior art date
Application number
KR20130037492A
Other languages
Korean (ko)
Other versions
KR20140121533A (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 KR20130037492A priority Critical patent/KR101478902B1/en
Priority to US14/159,821 priority patent/US20140289366A1/en
Publication of KR20140121533A publication Critical patent/KR20140121533A/en
Application granted granted Critical
Publication of KR101478902B1 publication Critical patent/KR101478902B1/en

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/12Protocols specially adapted for proprietary or special-purpose networking environments, e.g. medical networks, sensor networks, networks in vehicles or remote metering networks
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/2866Architectures; Arrangements
    • H04L67/30Profiles
    • H04L67/303Terminal profiles

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Health & Medical Sciences (AREA)
  • Computing Systems (AREA)
  • General Health & Medical Sciences (AREA)
  • Medical Informatics (AREA)
  • Computer And Data Communications (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

인스턴스 호스팅 환경에서 노드 별 특성에 따른 프로파일에 기초하여 서비스를 제공하는 방법 및 시스템이 개시된다. 서비스 제공 방법은, IoT(Internet of Things) 노드의 개발자로부터 제공되는 상기 IoT 노드에 대한 정보를 이용하여 IoT 프로파일을 생성하는 단계 및 상기 IoT 프로파일을 IoT 프로파일 데이터베이스에 저장하여 관리하거나 또는 상기 개발자에게 제공하는 단계를 포함할 수 있고, 상기 IoT 노드가 접속하는 인스턴스 호스팅 게이트웨이에서, (1) 상기 IoT 프로파일 데이터베이스에 저장된 상기 IoT 프로파일, (2) 상기 개발자에게 제공되어 상기 개발자와 연관된 URL을 통해 제공되는 상기 IoT 프로파일 또는 (3) 상기 개발자에게 제공되어 상기 IoT 노드에 포함되는 상기 IoT 프로파일을 이용하여 상기 IoT 노드를 등록하는 것을 특징으로 할 수 있다.A method and system for providing a service based on a profile according to node-specific characteristics in an instance hosting environment. The service providing method includes: generating an IoT profile using information about the IoT node provided from a developer of an Internet of Things (IoT) node; storing the IoT profile in the IoT profile database and managing or providing the IoT profile to the developer; (1) the IoT profile stored in the IoT profile database; (2) the IoT profile provided to the developer and provided via a URL associated with the developer; IoT profile, or (3) the IoT node is registered using the IoT profile provided to the developer and included in the IoT node.

Description

인스턴스 호스팅 환경에서 노드 별 특성에 따른 프로파일에 기초하여 서비스를 제공하는 방법 및 시스템{METHOD AND SYSTEM FOR PROVIDING SERVICE BASED ON PROFILE ACCORDING TO NODE PROPERTY IN INSTANCE HOSTING ENVIRONMENT}[0001] METHOD AND SYSTEM FOR PROVIDING SERVICE BASED ON PROPERTIES IN INSTANCE HOSTING ENVIRONMENT [0002]

본 발명의 실시예들은 인스턴스 호스팅 환경에서 노드 별 특성에 따른 프로파일에 기초하여 서비스를 제공하는 방법 및 시스템에 관한 것이다.Embodiments of the present invention are directed to a method and system for providing a service based on a profile according to node-specific characteristics in an instance hosting environment.

IoT(Internet of Things)는 기존 USN(Ubiquitous Sensor Network)나 M2M(Machine to Machine)에서 진화된 형태를 띄고 있는데, 기존 M2M이 통신장비(end-device)와 사람과의 통신이 주 목적이었다면, IoT는 사물의 범위를 넓혀 우리가 흔히 볼 수 있는 전화기, 책, 온도계 등의 사물을 사람과 통신이 가능하도록 해준다는 것이다. 즉, IoT는 인간과 사물, 서비스의 세 가지 분산된 환경 요소에 대해, 인간의 명시적인 개입 없이도 상호 협력적으로 센싱, 네트워킹, 정보 처리 등 지능적 관계를 형성하는 사물 공간 연결망을 의미할 수 있다.The Internet of Things (IOT) has evolved from the existing USN (Ubiquitous Sensor Network) or M2M (Machine to Machine). If the existing M2M was intended to communicate with end-devices and people, Is to broaden the scope of things so that we can communicate with people, such as telephones, books, thermometers, etc., that we commonly see. In other words, IoT can refer to a three-dimensional distributed environment element of human being, object, and service, and a spatial space network that forms an intelligent relationship such as sensing, networking, and information processing cooperatively without human intervention.

이러한 IoT 이외에도, WoT(Web of Things)나 WoO(Web of Objects)와 같이 다양한 개념과 기술들이 연구, 개발되고 있다. 이러한 개념과 기술들의 발전 및 확산으로 인해, 사용자들이 손쉽게 인터넷에 연결 가능한 기기들(가젯(gadget) 디바이스, 센서 디바이스, 액츄에이터(actuator) 등)의 사용이 늘어날 것으로 예산된다.In addition to IoT, various concepts and technologies such as Web of Things (WoT) and Web of Objects (WoO) are being researched and developed. Due to the evolution and diffusion of these concepts and technologies, it is expected that the use of devices (gadget devices, sensor devices, actuators, etc.), which users can easily connect to the Internet, will increase.

특히, 최근 들어 다양한 형태의 웹 연동형 가젯 디바이스들이 출시되고 있으며, 대다수의 센서 디바이스들의 경우, 웹을 통한 제어 및 모니터링 기능을 제공하고 있다. 또한, 웹을 통한 제어 기능을 제공하기 위한 단말들은, 단말 자체에 웹 서버 기능이 내장되거나 또는 온라인 상의 웹 서비스를 통해 제어될 수 있는 기능을 포함하고 있다.In particular, various types of web-linked gadget devices have recently been released, and most of the sensor devices provide control and monitoring functions through the web. In addition, terminals for providing a control function via the web include a function that enables the terminal itself to have a built-in web server function or to be controlled through an on-line web service.

그러나, 현재는 상술한 기술들, 기기들 또는 서비스들이 개별적으로 관리되고 있는 실정이라, 사용자의 불편함이 따르는 문제점이 있다. 예를 들어, 사용자는 다수의 기기들이 사용자 주위에 존재하나 개별적인 접근 경로(일례로, URL)를 통해 각각의 디바이스들을 제어해야 하는 불편함이 있다. 기기 자체가 웹 접근 기능(서버 기능)을 제공하는 경우에는 개별적인 기기의 접근을 위한 네트워크 연동 및 URL(IP 주소)가 필요하며, 전용 웹 서비스를 통해 서비스가 제공되는 경우에는 서비스별 접근 권 생성 및 URL이 필요하다.However, at present, the above-described technologies, devices or services are individually managed, and there is a problem that users are inconvenienced. For example, a user has the inconvenience that a plurality of devices are present around a user, but each device must be controlled through an individual access path (e.g., a URL). If the device itself provides a web access function (server function), network interworking and URL (IP address) for accessing individual devices are required. In the case where a service is provided through a dedicated web service, URL is required.

또한, 개별적으로 관리되는 데이터들을 유기적으로 연동하여 활용하기 힘든 문제점이 있다. 예를 들어, 집안의 보일러를 제어하는 센서의 경우 센서 기기가 직접 수집할 수 있는 주변 환경 정보는 사람 거주 유무, 내부 온도, 시간대 정도와 같이 매우 제한적이다. 만약, 이러한 센서 기기가 외부 정보(일례로 외부의 기온, 사용자의 스케쥴 정보 등)를 추가적으로 활용할 수 있다면, 보다 효과적인 제어 기능을 제공할 수 있으나, 각 기술들, 기기들 또는 서비스들마다 데이터들이 개별적으로 관리되고 있기 때문에 이러한 데이터들을 유기적으로 연동하여 활용하기 힘들다.In addition, there is a problem that it is difficult to utilize individually managed data in an interlocked manner. For example, in the case of a sensor that controls the boiler in the house, the environmental information that can be directly collected by the sensor device is very limited, such as the presence or absence of a person, internal temperature, and time zone. If such a sensor device can additionally utilize external information (e.g., outside temperature, user schedule information, etc.), more effective control functions may be provided, but data may be provided for each technology, It is difficult to utilize these data in an organic manner.

도 1은 종래기술에 있어서, 기기에서 임베디드 웹 서버를 내장하고 있는 경우의 서비스 제공 방식을 도시한 도면이다. 사용자는 웹과 같은 온라인(Online (Web))(110)을 통해 실제 세계(Physical World)(120)의 기기(IoT Node)(130)에 내장된 임베디드 웹 서버(Embedded Web Server)(140)에 접근할 수 있다. 이때, 임베디드 웹 서버(140)가 기기(130)에 내장되어 있기 때문에 기기(130)에서 생성되는 데이터, 그리고 특정 기능이나 서비스의 처리를 위한 프로세스 로직 모두가 기기(130)에 탑재되어 있다. 따라서, 기기(130)가 제공하는 서비스 영역을 벗어나, 다른 서비스 영역이나 다른 서비스의 데이터와 연동된 또는 융합된 서비스를 제공하는 것이 불가능하다.1 is a diagram illustrating a service providing method when an embedded web server is embedded in a device in the prior art. A user can access an embedded web server 140 embedded in a device 130 of a physical world 120 through an online (Web) It is accessible. At this time, because the embedded web server 140 is embedded in the device 130, both the data generated in the device 130 and the process logic for processing a specific function or service are loaded in the device 130. Therefore, it is impossible to provide services that are interlocked with or fused with data of other service areas or other services beyond the service area provided by the device 130. [

도 2는 종래기술에 있어서, 제조사가 별도의 웹 서버를 온라인상에서 제공하는 경우의 서비스 제공 방식을 도시한 도면이다. 도 2에서는 상술한 도 1에서와 달리, 제조사(또는 별도의 서비스 제공자)가 온라인(110)상에 웹 서버(Web Server)(210)를 구축하여 서비스를 제공하는 방식을 도시하고 있다. 이때, 사용자는 온라인(110)상의 웹 서버(210)를 통해 기기(IoT Node)(220)에 접근할 수 있다. 이 경우, 기기(210)에는 웹 서버(210)와 통신하기 위한 모듈(도 2의 HTTP 어댑터(HTTP Adaptor)(230))이 탑재될 수 있다. 따라서, 기기(220)에서 생성되는 데이터, 그리고 특정 기능이나 서비스의 처리를 위한 프로세스 로직 모두가 온라인상에서 제공이 가능하다. 필요에 따라, 데이터는 기기(220)에, 프로세스 로직은 웹 서버(210)상에 존재할 수도 있다. 이 경우에는, 제조사(또는 별도의 서비스 제공자)의 웹 서비스 가용 성능과 호스팅의 영속성에 대한 문제점이 발생할 수 있다.2 is a diagram illustrating a service providing method when a manufacturer provides a separate web server on-line in the prior art. In FIG. 2, unlike FIG. 1, a manufacturer (or a separate service provider) constructs a Web server 210 on the online 110 to provide a service. At this time, the user can access the device (IoT node) 220 through the web server 210 on-line 110. In this case, the device 210 may be equipped with a module (HTTP adapter 230 in FIG. 2) for communicating with the web server 210. Accordingly, both the data generated by the device 220 and the process logic for processing a specific function or service can be provided online. If desired, the data may reside on device 220 and the process logic may reside on web server 210. In this case, the manufacturer (or a separate service provider) may experience problems with Web service availability and persistence of hosting.

또한, 도 1 및 도 2를 참조하면, 사용자는 웹 서버(210)를 통해 임베디드 웹 서버(140)가 내장된 기기(130)로 접근할 수 없으며, 반대로 기기(130)의 임베디드 웹 서버(140)를 통해 웹 서버(210)나 기기(220)에 접근할 수 없다. 즉, 객체 인스턴스간에 상호 정보 교류가 불가능하여 연동형 또는 융합형 서비스를 제공할 수 없다.1 and 2, the user can not access the device 130 having the embedded web server 140 through the web server 210, and conversely, the user can not access the embedded web server 140 The web server 210 or the device 220 can not be accessed. That is, mutual information exchange between object instances is impossible, and thus interlocking or convergence type services can not be provided.

또한, 도 2를 참조하면, 기기(220)가 서비스의 제공을 위해, 센서 등과 같은 사물로부터 얻어진 정보나 사용자의 개인 정보(사용자의 위치 등) 등을 웹 서버(210)로 제공해야 하기 때문에 사용자의 프라이버시에 대한 문제가 발생할 소지가 존재한다.2, since the device 220 must provide information obtained from an object such as a sensor or personal information of a user (e.g., location of a user) to the web server 210 in order to provide a service, There is a possibility of causing a problem of the privacy of the user.

IoT(Internet of Things), WoT(Web of Things) 또는 WoO(Web of Objects) 환경에서 이기종의 기기들이나 다양한 서비스들을 연동 또는 융합하여 관리하고, 통합적으로 서비스를 제공하기 위한 서비스 제공 방법 및 시스템을 제공한다.Provides a method and system for providing services to provide heterogeneous devices or various services interlocking or converging in IoT (Internet of Things), WoT (Web of Things) or WoO (Web of Objects) do.

IoT(Internet of Things) 노드의 개발자로부터 제공되는 상기 IoT 노드에 대한 정보를 이용하여 IoT 프로파일을 생성하는 단계 및 상기 IoT 프로파일을 IoT 프로파일 데이터베이스에 저장하여 관리하거나 또는 상기 개발자에게 제공하는 단계를 포함하고, 상기 IoT 노드가 접속하는 인스턴스 호스팅 게이트웨이에서, (1) 상기 IoT 프로파일 데이터베이스에 저장된 상기 IoT 프로파일, (2) 상기 개발자에게 제공되어 상기 개발자와 연관된 URL을 통해 제공되는 상기 IoT 프로파일 또는 (3) 상기 개발자에게 제공되어 상기 IoT 노드에 포함되는 상기 IoT 프로파일을 이용하여 상기 IoT 노드를 등록하는 것을 특징으로 하는 서비스 제공 방법이 제공된다.Generating an IoT profile using information about the IoT node provided from a developer of an Internet of Things (IoT) node; and storing the IoT profile in the IoT profile database and managing or providing the IoT profile to the developer (1) the IoT profile stored in the IoT profile database; (2) the IoT profile provided through the URL provided to the developer and associated with the developer; or (3) the IoT profile provided to the developer, Wherein the IoT node is provided to a developer and the IoT node is registered using the IoT profile included in the IoT node.

일측에 따르면, 상기 IoT 노드에 대한 정보에 대한 정보는, 상기 개발자와 연관된 URL, 상기 IoT 프로파일과 연결된 프로세스 정보의 URL 중 적어도 하나를 포함하는 것을 특징으로 할 수 있다.According to one aspect, the information on the information about the IoT node includes at least one of a URL associated with the developer, and a URL of process information associated with the IoT profile.

다른 측면에 따르면, 상기 IoT 노드에 대한 정보에 대한 정보는, 상기 IoT 노드가 생산하는 데이터스트림에 대한 정보로서, 단위, 최소값 및 최대값 중 적어도 하나를 더 포함하는 것을 특징으로 할 수 있다.According to another aspect, the information on the information about the IoT node may include at least one of a unit, a minimum value, and a maximum value as information on a data stream produced by the IoT node.

또 다른 측면에 따르면, 상기 IoT 프로파일을 생성하는 단계는, 상기 IoT 노드에 대한 정보를 기설정된 XML 스키마 정의 (XML Schema Definition, XSD)에 따라 처리하여 상기 IoT 프로파일을 생성하는 것을 특징으로 할 수 있다.According to another aspect of the present invention, the step of generating the IoT profile may include processing the information about the IoT node according to a predetermined XML Schema Definition (XSD) to generate the IoT profile .

또 다른 측면에 따르면, 상기 IoT 노드의 데이터스트림이 상기 인스턴스 호스팅 게이트웨이에서 상기 IoT 프로파일의 정보를 이용하여 생성된 외부 API를 통해 제공되는 것을 특징으로 할 수 있다.According to another aspect of the present invention, a data stream of the IoT node is provided through an external API generated using the information of the IoT profile at the instance hosting gateway.

또 다른 측면에 따르면, 상기 IoT 노드의 데이터 로그(data log)가 JSON(JavaScript Object Notation) 또는 XML(eXtensible Markup Language) 형태로 제공되는 것을 특징으로 할 수 있다.According to another aspect of the present invention, the data log of the IoT node is provided in a form of JavaScript Object Notation (JSON) or XML (eXtensible Markup Language).

IoT(Internet of Things) 노드의 개발자로부터 제공되는 상기 IoT 노드에 대한 정보를 이용하여 IoT 프로파일을 생성하는 IoT 프로파일 생성부, 상기 IoT 프로파일을 저장 및 관리하는 IoT 프로파일 데이터베이스 및 상기 IoT 프로파일을 상기 개발자에게 제공하거나 또는 상기 IoT노드가 접속하는 인스턴스 호스팅 게이트웨이로 제공하는 IoT 프로파일 제공부를 포함하고, 상기 인스턴스 호스팅 게이트웨이에서, (1) 상기 인스턴스 호스팅 게이트웨이로 제공된 상기 IoT 프로파일, (2) 상기 개발자에게 제공되어 상기 개발자와 연관된 URL을 통해 제공되는 상기 IoT 프로파일 또는 (3) 상기 개발자에게 제공되어 상기 IoT 노드에 포함되는 상기 IoT 프로파일을 이용하여 상기 IoT 노드를 등록하는 것을 특징으로 하는 서비스 제공 시스템이 제공된다.An IoT profile generation unit for generating an IoT profile using information about the IoT node provided from a developer of an Internet of Things (IoT) node; an IoT profile database for storing and managing the IoT profile; (1) the IoT profile provided to the instance hosting gateway, (2) the IoT profile provided to the developer and provided to the instance hosting gateway provided by the IoT node, The IoT profile provided through the URL associated with the developer, or (3) the IoT node provided to the developer and included in the IoT node.

접속을 요청하는 IoT 노드, 상기 IoT노드의 개발자와 연관된 URL 또는 상기 IoT 노드의 IoT 프로파일을 생성하는 서버의 IoT 프로파일 데이터베이스를 통해 상기 IoT 노드의 상기 IoT 프로파일을 수신하는 IoT 프로파일 수신부 및 상기 IoT 프로파일에 기초하여 상기 접속을 요청하는 IoT 노드를 등록하는 IoT 노드 등록부를 포함하고, 상기 IoT 프로파일은, 상기 IoT 노드의 개발자에 의해 제공되는 상기 IoT 노드에 대한 정보 및 기설정된 XML 스키마 정의를 이용하여 상기 서버에서 생성되는 것을 특징으로 하는 인스턴스 호스팅 게이트웨이가 제공된다.An IoT profile receiving unit that receives the IoT profile of the IoT node through an IoT node requesting a connection, a URL associated with a developer of the IoT node or an IoT profile database of a server generating an IoT profile of the IoT node; And an IoT node registration unit for registering an IoT node requesting the connection based on the information about the IoT node provided by the developer of the IoT node and the predefined XML schema definition, And an instance hosting gateway is provided.

접속을 요청하는 IoT 노드, 상기 IoT노드의 개발자와 연관된 URL 또는 상기 IoT 노드의 IoT 프로파일을 생성하는 서버의 IoT 프로파일 데이터베이스를 통해 상기 IoT 노드의 상기 IoT 프로파일을 수신하는 단계, 상기 IoT 프로파일에 기초하여 상기 접속을 요청하는 IoT 노드를 등록하는 단계 및 상기 IoT 노드의 데이터스트림을 외부로 제공하기 위한 외부 API를 상기 IoT 프로파일을 이용하여 생성하는 단계를 포함하는 서비스 제공 방법이 제공된다.Receiving the IoT profile of the IoT node through an IoT node requesting a connection, a URL associated with a developer of the IoT node or an IoT profile database of a server generating an IoT profile of the IoT node; Registering an IoT node requesting the connection, and generating an external API for providing the data stream of the IoT node to the outside using the IoT profile.

IoT(Internet of Things), WoT(Web of Things) 또는 WoO(Web of Objects) 환경에서 이기종의 기기들이나 다양한 서비스들을 연동 또는 융합하여 관리하고, 통합적으로 서비스를 제공할 수 있다.In the Internet of Things (IOT), Web of Things (WoT), or Web of Objects (WoO) environments, heterogeneous devices and various services can be interlinked or fused to be managed and integrated.

도 1은 종래기술에 있어서, 기기에서 임베디드 웹 서버를 내장하고 있는 경우의 서비스 제공 방식을 도시한 도면이다.
도 2는 종래기술에 있어서, 제조사가 별도의 웹 서버를 온라인상에서 제공하는 경우의 서비스 제공 방식을 도시한 도면이다.
도 3은 본 발명의 일실시예에 있어서, 인스턴스 호스팅을 위한 전체 시스템 구조를 개괄적으로 도시한 일례이다.
도 4는 본 발명의 일실시예에 있어서, 인스턴스 호스팅 게이트웨이의 내부 구조의 일례를 설명하기 위한 블록도이다.
도 5는 본 발명의 일실시예에 있어서, 네트워크 어댑터의 일례를 설명하기 위한 블록도이다.
도 6은 본 발명의 일실시예에 있어서, 인스턴스 매니저의 일례를 설명하기 위한 블록도이다.
도 7은 본 발명의 일실시예에 있어서, 인스턴스 어플리케이션 서버의 일례를 설명하기 위한 블록도이다.
도 8은 본 발명의 다른 실시예에 있어서, 인스턴스 호스팅 플랫폼의 일례를 설명하기 위한 도면이다.
도 9는 본 발명의 다른 실시예에 있어서, 인스턴스 호스팅 플랫폼의 내부 구성을 설명하기 위한 블록도이다.
도 10은 본 발명의 일실시예에 있어서, IoT 프로파일의 생성 및 활용 과정의 일례를 도시한 도면이다.
도 11은 본 발명의 일실시예에 있어서, 외부 노출을 위한 오픈 API를 설정하기 위한 방법의 일례를 도시한 흐름도이다.
1 is a diagram illustrating a service providing method when an embedded web server is embedded in a device in the prior art.
2 is a diagram illustrating a service providing method when a manufacturer provides a separate web server on-line in the prior art.
FIG. 3 is an example of an overall system structure for instance hosting in an embodiment of the present invention.
4 is a block diagram for explaining an example of an internal structure of an instance hosting gateway, in an embodiment of the present invention.
5 is a block diagram for explaining an example of a network adapter in an embodiment of the present invention.
6 is a block diagram for explaining an example of an instance manager in an embodiment of the present invention.
7 is a block diagram for explaining an example of an instance application server according to an embodiment of the present invention.
8 is a diagram for explaining an example of an instance hosting platform in another embodiment of the present invention.
9 is a block diagram illustrating an internal configuration of an instance hosting platform in another embodiment of the present invention.
10 is a diagram illustrating an example of a process of creating and utilizing an IoT profile in an embodiment of the present invention.
11 is a flowchart illustrating an example of a method for setting an open API for external exposure in an embodiment of the present invention.

이하, 본 발명의 실시예를 첨부된 도면을 참조하여 상세하게 설명한다.DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS Hereinafter, embodiments of the present invention will be described in detail with reference to the accompanying drawings.

도 3은 본 발명의 일실시예에 있어서, 인스턴스 호스팅을 위한 전체 시스템 구조를 개괄적으로 도시한 일례이다. 도 3은 IoT 프로파일(IoT(Internet of Things) Profile)(310), IoT 노드(IoT Node)(320), 인스턴스 호스팅 게이트웨이(Instance Hosting Gateway)(330) 및 인스턴스 호스팅 플랫폼(Instance Hosting Platform)(340)을 도시하고 있다.FIG. 3 is an example of an overall system structure for instance hosting in an embodiment of the present invention. 3 illustrates an example of an IoT profile (IoT Profile) 310, an IoT node 320, an Instance Hosting Gateway 330, and an Instance Hosting Platform 340 ).

IoT 프로파일(310)은 IoT 노드(320)의 제조사나 개발자가 온라인상에서 제공하는 IoT 노드(320)에 대한 정보를 의미할 수 있다. 예를 들어, 이러한 IoT 프로파일(310)은 IoT 노드(320)에 대한 정보를 사용자가 수동으로 인스턴스 호스팅 게이트웨이(330)에 데이터를 입력해야 하는 불편함을 최소화하기 위해, 제조사나 개발자가 IoT 노드(320)에 대한 정보를 기정의된 XML(eXtensible Markup Language) 스킴(scheme)에 따라 처리하여 생성한 XML 파일을 의미할 수 있다.The IoT profile 310 may refer to information about the IoT node 320 provided by the manufacturer or the developer of the IoT node 320 on-line. For example, the IoT profile 310 may include information about the IoT node 320 such that the manufacturer or developer can use the IoT node 320 to minimize the inconvenience of manually entering data into the instance hosting gateway 330 320 may be an XML file generated by processing information according to a predetermined XML (extensible Markup Language) scheme.

이러한 IoT 프로파일(310)은 IoT 노드(320)에 대한 설명(Description)과 IoT 노드(320)의 동작에 관해 기술된 프로세스(Process)에 대한 식별자(일례로, 프로세스에 대한 정보가 포함된 문서의 URL)를 포함할 수 있다. 예를 들어, 프로세스는 별도의 파일(일례로, 확장자 '.js' 파일)로 온라인상에서 제공될 수 있으며, 프로세스에 대한 식별자는 이러한 파일의 위치를 나타내는 URL일 수 있다. 아래 표 1은 IoT 프로파일(310)이 포함할 수 있는 정보들의 일례를 나타내고 있다.The IoT profile 310 includes an identifier for the IoT node 320 and an identifier for the process described in relation to the operation of the IoT node 320 URL). For example, a process may be provided online with a separate file (e.g., an extension '.js' file), and the identifier for the process may be a URL that points to the location of such a file. Table 1 below shows an example of the information that the IoT profile 310 may include.

NameName DescriptionDescription 비고Remarks IoTProfileIDIoTProfileID IoT Profile이 위치한 고유 URLThe unique URL where the IoT Profile is located URI형식으로 표현Expressed in URI format IoTProfileVerIoTProfileVer IoT Profile의 버전Version of IoT Profile 'V'+'숫자 형식'으로 표현'V' + expressed as 'number format' IoTProfileDescIoTProfileDesc IoT Profile의 설명(Description)Description of IoT Profile IoTInputIoTInput IoT Node의 입력값(Input 기능을 제공하지 않는 인스턴스 노드의 경우에는 필요 없음), RESTful API 생성을 위한 정보Input values for IoT Node (not required for instance nodes that do not provide input functionality), information for creating RESTful APIs 데이터 지원 형식
- JSON
- XML
Data Support Format
- JSON
- XML
IoTOutputIoTOutput IOT Node의 출력값, RESTFUL API 생성을 위한 정보Output value of IOT Node, information for generating RESTFUL API IoTProcessIDIoTProcessID IoT Node의 프로세스 식별자Process identifier of IoT Node URI 형식으로 표현Expressed in URI format

IoT 노드(320)는 센서 기기와 같은 IoT 환경의 사물에 대응할 수 있으며, 'IoTNodeID'와 같은 자신의 식별자 정보를 제공할 수 있다. 만약, IoT 노드(320)가 스마트 기기와 같은 NC(Non-Constraint) 노드인 경우에는 IoT 노드(320)가 상술한 IoT 프로파일(310)을 직접 제공할 수도 있다.The IoT node 320 may correspond to objects of the IoT environment such as a sensor device, and may provide its own identifier information such as 'IoTNodeID'. If the IoT node 320 is an NC (Non-Constraint) node such as a smart device, the IoT node 320 may directly provide the IoT profile 310 described above.

도 3에서는 설명의 편의를 위해, 하나의 IoT 노드(320)와 IoT 노드(320)에 대한 하나의 IoT 프로파일(310)을 도시하고 있으나, IoT 환경에서는 다수의 IoT 노드들과 IoT 노드들 각각에 대한 IoT 프로파일들이 활용될 수 있음은 너무나 당연하다. 또한, 하나의 IoT 노드에 대한 복수의 IoT 프로파일들이 제공될 수도 있다.In FIG. 3, one IoT node 320 and one IoT profile 310 for the IoT node 320 are shown for convenience of explanation. However, in the IoT environment, a plurality of IoT nodes and IoT nodes It is quite natural that the IoT profiles can be utilized. Also, a plurality of IoT profiles for one IoT node may be provided.

하나의 IoT 노드와 인스턴스(instance)는 1:1, 1:N, N:1, N:M과 같이 다양하게 관계 지어질 수 있다. 또한, 인스턴스는 물리적인 IoT 노드가 없더라도, 프로세스의 형태로 존재 가능하며, 매시업(Mash-up) 프로세스 등과 같이 특정 장치와 연동되는 형태가 아닌 프로세스간 연동을 통해 인스턴스가 생성 및 연동될 수 있다. 예를 들어, 별도의 IoT 노드와 연결하지 않더라도 특정 프로세스가 인스턴스 호스팅 게이트웨이(330)에 설치(deploy)되어 동작함으로써, 인스턴스 호스팅 게이트웨이(330)에서 인스턴스가 생성될 수 있다. 본 명세서에서는 전반적으로 물리적인 장치로서 설명되는 IoT 노드(물리적 노드)와 본 발명의 실시예들에 따른 인스턴스 호스팅 게이트웨이간의 통신을 통해 IoT 노드로부터 수신되는 메시지를 개별 인스턴스와 연결하여 처리하는 실시예를 설명하고 있으나, 상술한 바와 같이, 적어도 하나의 IoT 노드는 물리적인 장치가 아닌 프로세스의 형태(프로세스 노드)로 존재할 수도 있다.One IoT node and instance can be related in various ways such as 1: 1, 1: N, N: 1, N: M. In addition, an instance may exist in the form of a process even if there is no physical IoT node, and an instance may be created and interworked through inter-process interactions, such as a mash-up process, rather than interworking with a specific device. For example, an instance can be created in the instance hosting gateway 330 by connecting a specific process to the instance hosting gateway 330 without deploying it to a separate IoT node. In the present specification, an example of processing a message received from an IoT node through a communication between an IoT node (physical node), which is generally described as a physical device, and an instance hosting gateway according to embodiments of the present invention, As described above, however, at least one IoT node may exist in the form of a process (process node) rather than a physical device.

또한, 센서 디바이스 또는 엑추에이터 등과 같은 물리적인 장치 없이 다수의 센서로부터 정보를 받아 이를 온라인상의 다른 웹 서비스 또는 어플리케이션과 연동 기능만을 제공하는 프로세스가 제공될 수도 있다. 예를 들어, 센서들의 정보와 소셜 서비스 또는 사용자가 이용하는 특정 어플리케이션의 상태 정보를 분석해 특정 결과를 제공하는 서비스의 경우, 해당 서비스를 동작시킬 별도의 프로세싱 환경이 필요하다. 이 경우, 본 발명의 실시예들에 따른 인스턴스 호스팅 게이트웨이에서 상기 프로세싱 환경을 제공해줄 수 있다.Also, a process may be provided that receives information from a plurality of sensors without providing a physical device such as a sensor device or an actuator, and provides only the interworking function with other web services or applications on-line. For example, in the case of a service providing a specific result by analyzing the information of the sensors and the status information of a specific application used by a user or a social service, a separate processing environment for operating the service is required. In this case, the instance hosting gateway according to embodiments of the present invention may provide the processing environment.

인스턴스 호스팅 게이트웨이(330)는 IoT 노드(320)로부터 수신되는 메시지를 개별 인스턴스와 연결해 처리하고, 사용자 또는 서비스의 요청에 따라 외부 서비스와 연동될 수 있다. 이러한 인스턴스 호스팅 게이트웨이(330)는 IoT 노드(320)를 위한 AP(Access Point) 환경에 탑재될 수 있다. 예를 들어, 인스턴스 호스팅 게이트웨이(330)는 AP에 탑재되어 웹 어플리케이션 서버(Web Application Server, WAS) 형태로 동작하는 인스턴스 어플리케이션 서버(Instance Application Server) 부분과 AP상에 소프트웨어 형태, 하드웨어 형태 또는 소프트웨어와 하드웨어의 결합 형태로 탑재(일례로, AP의 운영체제에 소프트웨어의 형태로 탑재되는 모듈과 IoT 노드(320)와의 통신을 위해 하드웨어의 형태로 탑재되는 모듈)되는 부분으로 구성될 수 있다.The instance hosting gateway 330 processes messages received from the IoT node 320 with individual instances and processes them, and can interact with external services upon request of a user or service. This instance hosting gateway 330 may be implemented in an Access Point (AP) environment for the IoT node 320. [ For example, the instance hosting gateway 330 may include an Instance Application Server portion mounted on the AP and operating in the form of a Web Application Server (WAS) (For example, a module mounted in the form of software in the operating system of the AP and a module mounted in the form of hardware for communication with the IoT node 320) in a combined form of hardware.

일례로, 인스턴스 호스팅 게이트웨이(330)는 특정 공간(일례로, 집안)에 설치된 AP에 포함될 수 있으며, 상기 특정 공간에 포함된 사물들(IoT 노드들)과 통신하여 데이터를 수신 및 처리하고, 외부 서비스와의 연동 서비스를 제공하기 위한 기능을 수행할 수 있다.For example, the instance hosting gateway 330 may be included in an AP installed in a specific space (e.g., a house), communicates with objects (IoT nodes) included in the specific space to receive and process data, And perform a function for providing an interworking service with the service.

이때, 인스턴스 호스팅 게이트웨이(330)는 새로운 IoT 노드(320)를 발견하면, IoT 프로파일(310)을 다운로드하여 설치할 수 있다. 예를 들어, 사용자는 IoT 프로파일(310)에 대응하는 XML 파일의 위치를 인스턴스 호스팅 게이트웨이(330)에 입력할 수 있으며, 인스턴스 호스팅 게이트웨이(330)는 입력된 위치에 기초하여 XML 파일을 다운로드하여 설치할 수 있다.At this time, if the instance hosting gateway 330 finds a new IoT node 320, the IoT profile 310 can be downloaded and installed. For example, the user can input the location of the XML file corresponding to the IoT profile 310 to the instance hosting gateway 330, and the instance hosting gateway 330 downloads and installs the XML file based on the input location .

이러한 인스턴스 호스팅 게이트웨이(330)에 대해서는 이후 도 4 내지 도 7을 통해 더욱 자세히 설명한다.This instance hosting gateway 330 will be described in more detail later with reference to FIGS.

인스턴스 호스팅 플랫폼(340)은 인스턴스간 상호 연동 기능과 매시업(Mash-up) 기능을 제공할 수 있다. 예를 들어, 인스턴스 호스팅 게이트웨이(330)는 사용자 또는 서비스의 요청에 따라 제공하기 위한 기능을 API(Application Program Interface) 형태로 외부로 제공하여 외부 서비스와 연동하기 위해, 인스턴스 호스팅 플랫폼(340)과 통신할 수 있다.The instance hosting platform 340 may provide inter-instance interworking and mash-up functionality. For example, the instance hosting gateway 330 may provide a function for providing a function for a user or a service upon request to the outside in the form of an API (Application Program Interface) and communicate with the instance hosting platform 340 can do.

도 4는 본 발명의 일실시예에 있어서, 인스턴스 호스팅 게이트웨이의 내부 구조의 일례를 설명하기 위한 블록도이다. 본 실시예에 따른 인스턴스 호스팅 게이트웨이(330)는 도 4에 도시된 바와 같이 네트워크 어댑터(Network Adaptor)(410), 네트워크 핸들러(Network Handler)(420), 인스턴스 매니저(Instance Manager)(430) 및 인스턴스 어플리케이션 서버(Instance Application Server)(440)를 포함할 수 있다.4 is a block diagram for explaining an example of an internal structure of an instance hosting gateway, in an embodiment of the present invention. The instance hosting gateway 330 according to the present embodiment includes a network adapter 410, a network handler 420, an instance manager 430, and an instance An application server 440, and the like.

네트워크 어댑터(410)는 인스턴스 호스팅 게이트웨이(330)가 지원하는 네트워크 인터페이스 규격을 통해 IoT 노드와 유무선을 통해 물리적으로 연결하는 기능을 제공할 수 있다. 예를 들어, 네트워크 어댑터(410)는 지그비(Zigbee), 블루투스(Bluetooth), 지웨이브(Z-wave), 이더넷(Ethernet), 와이파이(Wi-Fi)와 같은 무선 랜, USB(Universal Serial Bus) 등과 같이 다양한 형태의 네트워크 연동을 위한 어댑터 기능을 제공할 수 있으며, 각각의 네트워크 인터페이스 규격에 따른 메시지 처리를 위해, 메시지 파싱 기능이 추가적으로 제공될 수 있다.The network adapter 410 may provide a function of physically connecting to the IoT node through a wired or wireless network through a network interface standard supported by the instance hosting gateway 330. For example, the network adapter 410 may be a wireless LAN such as Zigbee, Bluetooth, Z-wave, Ethernet, Wi-Fi, USB (Universal Serial Bus) And the like. In addition, a message parsing function may be additionally provided for message processing according to each network interface standard.

특히, IoT 환경에서 IoT 노드들은 각각의 특성에 따라 다양한 메시지 포맷을 사용하기 때문에 지그비, 블루투스, 지웨이브 등과 같은 근접 네트워크 인터페이스 기술을 사용하는 경우, 네트워크 어댑터(410)는 개별 네트워크 인터페이스 특성에 따라 IoT 노드들로부터 수신한 메시지 데이터를 인스턴스별 포맷에 알맞게 구조화하는 기능을 더 제공할 수 있다.In particular, in the IoT environment, the IoT nodes use various message formats according to their respective characteristics. Therefore, when the proximity network interface technology such as Zigbee, Bluetooth, GeWave, etc. is used, It is possible to further provide a function of structuring the message data received from the nodes according to the instance-specific format.

이러한 네트워크 어댑터(410)에 대해서는 이후 도 5를 통해 더욱 자세히 설명한다.Such a network adapter 410 will be described later in more detail with reference to FIG.

네트워크 핸들러(420)는 네트워크 어댑터(410)로부터 수신된 메시지를 인스턴스 매니저(430)로 전달할 수 있다. 또한, 네트워크 핸들러(420)는 네트워크 어댑터(410)가 지그비를 이용하는 경우, 인스턴스별 포맷에 알맞게 구조화된 메시지 값에 대해, 시스템에서 부여한 인스턴스 식별자(Instance ID)를 추가하는 기능을 수행할 수 있다.The network handler 420 may forward the message received from the network adapter 410 to the instance manager 430. In addition, when the network adapter 410 uses ZigBee, the network handler 420 may perform a function of adding an instance ID (Instance ID) assigned by the system to a message value structured in accordance with the instance-specific format.

인스턴스 매니저(430)는 인스턴스 호스팅을 위한 핵심 기능을 담당하는 모듈로, IoT 프로파일 및 프로세스를 설치(deploy)하는 기능을 제공할 수 있으며, 개별 IoT 노드들의 메시지를 인스턴스로 연동하는 역할 및 각각의 과정들을 로깅하는 역할을 수행할 수 있다.The instance manager 430 is a module for performing core functions for instance hosting and can provide a function of deploying IoT profiles and processes. The role of interworking messages of individual IoT nodes with instances, And the like.

이러한 인스턴스 매니저(430)에 대해서는 이후 도 6을 통해 더욱 자세히 설명한다. The instance manager 430 will be described later in more detail with reference to FIG.

인스턴스 어플리케이션 서버(440)는 인스턴스 호스팅 게이트웨이(330)의 웹 어플리케이션 서버 기능을 담당할 수 있다. 이때, 인스턴스 어플리케이션 서버(440)를 통해 제공되는 기능들은 웹 인터페이스로 제공될 수 있다.The instance application server 440 may be responsible for the web application server function of the instance hosting gateway 330. At this time, the functions provided through the instance application server 440 may be provided as a web interface.

이러한 인스턴스 어플리케이션 서버(440)에 대해서는 이후 도 7을 통해 더욱 자세히 설명한다.The instance application server 440 will be described later in more detail with reference to FIG.

도 5는 본 발명의 일실시예에 있어서, 네트워크 어댑터의 일례를 설명하기 위한 블록도이다. 본 실시예에 따른 네트워크 어댑터(410)는 지그비(Zigbee), 블루투스(Bluetooth), 지웨이브(Z-wave), 이더넷(Ethernet), 와이파이(Wi-Fi)와 같은 무선 랜, USB(Universal Serial Bus) 등과 같이 다양한 형태의 네트워크 연동을 위한 어댑터 기능을 제공할 수 있다. 또한, 네트워크 어댑터(410)는 각각의 인터페이스별, 인터페이스 내 장치 별로 메시지를 구분하여 수신되는 데이터의 완결성을 보장하기 위한 기능을 제공할 수 있으며, 각각의 네트워크 인터페이스 규격에 따른 메시지 처리를 위해, 메시지 파싱 기능을 제공하기 위한 메시지 파서(510)를 포함할 수 있다.5 is a block diagram for explaining an example of a network adapter in an embodiment of the present invention. The network adapter 410 according to the present embodiment may be a wireless LAN such as Zigbee, Bluetooth, Z-wave, Ethernet, Wi-Fi, ), And the like, can be provided. In addition, the network adapter 410 may provide a function for ensuring the integrity of data received by distinguishing messages for each interface and for each device in the interface. In order to process messages in accordance with each network interface standard, And a message parser 510 for providing a parsing function.

메시지 파서(510)는 인스턴스 설치(deploy) 과정에서 개별 인스턴스와 연결된 메시지의 구조 정보를 얻기 위해 이용될 수 있다. 이때, 메시지 파서(510)는 개별 단말 장치(IoT 노드)가 제공하는 메시지 포맷에 따라 메시지를 파싱할 수 있다. 일례로, 동일한 지그비 네트워크 인터페이스를 이용하는 기기들간에도 각기 서로 다른 메시지 포맷이 이용될 수 있다.The message parser 510 may be used to obtain structure information of a message associated with an individual instance during an instance deployment. At this time, the message parser 510 can parse the message according to the message format provided by the individual terminal device (IoT node). For example, different message formats may be used between devices using the same ZigBee network interface.

도 6은 본 발명의 일실시예에 있어서, 인스턴스 매니저의 일례를 설명하기 위한 블록도이다. 본 실시예에 따른 인스턴스 매니저(430)는 메시지 라우터(Message Router)(610), 로더(Loader)(620), 업데이터(Updater)(630), 디플로이어(Deployer)(640), 인스턴스 라이프사이클 컨트롤러(Instance Lifecycle Controller)(650) 및 로거(Logger)(660)를 포함할 수 있다. 또한, 도 4에서 설명한 인스턴스 호스팅 게이트웨이(330)는 필요에 따라 데이터베이스(Simple DB)(670) 및 자바스크립트 엔진(JavaScript Engine)(680)을 더 포함할 수 있다.6 is a block diagram for explaining an example of an instance manager in an embodiment of the present invention. The instance manager 430 according to the present embodiment includes a message router 610, a loader 620, an updater 630, a deployer 640, A controller (Instance Lifecycle Controller) 650 and a logger (Logger) 660. In addition, the instance hosting gateway 330 described in FIG. 4 may further include a database (Simple DB) 670 and a JavaScript engine (JavaScript engine) 680 as needed.

메시지 라우터(610)는 도 4를 통해 설명한 네트워크 핸들러(420) 또는 인스턴스 어플리케이션 서버(440) 등으로부터 요청 받은 메시지를 라우팅하는 역할을 수행할 수 있다. 이때, 기본적으로, 메시지 라우터(610)의 모든 트랜잭션(transaction)은 로깅(logging)될 수 있다.The message router 610 may route the requested message from the network handler 420 or the instance application server 440 described with reference to FIG. At this time, basically, all the transactions of the message router 610 can be logged.

로더(620)는 인스턴스 별로 프로세스를 처리할 때, 개별 인스턴스를 호출하는 역할을 수행할 수 있다. 또한, 로더(620)는 메시지 기반 호출 이외에, 타이머 기반 자체 호출되어야 하는 인스턴스들에 대한 호출 기능 역시 제공할 수 있다. 예를 들어, 로더(620)는 인스턴스 프로세스를 호출함에 있어, 수신된 데이터가 호출해야 할 개별 프로세스의 메서드(method)를 매칭하여 자바스크립트 엔진(680)을 호출하는 기능을 제공할 수 있다. 이를 위해, 로더(620)는 메시지 파라미터별로 호출 메서드를 결정하는 기능을 제공할 수 있다.The loader 620 may be responsible for calling individual instances when processing a process instance by instance. In addition to the message based call, the loader 620 may also provide a call function for instances that must be self-called based on a timer. For example, the loader 620 may provide the ability to invoke the JavaScript engine 680 in invoking the instance process by matching the methods of the individual processes that the received data should invoke. To this end, the loader 620 may provide a function for determining a calling method for each message parameter.

업데이터(630)는 외부에 존재하는 IoT 프로파일 및 프로세스 정보를 인스턴스 호스팅 게이트웨이(330)로 다운로드하는 기능을 수행할 수 있다.The updater 630 may perform the function of downloading the externally existing IoT profile and process information to the instance hosting gateway 330.

디플로이어(640)는 IoT 프로파일의 정보를 파싱하고, 프로세스 정보를 인스턴스 매니저(430)에 등록하는 역할을 수행할 수 있다. 개별 IoT 프로파일과 프로세스 정보는 디플로이 과정을 통해, 정식적으로 인스턴스 호스팅 서비스로서 이용될 수 있다.The deployer 640 can perform the role of parsing the information of the IoT profile and registering the process information in the instance manager 430. Individual IoT profiles and process information can be formally used as instance hosting services through the deployment process.

인스턴스 라이프사이클 컨트롤러(650)는 인스턴스의 생애주기를 관리하는 기능을 제공하는 모듈로, 로더(620), 업데이터(630) 및 디플로이어(640)를 제어하기 위한 기능을 제공할 수 있다. 일례로, 인스턴스 라이프사이클 컨트롤러(650)는 인스턴스 매니저(430)의 기능들 제어할 수 있으며, 이후 설명될 인스턴스 관리부(Instance Mgmt.)와의 접점 기능을 제공할 수 있다.The instance life cycle controller 650 is a module that provides a function of managing the life cycle of an instance and can provide functions for controlling the loader 620, the updater 630, and the deployer 640. For example, the instance lifecycle controller 650 may control the functions of the instance manager 430 and may provide a contact function with an instance management unit (Instance Mgmt.) To be described later.

로거(660)는 인스턴스 매니저(430)에서 일어나는 데이터 입출력 및 어플리케이션 작동 정보를 로깅하는 기능을 제공할 수 있다.The logger 660 may provide a function to log data input / output and application operating information occurring in the instance manager 430. [

데이터베이스(670)는 IoT 노드의 데이터를 저장할 수 있다. The database 670 may store data of the IoT node.

자바스크립트 엔진(680)는 자바스크립트를 처리할 수 있다. 예를 들어, IoT 노드의 인스턴스 프로세스는 자바스크립트의 구문에 따라 처리될 수 있으며, 브라우저에서 실행되는 웹 환경의 스크립트와는 달리 독립적인 프로그래밍용 언어로서 활용될 수 있다. 이때, 자바스크립트 엔진(680)은 이러한 프로세스의 자바스크립트 구문을 처리하기 위해 이용될 수 있다. 다른 예로, 인스턴스 어플리케이션 서버(440)의 각각의 기능이 자바스크립트를 기반으로 동작할 수 있다.The JavaScript engine 680 may process JavaScript. For example, the instance process of an IoT node can be handled according to the syntax of JavaScript, and can be used as a standalone programming language, unlike scripts in the Web environment running in a browser. At this time, the JavaScript engine 680 may be used to process the JavaScript syntax of this process. As another example, each function of the instance application server 440 may be based on JavaScript.

도 7은 본 발명의 일실시예에 있어서, 인스턴스 어플리케이션 서버의 일례를 설명하기 위한 블록도이다. 본 실시예에 따른 인스턴스 어플리케이션 서버(440)는 도 7에 도시된 바와 같이, API 노출부(API Exposure)(710) 및 관리 포털(Management Portal)(720)을 포함할 수 있다.7 is a block diagram for explaining an example of an instance application server according to an embodiment of the present invention. The instance application server 440 according to the present embodiment may include an API Exposure 710 and a Management Portal 720 as shown in FIG.

API 노출부(710)는 인스턴스 호스팅 게이트웨이(330)가 제공하는 기능을 API 형태로 외부로 제공하는 기능을 수행할 수 있다. 이때, API 노출부(710)는 도 7에 도시된 바와 같이 레스트풀 관리부(RESTful)(711), 피더(Feeder)(712), API 트리거(API Trigger)(713), 키 생성부(Key Generator)(714) 및 인증부(OAuth)(715)를 포함할 수 있다.The API-exposing unit 710 can perform a function of externally providing functions provided by the instance hosting gateway 330 in an API form. 7, the API exposure unit 710 includes a rest pool management unit 711, a feeder 712, an API trigger 713, a key generator 713, ) 714 and an authentication unit (OAuth) 715.

레스트풀 관리부(711)은 IoT 프로파일의 정보를 바탕으로 IoT 노드 인스턴스의 입력값, 출력값을 레스트풀 관리부(711)의 인터페이스로 제공하는 역할을 수행할 수 있다.The rest pool management unit 711 can provide the input value and the output value of the IoT node instance to the interface of the rest pool management unit 711 based on the information of the IoT profile.

피더(712)는 IoT 프로파일의 정보를 바탕으로 IoT 노드 인스턴스의 출력값을 피드(feed) 형태로 제공할 수 있다. 이때, 피드 형태로 제공되는 형식은 JSON(JavaScript Object Notation) 및 XML 중 적어도 하나의 형식을 따를 수 있다.The feeder 712 may provide the output value of the IoT node instance in the form of a feed based on the information of the IoT profile. At this time, the format provided in the form of a feed may follow the format of at least one of JavaScript Object Notation (JSON) and XML.

API 트리거(713)는 써드 파티(3rd party) API와 같은 외부 API를 트리거링하는 기능을 제공할 수 있다. 이때, API 트리거(713)는 메시지가 인스턴스의 서비스 특성에 따른 API 트리거링 기능을 포함하는 경우, 해당 API로 메시지를 전달(push)할 수 있다.API trigger 713 may provide the ability to trigger an external API, such as third-party (3 rd party) API. At this time, if the message includes an API triggering function according to the service characteristic of the instance, the API trigger 713 can push a message to the API.

키 생성부(714)는 외부 서비스들과의 연동을 위해, 접근 인증을 제어하기 위한 키 생성 기능을 제공할 수 있다.The key generation unit 714 may provide a key generation function for controlling access authentication for interworking with external services.

인증부(715)는 외부 서비스들과 연동시 인증을 위한 기능을 제공할 수 있다. 예를 들어, 인증부(715)는 키 생성부(714)에서 생성된 키를 이용하여 외부 서비스들에 대한 인증을 수행할 수 있다.The authentication unit 715 may provide a function for authentication when interworking with external services. For example, the authentication unit 715 may perform authentication for external services using the key generated by the key generation unit 714. [

관리 포털(720)은 인스턴스 호스팅 게이트웨이(330)의 기능을 사용자가 웹이나 어플리케이션을 통해 조작하기 위한 기능을 제공할 수 있다. 이때, 관리 포털(720)은 도 7에 도시된 바와 같이, 사용자 관리부(User Mgmt.)(721), 인스턴스 관리부(Instance Mgmt.)(722), 시스템 관리부(System Mgmt.)(723) 및 API 관리부(API Mgmt.)(724)를 포함할 수 있다.The management portal 720 may provide functionality for the user to manipulate the functionality of the instance hosting gateway 330 through a web or application. 7, the management portal 720 includes a user management unit 721, an instance management unit 722, a system management unit 723, (API Mgmt.) 724, as shown in FIG.

사용자 관리부(721)는 사용자 계정 관리 기능(사용자 인터페이스)을 웹 형태로 제공할 수 있다.The user management unit 721 can provide a user account management function (user interface) in a web form.

인스턴스 관리부(722)는 인스턴스 관리 기능(사용자 인터페이스)을 웹 형태로 제공할 수 있다.The instance management unit 722 can provide an instance management function (user interface) in a web form.

시스템 관리부(723)는 시스템 관리 기능(사용자 인터페이스)을 웹 형태로 제공할 수 있다.The system management unit 723 can provide a system management function (user interface) in a web form.

API 관리부(724)는 API 관리 기능(사용자 인터페이스)을 웹 형태로 제공할 수 있다. The API management unit 724 can provide an API management function (user interface) in the form of a web.

이미 설명한 바와 같이, 본 실시예에 따른 인스턴스 호스팅 게이트웨이(330)를 구성하는 요소들의 적어도 일부는 소프트웨어 형태로 구현될 수 있다. 이 경우, 이러한 적어도 일부는 복수의 모듈을 포함하는 어플리케이션의 형태로 제공될 수 있으며, 이러한 어플리케이션의 설치를 위해 파일을 제공하는 파일 배포 시스템이 제공될 수 있다. 일실시예로, 어플리케이션은, 복수의 노드들과 유무선 네트워크를 통해 연결하여 복수의 노드들로부터 데이터를 수신하는 모듈 및 복수의 노드들에 대해 제공되는 프로파일들 및 프로세스들을 이용하여 복수의 노드들 중 적어도 둘 이상의 노드들로부터 수신된 데이터를 하나의 인스턴스로 연동하여 처리하는 모듈을 포함할 수 있다. 다른 실시예로, 이러한 어플리케이션은 복수의 노드들이 연결되는 액세스 포인트(Access Point, AP)에 설치될 수 있다. 이러한 모듈들은, 인스턴스 호스팅 게이트웨이(330)를 구성하는 요소들 중 어떠한 요소들이 소프트웨어 형태로 구현되는가에 따라 달라질 수 있다.As described above, at least some of the elements constituting the instance hosting gateway 330 according to the present embodiment may be implemented in software form. In this case, at least a part thereof may be provided in the form of an application including a plurality of modules, and a file distribution system for providing a file for installation of such an application may be provided. In one embodiment, the application includes a module for connecting through a wired or wireless network with a plurality of nodes to receive data from a plurality of nodes and a module for receiving data from a plurality of nodes using profiles and processes provided for the plurality of nodes. And a module for interworking and processing data received from at least two nodes in one instance. In another embodiment, such an application may be installed in an access point (AP) to which a plurality of nodes are connected. These modules may vary depending on which of the elements constituting the instance hosting gateway 330 is implemented in software.

또한, 본 실시예에 따른 인스턴스 호스팅 게이트웨이(330)가 수행하는 단계들이 포함된 서비스 제공 방법이 제공될 수 있다. 예를 들어, 서비스 제공 방법은 복수의 노드들과 유무선 네트워크를 통해 연결하여 복수의 노드들로부터 데이터를 수신하는 단계, 복수의 노드들에 대해 제공되는 프로파일들 및 프로세스들을 이용하여 복수의 노드들 중 적어도 둘 이상의 노드들로부터 수신된 데이터를 하나의 인스턴스로 연동하여 처리하는 단계 및 처리의 결과를 웹이나 어플리케이션을 통해 사용자에게 제공하는 단계를 포함할 수 있다. 다른 실시예로, 적어도 둘 이상의 노드들로부터 수신된 데이터를 하나의 인스턴스로 연동하여 처리하는 단계는 인스턴스 별로 프로세스를 처리하기 위해, 개별 인스턴스를 호출하는 단계 및 개별 인스턴스의 생애주기를 관리하는 기능을 제공하는 단계를 포함할 수 있다.In addition, a service providing method including the steps performed by the instance hosting gateway 330 according to the present embodiment may be provided. For example, a method of providing a service may include connecting to a plurality of nodes via a wired or wireless network to receive data from a plurality of nodes, using profiles and processes provided for the plurality of nodes, Processing the data received from at least two or more nodes in a single instance and processing the result, and providing the result of the processing to the user via the web or application. In another embodiment, the step of processing the data received from at least two nodes in one instance in an interlocked manner includes the steps of calling the individual instance to process the instance by instance and managing the life cycle of the individual instance And the like.

도 8은 본 발명의 다른 실시예에 있어서, 인스턴스 호스팅 플랫폼의 일례를 설명하기 위한 도면이다. 도 3의 실시예에서 설명한 인스턴스 호스팅 플랫폼(340)은 특정 공간내의 AP에 탑재된 인스턴스 호스팅 게이트웨이(330)로부터 온라인을 통해 API를 제공받아 처리하여, 인스턴스간 상호 연동 기능과 매시업(Mash-up) 기능을 제공하였다. 도 8에서 설명하는 다른 실시예에 따른 인스턴스 호스팅 플랫폼(800)은 도 3의 인스턴스 호스팅 게이트웨이(330)와 인스턴스 호스팅 플랫폼(340)이 결합된 형태로, 온라인상에서 서비스를 제공할 수 있다.8 is a diagram for explaining an example of an instance hosting platform in another embodiment of the present invention. The instance hosting platform 340 described in the embodiment of FIG. 3 receives and processes APIs on-line from the instance hosting gateway 330 installed in an AP in a specific space, and performs inter-instance interworking functions and mash- Function. The instance hosting platform 800 according to another embodiment illustrated in FIG. 8 may provide a service on-line in the form of a combination of the instance hosting gateway 330 and the instance hosting platform 340 of FIG.

도 8의 인스턴스 호스팅 플랫폼(800)은 외부와의 연결을 위한 구성요소들로서 인스턴스 호스팅 매니저(Instance Hosting Manager)(810), 제1 네트워크 어댑터(HTTP Adaptor)(820) 및 제2 네트워크 어댑터(HTTP Adaptor)(830)를 포함할 수 있다. 인스턴스 호스팅 플랫폼(800)이 포함할 수 있는 다른 구성요소들에 대해서는 도 9를 통해 더욱 자세히 설명한다.The instance hosting platform 800 of FIG. 8 includes components for connection to the outside, such as an instance hosting manager 810, a first network adapter 820 and a second network adapter 820. [ 830 < / RTI > Other components that the instance hosting platform 800 may include are described in more detail in FIG.

인스턴스 호스팅 매니저(810)는 엔드 유저(End User)와 연결하기 위한 기능을 제공할 수 있다. 엔드 유저는 IoT 노드들의 사용자들이 이용하는 단말기를 의미할 수 있으며, 단말기에 설치된 적어도 하나의 웹브라우저와 적어도 하나의 어플리케이션을 통해 인스턴스 호스팅 플랫폼(800)과 통신할 수 있다.The instance hosting manager 810 may provide a function for connecting with an end user. The end user may refer to a terminal used by users of the IoT nodes and may communicate with the instance hosting platform 800 through at least one web browser and at least one application installed in the terminal.

제1 네트워크 어댑터(820)는 소셜 네트워크 서비스나 지도 서비스, 날씨 서비스 등과 같이 다양한 외부 서비스들을 나타내는 개인 인스턴스들(Personal Instances)과의 연결을 위한 기능을 제공할 수 있다. 예를 들어, 제1 네트워크 어댑터(820)는 다양한 외부 서비스들을 제공하는 서버들과의 연결을 위해 이용될 수 있다. 외부 서비스에 따른 인스턴스의 정보는 서비스별로 개별적인 형태로 존재할 수 있다.The first network adapter 820 may provide functionality for connection to personal instances representing various external services such as social network services, map services, weather services, and the like. For example, the first network adapter 820 may be used for connections with servers that provide various external services. The information of the instance according to the external service may exist in the form of individual service.

제2 네트워크 어댑터(830)는 다양한 IoT 노드들과 연결하기 위한 기능을 포함할 수 있다. 예를 들어, 인스턴스 호스팅 플랫폼(800)은 도 1 및 도 2를 통해 각각 설명한 기기들(130 및 220)과 같이 다양한 형태로 서비스를 제공하는 기존의 IoT 노드들과도 연동하여 서비스를 제공하는 것이 가능할 수 있다.The second network adapter 830 may include functionality for coupling with various IoT nodes. For example, the instance hosting platform 800 may provide services in cooperation with existing IoT nodes that provide services in various forms, such as the devices 130 and 220, respectively, illustrated in FIGS. 1 and 2 It can be possible.

도 9는 본 발명의 다른 실시예에 있어서, 인스턴스 호스팅 플랫폼의 내부 구성을 설명하기 위한 블록도이다. 본 실시예에 따른 인스턴스 호스팅 플랫폼(800)은 도 8에서 설명한 구성요소들 이외에, 인스턴스 업데이트 매니저(Instance Update Manager)(840), 인스턴스 버스(Instance BUS)(850), 인스턴스 풀(Instance Pool)(860), 인스턴스 로거(Instance Logger)(870), 인스턴스 모니터(Instance Monitor)(880) 및 인스턴스 라이프사이클 매니저(Instance Lifecycle Manager)(890)를 더 포함할 수 있다.9 is a block diagram illustrating an internal configuration of an instance hosting platform in another embodiment of the present invention. The instance hosting platform 800 according to the present embodiment includes an instance update manager 840, an instance BUS 850, an instance pool (not shown) 860, an Instance Logger 870, an Instance Monitor 880, and an Instance Lifecycle Manager 890.

인스턴스 업데이트 매니저(840)는 인스턴스 호스팅 프로파일(Instance Hosting Profile) 및 개인 인스턴스 프로파일(Personal Instance Profile)을 다운로드, 갱신, 저장 및 관리하는 기능을 수행할 수 있다. 인스턴스 호스팅 프로파일은 이미 설명한 IoT 프로파일에 대응할 수 있으며, 개별 인스턴스 프로파일은 도 8에서 설명한 개별 인스턴스들에 대한 프로파일을 포함할 수 있다. 예를 들어, 개별 인스턴스들에 대한 프로파일은 외부 서비스를 제공하는 제공자나 개발자에 의해 제공될 수 있다.The instance update manager 840 can perform functions of downloading, updating, storing, and managing an instance hosting profile and a personal instance profile. The instance hosting profile may correspond to the IoT profile already described, and the individual instance profile may include a profile for the individual instances described in FIG. For example, a profile for individual instances may be provided by a provider or developer providing external services.

인스턴스 버스(850)는 인스턴스들간의 메시지 버스 기능을 제공할 수 있다. 예를 들어, 이후 설명될 인스턴스 풀(860)에 저장된 IoT 노드(130)의 데이터 'D1'이 IoT 노드(220)와 통신하는 웹 서버(210)의 요청에 따라 인스턴스 버스(850)를 통해 제공될 수 있다. 또한, 인스턴스 버스(850)는 인스턴스 상호간의 인증 기능을 제공할 수도 있다.The instance bus 850 may provide message bus functionality between instances. For example, the data 'D1' of the IoT node 130 stored in the instance pool 860 to be described later is provided through the instance bus 850 in response to a request from the web server 210 in communication with the IoT node 220 . The instance bus 850 may also provide mutual authentication functionality.

인스턴스 풀(860)은 인스턴스들의 실행 환경을 의미할 수 있으며, 인스턴스들이 실행되는 공간으로, 개별 프로세스들이 설치(deploy)되는 공간을 의미할 수 있다. 부가적으로, 인스턴스를 로드하고, 저장하고, 인스턴스들과 인스턴스 풀(860)을 관리하기 위한 기능들을 제공할 수 있다. 인스턴스 풀(860)은 인스턴스의 특성에 따라, 타이머 등을 이용하여 웨이크업(wake-up) 형태로 인스턴스를 처리할 수도 있다. 이러한 인스턴스 풀(860)에는 인스턴스 버스(850)를 통해 다양한 IoT 노드들에 대한 데이터가 전달될 수 있기 때문에, 이기종의 또는 서로 다른 프로토콜을 활용하는 IoT 노드들로부터 전송된 데이터들도 연동 및 융합하여 서비스를 제공하는 것이 가능해진다.The instance pool 860 may refer to an execution environment of the instances, and may be a space where the instances are executed, which means a space where individual processes are deployed. Additionally, it can provide functions for loading and storing instances, and managing instances and instance pool 860. The instance pool 860 may process an instance in a wake-up form using a timer or the like, depending on the characteristics of the instance. Since data for various IoT nodes can be transferred to the instance pool 860 via the instance bus 850, data transmitted from IoT nodes using heterogeneous or different protocols can be interlocked and fused It becomes possible to provide a service.

인스턴스 로거(870)는 인스턴스와 관련된 메시지의 로깅을 처리할 수 있다.Instance logger 870 can handle logging of messages associated with the instance.

인스턴스 모니터(880)는 인스턴스의 정상 동작 여부를 모니터링할 수 있다.The instance monitor 880 may monitor whether the instance is operating normally.

인스턴스 라이프사이클 매니저(890)는 인스턴스의 주기적/반복적 동작 기능을 관리할 수 있다.The instance lifecycle manager 890 can manage the periodic / repetitive operation function of the instance.

또한, 본 실시예에 따른 인스턴스 호스팅 플랫폼(800)가 수행하는 단계들이 포함된 서비스 제공 방법이 제공될 수 있다. 예를 들어, 서비스 제공 방법은 임베디드 웹 서버를 탑재한 노드 또는 웹 서버를 중계하여 연결된 노드를 통해 데이터를 수신하는 단계, 데이터를 인스턴스들간에 교환하는 단계 및 노드들에 대해 제공되는 프로파일들 및 프로세스들을 이용하여 복수의 노드들 중 적어도 둘 이상의 노드들로부터 수신된 데이터를 하나의 인스턴스로 연동하여 처리하는 단계를 포함할 수 있다. 다른 실시예로, 서비스 제공 방법은 프로파일들 및 개인 인스턴스 프로파일들을 다운로드 및 관리하는 단계 및 개인 인스턴스 프로파일을 이용하여 웹 서비스를 포함하는 외부 서비스와 연결하는 단계를 더 포함할 수 있다.In addition, a service providing method including steps performed by the instance hosting platform 800 according to the present embodiment may be provided. For example, a service providing method includes relaying a node or a web server equipped with an embedded Web server to receive data through a connected node, exchanging data between instances, and providing profiles and processes And processing data received from at least two of the plurality of nodes in a single instance by using the plurality of nodes. In another embodiment, the method of providing a service may further include downloading and managing profiles and personal instance profiles, and associating with an external service including a web service using a personal instance profile.

이후에서는 IoT 프로파일에 대해 보다 구체적으로 설명한다.Hereinafter, the IoT profile will be described in more detail.

도 10은 본 발명의 일실시예에 있어서, IoT 프로파일의 생성 및 활용 과정의 일례를 도시한 도면이다. 도 10은 서비스 제공자 시스템(1010)과 개발자 시스템(1020)를 도시하고 있다.10 is a diagram illustrating an example of a process of creating and utilizing an IoT profile in an embodiment of the present invention. FIG. 10 shows a service provider system 1010 and a developer system 1020.

서비스 제공자 시스템(1010)은 인스턴스 호스팅 게이트웨이의 서비스를 제공하는 서비스 제공자의 시스템일 수 있으며, 개발자 시스템(1020)은 IoT 노드의 개발자(또는 개발사)가 이용하는 시스템일 수 있다. 예를 들어, 서비스 제공자 시스템(1010)은 서비스 제공자가 IoT 프로파일을 생성 및 관리하기 위해 제공하는 서버일 수 있고, 개발자 시스템(1020)은 상기 서버가 제공하는 웹사이트에 접속하기 위해 개발자가 이용하는 클라이언트 단말기일 수 있다.The service provider system 1010 may be a system of a service provider providing the service of the instance hosting gateway, and the developer system 1020 may be a system used by the developer (or developer) of the IoT node. For example, the service provider system 1010 may be a server that the service provider provides to create and manage an IoT profile, and the developer system 1020 may be a client used by the developer to access a web site provided by the server Lt; / RTI >

개발자는 개발자 시스템(1020)을 이용하여 서비스 제공자 시스템(1010)이 제공하는 웹사이트에 접속하여 IoT 노드에 대한 정보를 입력할 수 있다.The developer can access the website provided by the service provider system 1010 using the developer system 1020 to input information about the IoT node.

이때, 서비스 제공자 시스템(1010)은 웹사이트를 통해 수신되는 IoT 노드에 대한 정보를 이용하여 IoT 프로파일을 생성할 수 있다. 예를 들어, 서비스 제공자 시스템(1010)은 IoT 프로파일 생성부(1011)를 포함할 수 있고, 수신된 IoT 노드에 대한 정보와 XML 스키마 정의(XML Schema Definition, XSD)를 이용하여 IoT 프로파일 생성부(1011)에서 IoT 프로파일이 생성될 수 있다.At this time, the service provider system 1010 can generate the IoT profile using the information about the IoT node received through the website. For example, the service provider system 1010 may include an IoT profile generation unit 1011, and the IoT profile generation unit 1011 may use the information about the received IoT node and the XML Schema Definition (XSD) 0.0 > 1011). ≪ / RTI >

생성된 IoT 프로파일은 서비스 제공자 시스템(1010)에 저장 및 관리될 수 있다. 예를 들어, 서비스 제공자 시스템(1010)은 IoT 프로파일 데이터베이스(1012)를 포함할 수 있고, 생성된 IoT 프로파일은 IoT 프로파일 데이터베이스(1012)에 저장되어 관리될 수 있다. IoT 프로파일 데이터베이스(1012)는 일례로, 웹 서비스를 등록하고 검색하기 위한 저장소인 UDDI(Universal Description Discovery and Integration)로 구현될 수 있다. 또한, 생성된 IoT 프로파일은 개발자 시스템(1020)으로도 제공될 수 있다.The generated IoT profile may be stored and managed in the service provider system 1010. For example, the service provider system 1010 may include an IoT profile database 1012, and the generated IoT profiles may be stored and managed in the IoT profile database 1012. [ The IOT profile database 1012 can be implemented as a Universal Description Discovery and Integration (UDDI), which is a repository for registering and searching Web services. The generated IoT profile may also be provided to the developer system 1020.

개발자에 의해 제공되는 IoT 노드에 대한 정보는 일례로, 아래 표 2와 같은 정보들을 포함할 수 있다.The information on the IoT node provided by the developer may include, for example, the information shown in Table 2 below.

ElementElement DescriptionDescription IoT_ProfileIoT_Profile Root TagRoot Tag ProfileProfile 하나의 IoT 프로파일 상에 다수의 프로파일 설정 가능Multiple profiles can be set on one IoT profile urlurl 해당 IoT 프로파일이 위치하는 URL 정보URL information where the corresponding IoT profile is located Display_nameDisplay_name 서비스 설치(Deploy) 과정에서 프로파일을 대표하는 이름The name that represents the profile during the Deploy process. Product_NameProduct_Name IoT 프로파일이 수식하는 제품명(IoT Node Name)The product name (IoT Node Name) Product_imageProduct_image IoT 프로파일이 수식하는 제품의 이미지 (프로파일 로딩 (Loading) 시 이미지 정보를 함께 읽어 올 수 있도록 제공)IoT profile provides the image of the product to be modified (loading image information when loading profile) descriptiondescription IoT Node에 대한 설명Description of IoT Node schemaschema IoT 프로파일에 대한 SchemaSchema for IoT profile createdcreated IoT 프로파일 생성일IoT profile creation date versionversion IoT 프로파일 버전IoT profile version creatorcreator IoT 프로파일 생성자IoT Profile Creator Process_urlProcess_url IoT 프로파일과 연결된 Process URLProcess URL associated with IoT profile datastreamdatastream IoT Node가 생산하는 데이터스트림(datastream)에 관한 Tag
하나의 센서에 Input/output 형태의 다양한 데이터스트림이 존재 가능
Tag related to data stream (datastream) produced by IoT Node
Various data streams of input / output type can exist in one sensor
idid Sensor 데이터스트림을 구분하기 위한 고유 값Eigenvalues for distinguishing Sensor data streams namename Sensor 데이터스트림을 구분 하기 위한 이름Name to distinguish the Sensor data stream unitsunits 데이터스트림이 사용할 단위The unit the data stream will use Min_valueMin_value 최소 값(부호가 표기된 숫자값)Minimum value (signed numeric value) Max_valueMax_value 최대 값(부호가 표기된 숫자값)Maximum value (signed numeric value)

개발자가 제공하는 IoT 노드에 대한 정보는 기설정된 문서 생성 규칙(IoT 노드 스키마(schema))에 따라 작성되어 제공될 수 있으며, 상술한 바와 같이, 서비스 제공자 시스템(1010)은 작성 및 제공된 IoT 노드에 대한 정보를 통해 IoT 프로파일을 생성하기 위한 기능을 웹 서비스 형태로 제공할 수 있다. 예를 들어, IoT 프로파일은 표 2와 같이 표현되는 IoT 노드에 대한 정보를 이용하여 생성될 수 있으며, IoT 노드의 기본적인 서술(description) 및 인터페이스 정보를 포함할 수 있다.The information about the IoT node provided by the developer can be prepared and provided according to a predetermined document generation rule (IoT node schema), and as described above, the service provider system 1010 can provide the IoT node created and provided A function for generating an IoT profile can be provided in the form of a web service. For example, the IoT profile may be generated using the information about the IoT node represented as Table 2, and may include the basic description and interface information of the IoT node.

생성된 IoT 프로파일은 IoT 프로파일 데이터베이스(1012)를 통해 배포되거나, 또는 개발자의 웹사이트에 업로드되어 개발자의 웹사이트를 통해 배포될 수 있다. 또한, 이미 설명한 바와 같이 IoT 노드가 스마트 기기와 같은 NC(Non-Constraint) 노드인 경우에는 IoT 노드에 IoT 프로파일이 포함되어 IoT 노드가 IoT 프로파일을 직접 제공할 수도 있다.The generated IoT profile can be distributed through the IoT profile database 1012, or uploaded to the developer's web site and distributed through the developer's web site. Also, as described above, when the IoT node is an NC (Non-Constraint) node such as a smart device, the IoT node includes the IoT profile so that the IoT node directly provides the IoT profile.

이후에서는, 본 발명의 실시예들에 따른 인스턴스 호스팅 게이트웨이에서 IoT 프로파일을 기반으로 개별 IoT 노드로부터 제공되는 정보를 서비스 상의 정보로 인식하기 위한 방법에 대해 설명한다. 도 6 및 도 7을 통해 설명한 바와 같이, 인스턴스 호스팅 게이트웨이는 외부에 존재하는 IoT 프로파일 및 프로세스 정보를 다운로드(도 6을 통해 설명한 업데이터(630) 참조)할 수 있다. 이때, 인스턴스 호스팅 게이트웨이는 IoT 프로파일의 정보를 바탕으로 IoT 노드 인스턴스의 입력값, 출력값을 레스트풀 관리부의 인터페이스(레스트풀 인터페이스(RESTful Interface))를 통해 제공할 수 있다.Hereinafter, a method for recognizing information provided from individual IoT nodes as information on a service based on the IoT profile in the instance hosting gateway according to the embodiments of the present invention will be described. As described with reference to FIGS. 6 and 7, the instance hosting gateway can download the IoT profile and process information existing externally (see the updater 630 described with reference to FIG. 6). At this time, the instance hosting gateway can provide the input value and the output value of the IoT node instance through the interface (restful interface) of the rest pool management unit based on the information of the IoT profile.

일반적인 컨텐츠/데이터 통합(aggregation) 시스템들의 경우에는 사용자가 직접 또는 위자드(wizard) 형태를 이용하여 외부로 노출된 API를 설정해야 하며, 개별적인 인터페이스의 네이밍(naming), 노출할 데이터 소스 등을 지정해야 하는 불편함이 따른다.In the case of general content / data aggregation systems, the user must set the exposed API either directly or using a wizard form, and specify the naming of the individual interfaces and the data source to be exposed. .

본 발명의 실시예들에 따른 인스턴스 호스팅 게이트웨이는 레스트풀 인터페이스 생성과 관련하여 IoT 프로파일을 읽어드린 후 데이터스트림 값을 자동적으로 외부 노출하기 위한 API를 생성하는 기능을 제공할 수 있다. 예를 들어, 도 7을 통해서는 인스턴스 호스팅 게이트웨이가 제공하는 기능을 API 형태로 외부로 제공하는 기능을 수행하기 위한 API 노출부(710)에 대해 설명한 바 있다.The instance hosting gateway according to the embodiments of the present invention may provide a function of generating an API for automatically externally exposing a data stream value after reading the IoT profile in connection with the generation of the rest pool interface. For example, an API exposing unit 710 has been described with reference to FIG. 7 for performing a function of externally providing functions provided by an instance hosting gateway in an API form.

도 11은 본 발명의 일실시예에 있어서, 외부 노출을 위한 오픈 API를 설정하기 위한 방법의 일례를 도시한 흐름도이다. 본 실시예에 따른 레스트풀 인터페이스의 생성 방법은 본 발명의 실시예들에 따른 인스턴스 호스팅 게이트웨이(또는 인스턴스 호스팅 게이트웨이가 포함하는 인스턴스 어플리케이션 서버)에 의해 수행될 수 있다.11 is a flowchart illustrating an example of a method for setting an open API for external exposure in an embodiment of the present invention. The method of generating the rest pool interface according to the present embodiment can be performed by the instance hosting gateway (or the instance application server included in the instance hosting gateway) according to the embodiments of the present invention.

단계(1110)에서 인스턴스 호스팅 게이트웨이는 데이터스트림 정보를 로딩할 수 있다. 여기서, 데이터스트림 정보는, IoT 노드에서 생성되어 수신된 로(raw) 데이터스트림 정보일 수 있다. 로딩하기 위한 데이터스트림 정보가 존재하지 않는 경우, 오픈 API를 설정하기 위한 프로세스는 종료될 수 있다.In step 1110, the instance hosting gateway may load the data stream information. Here, the data stream information may be raw data stream information generated and received at the IoT node. If there is no data stream information for loading, the process for setting the open API may be terminated.

단계(1120)에서 인스턴스 호스팅 게이트웨이는 사용자의 동의 여부를 확인할 수 있다. 등록된 인스턴스들의 외부 노출을 위한 API들에 대한 기능은 레스트풀 형식으로 제공될 수 있다. API 생성 정보는, IoT 프로파일 및 개별 인스턴스의 정보를 바탕으로 사용자의 동의를 얻어 제공될 수 있다. 따라서, 인스턴스 호스팅 게이트웨이는 API 생성 정보를 제공할 것인가에 대한 사용자의 동의 여부를 확인할 수 있다. 만약, 사용자가 API 생성 정보의 제공에 동의하지 않는 경우, 오픈 API를 설정하기 위한 프로세스는 종료될 수 있다.In step 1120, the instance hosting gateway can confirm whether the user agrees. The functionality for APIs for external exposure of registered instances may be provided in a rest pool format. The API generation information can be provided with the user's agreement based on the IoT profile and the information of the individual instances. Accordingly, the instance hosting gateway can confirm whether or not the user agrees to provide the API generation information. If the user does not agree to provide the API generation information, the process for setting the open API may be terminated.

단계(1130)에서 인스턴스 호스팅 게이트웨이는 레스트풀 형식 또는 피드(Feed) 형식을 선택할 수 있다. 레스트풀 형식이 선택된 경우에는 단계(1140)이, 피드 형식이 선택된 경우에는 단계(1180)이 수행될 수 있다.In step 1130, the instance hosting gateway may select a rest pool type or a feed type. Step 1140 may be performed if the rest pool format is selected, and step 1180 may be performed if the feed format is selected.

레스트풀 형식은 IoT 노드에서 생성된 로(raw) 데이터스트림 정보를 API 웹 인터페이스를 통해 직접적으로 외부에 제공하는 형태로, 로(raw) 데이터스트림 정보를 제공하는 과정은 IoT 노드의 인스턴스 설치(deploy)시 사용자의 선택에 따라 진행될 수 있다. 이를 위해, 인스턴스는 개별적으로 외부 노출을 위한 인터페이스 정보를 탑재할 수 있으며, 인스턴스 호스팅 게이트웨이는 인스턴스에 탑재된 정보를 인스턴스 설치 시 읽어 들여 사용자에게 제공할 수 있다. 예를 들어, 레스트풀 인터페이스를 노출하는 경우, 개별 인스턴스별로 데이터의 활용 형태나 제공 가능한 데이터들의 정보가 달라질 수 있기 때문에, 매번 새로운 체계의 주소를 형성하게 된다. 따라서, 본 실시예들에서는 레스트풀 인터페이스를 제공하기 위해, IoT 프로파일 및 프로세스 정보를 읽어 들여 자동화된 형태로 레스트풀 인터페이스를 제공하는 설명 문서를 생성할 수 있고, 해당 설명 문서에 대한 URL을 생성할 수 있다.The rest pool format provides raw data stream information generated by the IoT node directly to the outside through the API web interface. The process of providing raw data stream information is performed by installing an IoT node instance ) Can be performed according to the user's selection. To do this, the instances can individually populate the interface information for external exposures, and the instance hosting gateway can read the instance-mounted information at the time of instance installation and provide it to the user. For example, if you expose the rest pool interface, the form of utilization of the data for each individual instance or the information of the data that can be provided may vary, thus forming a new system address each time. Accordingly, in the present embodiments, in order to provide the rest pool interface, a description document that reads the IoT profile and the process information and provides the rest pool interface in an automated form can be generated, and a URL for the description document can be generated .

단계(1140)에서 인스턴스 호스팅 게이트웨이는 사용자 식별자(User ID)를 획득할 수 있다. 예를 들어, 도 7을 통해 설명한 관리 포털(Management Portal)(720)을 통해 인스턴스별로 인스턴스의 실 소유 사용자 여부가 확인될 수 있다. 이 경우, 인스턴스 호스팅 게이트웨이는 단계(1140)에서 확인된 사용자의 사용자 식별자를 획득할 수 있다.In step 1140, the instance hosting gateway may obtain a user identifier (User ID). For example, the management portal 720 described with reference to FIG. 7 can confirm whether the instance is actually owned by each instance. In this case, the instance hosting gateway may obtain the user identity of the user identified in step 1140.

단계(1150)에서 인스턴스 호스팅 게이트웨이는 인스턴스 식별자(Instance ID)를 획득할 수 있다. 인스턴스 식별자는 IoT 노드로부터 수신되는 메시지마다(또는 상술한 데이터스트림 정보마다) 부여될 수 있다.In step 1150, the instance hosting gateway may obtain an instance identifier (Instance ID). The instance identifier may be given for each message received from the IoT node (or for each of the above-described data stream information).

단계(1160)에서 인스턴스 호스팅 게이트웨이는 API의 URL을 생성할 수 있다. 이미 설명한 바와 같이, 본 실시예들에서 인스턴스 호스팅 게이트웨이는 레스트풀 인터페이스를 제공하기 위해, IoT 프로파일 및 프로세스 정보를 읽어 들여 자동화된 형태로 레스트풀 인터페이스를 제공하는 설명 문서(외부로 제공될 오픈 API를 위한 설명 문서)를 생성할 수 있으며, 이러한 설명 문서에 대한 URL을 생성할 수 있다. 아래 표 3은 생성된 URL의 일례이다.In step 1160, the instance hosting gateway may generate the URL of the API. As described above, in the present embodiment, in order to provide a rest pool interface, the instance hosting gateway reads a description document (an open API to be provided externally) that reads the IoT profile and process information and provides a rest pool interface in an automated form And a URL for such a description document can be generated. Table 3 below is an example of the generated URL.

https://$userID$.instancehosting.com/instanceId/$instanceID$/description.html
* 변수값들의 경우 ‘$’로 표기해 구분
http: //$userID$.instancehosting.com/instanceId/$instanceID$/description.html
* Variable values are indicated by '$'.

단계(1170)에서 인스턴스 호스팅 게이트웨이는 서버에 생성된 URL을 등록할 수 있다. 예를 들어, 특정 인스턴스의 레스트풀 인터페이스 호출 관련 정보가 외부 3rd 파티 서비스를 위해 필요한 경우, 인스턴스 호스팅 게이트웨이는 API 제공 시 관련된 레스트풀 호출을 위한 기본적인 정보를 웹 페이지 형태로 제공할 수 있다. 이러한 기본적인 정보가 레스트풀 인터페이스를 제공하는 설명 문서의 형태로 상기 URL을 통해 제공될 수 있다. 따라서, 인스턴스 호스팅 게이트웨이는 서버에 생성된 URL을 등록함으로써, 외부 3rd 파티 서비스에서 이러한 설명 문서를 참조할 수 있다.In step 1170, the instance hosting gateway may register the URL generated on the server. For example, if the information about the rest pool interface call for a particular instance is needed for an external 3 rd party service, the instance hosting gateway can provide basic information for the related rest pool call in the form of a web page when providing the API. This basic information can be provided through the URL in the form of a descriptive document providing a rest pool interface. Therefore, the instance hosting gateway can refer to this description document in the external 3 rd party service by registering the generated URL on the server.

단계(1180)에서 인스턴스 호스팅 게이트웨이는 규격을 선택할 수 있다. 피드 형식의 경우, 개별 인스턴스들이 저장하는 IoT 노드의 데이터 로그(data log)가 JSON이나 XML 형태로 포맷팅되어 제공될 수 있다. 예를 들어, IOT 노드의 데이터스트림 정보는 상기 IoT 노드와 연관된 적어도 하나의 인스턴스와 연관하여 데이터 로그로서 저장될 수 있다. 인스턴스 호스팅 게이트웨이는 단계(1080)에서 이러한 데이터 로그를 JSON을 이용하여 제공할 것인지 또는 XML을 이용하여 제공할 것인지를 선택할 수 있다. 이 경우, 사용자가 데이터 로그의 관련 필드별로 공개 여부를 설정할 수 있는 기능이 제공될 수 있다. 피드는 인터페이스별로 제공 가능한 정보를 데이터스트림 또는 피드 형식으로 제공하고자 할 때에 필요한 규격(일례로, JSON 규격)을 제공하기 위한 인터페이스 정보를 포함할 수 있다. 이때, 개별 인스턴스의 고유 정보 별로 피드의 제공 위치 정보가 생성될 수 있다. 아래 표 4는 JSON 기반 피드 형식에서의 기본 데이터 제공 값을 나타낸 일례이다.At step 1180, the instance hosting gateway may select a specification. For the feed format, the data log of the IoT node that individual instances store can be provided formatted in JSON or XML format. For example, data stream information of an IOT node may be stored as a data log in association with at least one instance associated with the IoT node. The instance hosting gateway may select at step 1080 whether to provide this data log using JSON or XML. In this case, a function may be provided that allows the user to set whether or not to disclose data in the related fields of the data log. The feed may include interface information for providing a standard (for example, a JSON standard) required when providing information that can be provided for each interface in a data stream or a feed format. At this time, the provision position information of the feed may be generated for each unique information of the individual instance. Table 4 below shows an example of basic data provision values in the JSON-based feed format.

IDID ValueValue DescriptionDescription StatusStatus StringString 해당 Feed의 동작 유무 정보를 나타내며 running, suspend, stop 값을 가질 수 있음Indicates the operation status of the corresponding feed and can have running, suspend, and stop values titletitle StringString 해당 Feed의 Title Title of the Feed FeedFeed URLURL Feed 고유 URLFeed-specific URL tagstags StringString 해당 Feed의 tag 정보Tag information for this feed descriptiondescription StringString 해당 Feed의 설명Description of the Feed createdcreated StringString 해당 Feed의 생성일Date of creation of this feed versionversion StringString 버전 정보Version Information creatorcreator URLURL 생성자 (사용자 ID) The constructor (user ID) updatedupdated DateDate 최종 Message Update 시각Last Message Update Time idid NumberNumber 고유 Feed IDUnique Feed ID datastreamsdatastreams ( ( currentcurrent __ valuevalue ))   제공하는 데이터의 값이 datastream 형식으로 제공되는 경우If the value of the data you provide is provided in datastream format atat StringString Time + GeoLocation "at":"2012-12-14T05:25:57.529014Z",Time + GeoLocation "at": "2012-12-14T05: 25: 57.529014Z", unitunit StringString Label 정보를 포함한 Unit 정보Unit information with label information maxmax __ valuevalue StringString 데이타의 최대 값Maximum value of data minmin __ valuevalue StringString 데이터의 최소 값Minimum value of data

표 4에서 언더바로 표기된 필드는 반복되는 정보를 의미할 수 있다.In Table 4, the underlined fields may indicate repeated information.

단계(1190)에서 인스턴스 호스팅 게이트웨이는 인스턴스 식별자를 등록할 수 있다. 예를 들어, 인스턴스 호스팅 게이트웨이는 IoT 프로파일의 정보를 바탕으로 IoT 노드 인스턴스의 출력값을 피드(feed) 형태로 제공할 수 있는 피더(Feeder)(도 7을 통해 설명한 피더(712)에 대응)를 포함할 수 있다. 인스턴스 호스팅 게이트웨이는 단계(1090)에서 인스턴스 식별자를 이러한 피더에 등록할 수 있고, 등록된 인스턴스 식별자를 통해 데이터 로그가 설정된 규격에 따라 포맷팅되어 외부로 제공될 수 있다.In step 1190, the instance hosting gateway may register the instance identifier. For example, the instance hosting gateway includes a feeder (corresponding to the feeder 712 described with reference to FIG. 7) that can provide the output value of the IoT node instance in the form of a feed based on the information of the IoT profile can do. The instance hosting gateway may register the instance identifier to this feeder at step 1090 and the data log may be formatted according to the established specification via the registered instance identifier and provided externally.

또한, 본 발명의 일실시예에서는 레스트풀 형식의 요청 시 시큐리티 홀(security hole) 회피를 위한 기능을 지원할 수 있다. 본 실시예에 따른 인스턴스 호스팅 게이트웨이에서 레스트풀은 키(key) 형태와 'OAuth' 형태의 두 가지 방식으로 인증 기능을 제공할 수 있다.In addition, in an embodiment of the present invention, it is possible to support a function for avoiding a security hole when requesting a full pool type. In the instance hosting gateway according to the present embodiment, the rest pool can provide the authentication function in two ways, a key type and an 'OAuth' type.

우선, 키 형태로 레스트풀 인터페이스가 요청될 경우, API의 URL은 아래 표 5와 같이 구성될 수 있다.First, when a rest pool interface is requested in the form of a key, the URL of the API can be configured as shown in Table 5 below.

https://$userID$.instancehosting.com/instanceId/$instanceID$/key/
$tokenKey$/start/$startingpoint$/display/$requestCount$
http: //$userID$.instancehosting.com/instanceId/$instanceID$/key/
$ tokenKey $ / start / $ startingPoint $ / display / $ requestCount $

또한, 'OAuth' 형태는 일반적인 OAuth 인증 프로세스에 따라 진행될 수 있으며, 인스턴스 호스팅 게이트웨이는 서비스 제공자 역할의 기능을 제공할 수 있다. 'OAuth' 형태로 레스트풀 인터페이스가 요청될 경우, API의 URL은 아래 표 6과 같이 구성될 수 있다.In addition, the 'OAuth' type can proceed according to the normal OAuth authentication process, and the instance hosting gateway can provide the function of the service provider role. When the rest pool interface is requested in the form of 'OAuth', the URL of the API can be configured as shown in Table 6 below.

https://$userID$.instancehosting.com/instanceId/$instanceID$/start/
$startingpoint$/display/$requestCount$
http: //$userID$.instancehosting.com/instanceId/$instanceID$/start/
$ startingPoint $ / display / $ requestCount $

키 정보는, 'OAuth'를 통해 인증 절차를 진행하였기 때문에 별도의 URL 형태로 요청되지 않는다.The key information is not requested in the form of a separate URL since the authentication process has been performed through 'OAuth'.

표 3, 표 5 및 표 6에서 사용된 용어들은 일례로, 아래 표 7과 같이 표현될 수 있다.The terms used in Tables 3, 5 and 6 are, for example, as shown in Table 7 below.

URL ParameterURL Parameter DescriptionDescription 비고Remarks userIDuserID 인스턴스 호스팅 게이트웨이 시스템상에 등록된 사용자 식별자User identifiers registered on the instance hosting gateway system instanceIDinstanceID 인스턴스 호스팅 게이트웨이 상에서 동작중인 인스턴스 식별자Instance identifier running on the instance hosting gateway KeyKey 사용자가 발급 받은 키The key that the user issued OAuth 인증의 경우 URL상에 별도의 키 값을 입력하지 않으며, 주소부분도 제외된다. For OAuth authentication, no key value is entered in the URL, and the address part is excluded. StartStart 요청 데이터 시작 시점Start of request data 데이터 값 또는 로그를 1개의 개수 단위로 접근Access to data values or logs in a single unit displaydisplay 요청 데이터의 개수Number of request data 1~10,000개 까지 지원Supports 1 ~ 10,000

이와 같이, 본 발명의 실시예들에 따르면, IoT(Internet of Things), WoT(Web of Things) 또는 WoO(Web of Objects) 환경에서 이기종의 기기들이나 다양한 서비스들을 연동 또는 융합하여 관리하고, 통합적으로 서비스를 제공할 수 있다.As described above, according to the embodiments of the present invention, heterogeneous devices and various services can be interlinked or fused in IoT (Internet of Things), WoT (Web of Things) or WoO (Web of Objects) Service can be provided.

이상에서 설명된 장치는 하드웨어 구성요소, 소프트웨어 구성요소, 및/또는 하드웨어 구성요소 및 소프트웨어 구성요소의 조합으로 구현될 수 있다. 예를 들어, 실시예들에서 설명된 장치 및 구성요소는, 예를 들어, 프로세서, 콘트롤러, ALU(arithmetic logic unit), 디지털 신호 프로세서(digital signal processor), 마이크로컴퓨터, FPA(field programmable array), PLU(programmable logic unit), 마이크로프로세서, 또는 명령(instruction)을 실행하고 응답할 수 있는 다른 어떠한 장치와 같이, 하나 이상의 범용 컴퓨터 또는 특수 목적 컴퓨터를 이용하여 구현될 수 있다. 처리 장치는 운영 체제(OS) 및 상기 운영 체제 상에서 수행되는 하나 이상의 소프트웨어 애플리케이션을 수행할 수 있다. 또한, 처리 장치는 소프트웨어의 실행에 응답하여, 데이터를 접근, 저장, 조작, 처리 및 생성할 수도 있다. 이해의 편의를 위하여, 처리 장치는 하나가 사용되는 것으로 설명된 경우도 있지만, 해당 기술분야에서 통상의 지식을 가진 자는, 처리 장치가 복수 개의 처리 요소(processing element) 및/또는 복수 유형의 처리 요소를 포함할 수 있음을 알 수 있다. 예를 들어, 처리 장치는 복수 개의 프로세서 또는 하나의 프로세서 및 하나의 콘트롤러를 포함할 수 있다. 또한, 병렬 프로세서(parallel processor)와 같은, 다른 처리 구성(processing configuration)도 가능하다.The apparatus described above may be implemented as a hardware component, a software component, and / or a combination of hardware components and software components. For example, the apparatus and components described in the embodiments may be implemented within a computer system, such as, for example, a processor, a controller, an arithmetic logic unit (ALU), a digital signal processor, a microcomputer, a field programmable array (FPA) A programmable logic unit (PLU), a microprocessor, or any other device capable of executing and responding to instructions. The processing device may execute an operating system (OS) and one or more software applications running on the operating system. The processing device may also access, store, manipulate, process, and generate data in response to execution of the software. For ease of understanding, the processing apparatus may be described as being used singly, but those skilled in the art will recognize that the processing apparatus may have a plurality of processing elements and / As shown in FIG. For example, the processing unit may comprise a plurality of processors or one processor and one controller. Other processing configurations are also possible, such as a parallel processor.

소프트웨어는 컴퓨터 프로그램(computer program), 코드(code), 명령(instruction), 또는 이들 중 하나 이상의 조합을 포함할 수 있으며, 원하는 대로 동작하도록 처리 장치를 구성하거나 독립적으로 또는 결합적으로(collectively) 처리 장치를 명령할 수 있다. 소프트웨어 및/또는 데이터는, 처리 장치에 의하여 해석되거나 처리 장치에 명령 또는 데이터를 제공하기 위하여, 어떤 유형의 기계, 구성요소(component), 물리적 장치, 가상 장치(virtual equipment), 컴퓨터 저장 매체 또는 장치, 또는 전송되는 신호 파(signal wave)에 영구적으로, 또는 일시적으로 구체화(embody)될 수 있다. 소프트웨어는 네트워크로 연결된 컴퓨터 시스템 상에 분산되어서, 분산된 방법으로 저장되거나 실행될 수도 있다. 소프트웨어 및 데이터는 하나 이상의 컴퓨터 판독 가능 기록 매체에 저장될 수 있다.The software may include a computer program, code, instructions, or a combination of one or more of the foregoing, and may be configured to configure the processing device to operate as desired or to process it collectively or collectively Device can be commanded. The software and / or data may be in the form of any type of machine, component, physical device, virtual equipment, computer storage media, or device , Or may be permanently or temporarily embodied in a transmitted signal wave. The software may be distributed over a networked computer system and stored or executed in a distributed manner. The software and data may be stored on one or more computer readable recording media.

실시예에 따른 방법은 다양한 컴퓨터 수단을 통하여 수행될 수 있는 프로그램 명령 형태로 구현되어 컴퓨터 판독 가능 매체에 기록될 수 있다. 상기 컴퓨터 판독 가능 매체는 프로그램 명령, 데이터 파일, 데이터 구조 등을 단독으로 또는 조합하여 포함할 수 있다. 상기 매체에 기록되는 프로그램 명령은 실시예를 위하여 특별히 설계되고 구성된 것들이거나 컴퓨터 소프트웨어 당업자에게 공지되어 사용 가능한 것일 수도 있다. 컴퓨터 판독 가능 기록 매체의 예에는 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체(magnetic media), CD-ROM, DVD와 같은 광기록 매체(optical media), 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical media), 및 롬(ROM), 램(RAM), 플래시 메모리 등과 같은 프로그램 명령을 저장하고 수행하도록 특별히 구성된 하드웨어 장치가 포함된다. 프로그램 명령의 예에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함한다. 상기된 하드웨어 장치는 실시예의 동작을 수행하기 위해 하나 이상의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지이다.The method according to an embodiment may be implemented in the form of a program command that can be executed through various computer means and recorded in a computer-readable medium. The computer-readable medium may include program instructions, data files, data structures, and the like, alone or in combination. The program instructions to be recorded on the medium may be those specially designed and configured for the embodiments or may be available to those skilled in the art of computer software. Examples of computer-readable media include magnetic media such as hard disks, floppy disks and magnetic tape; optical media such as CD-ROMs and DVDs; magnetic media such as floppy disks; Magneto-optical media, and hardware devices specifically configured to store and execute program instructions such as ROM, RAM, flash memory, and the like. Examples of program instructions include machine language code such as those produced by a compiler, as well as high-level language code that can be executed by a computer using an interpreter or the like. The hardware devices described above may be configured to operate as one or more software modules to perform the operations of the embodiments, and vice versa.

이상과 같이 실시예들이 비록 한정된 실시예와 도면에 의해 설명되었으나, 해당 기술분야에서 통상의 지식을 가진 자라면 상기의 기재로부터 다양한 수정 및 변형이 가능하다. 예를 들어, 설명된 기술들이 설명된 방법과 다른 순서로 수행되거나, 및/또는 설명된 시스템, 구조, 장치, 회로 등의 구성요소들이 설명된 방법과 다른 형태로 결합 또는 조합되거나, 다른 구성요소 또는 균등물에 의하여 대치되거나 치환되더라도 적절한 결과가 달성될 수 있다.While the present invention has been particularly shown and described with reference to exemplary embodiments thereof, it is to be understood that the invention is not limited to the disclosed exemplary embodiments. For example, it is to be understood that the techniques described may be performed in a different order than the described methods, and / or that components of the described systems, structures, devices, circuits, Lt; / RTI > or equivalents, even if it is replaced or replaced.

그러므로, 다른 구현들, 다른 실시예들 및 특허청구범위와 균등한 것들도 후술하는 특허청구범위의 범위에 속한다.Therefore, other implementations, other embodiments, and equivalents to the claims are also within the scope of the following claims.

330: 인스턴스 호스팅 게이트웨이(Instance Hosting Gateway)
410: 네트워크 어댑터(Network Adaptor)
420: 네트워크 핸들러(Network Handler)
430: 인스턴스 매니저(Instance Manager)
440: 인스턴스 어플리케이션 서버(Instance Application Server)
330: Instance Hosting Gateway (Instance Hosting Gateway)
410: Network Adapter
420: Network Handler
430: Instance Manager (Instance Manager)
440: Instance Application Server

Claims (15)

서비스 제공 시스템이 수행하는 서비스 제공 방법에 있어서,
상기 서비스 제공 시스템이 포함하는 IoT(Internet of Things) 프로파일 생성부가, IoT 노드의 개발자의 시스템으로 웹사이트를 제공하고, 상기 개발자의 시스템이 상기 웹사이트를 통해 제공하는 상기 IoT 노드에 대한 정보를 이용하여 IoT 프로파일을 생성하는 단계; 및
상기 서비스 제공 시스템이 포함하는 IoT 프로파일 제공부가, 상기 IoT 프로파일을 IoT 프로파일 데이터베이스에 저장하여 관리하거나 또는 상기 개발자의 시스템으로 제공하는 단계
를 포함하고,
상기 IoT 노드가 접속하는 인스턴스 호스팅 게이트웨이에서, (1) 상기 IoT 프로파일 데이터베이스에 저장된 상기 IoT 프로파일, (2) 상기 개발자의 시스템으로 제공되어 상기 개발자와 연관된 URL을 통해 제공되는 상기 IoT 프로파일 또는 (3) 상기 IoT 프로파일 제공부를 통해 상기 개발자의 시스템으로 제공된 후에, 상기 IoT 노드에 포함되는 상기 IoT 프로파일을 이용하여 상기 IoT 노드를 등록하는 것을 특징으로 하는 서비스 제공 방법.
A service providing method performed by a service providing system,
An IoT (Internet of Things) profile generating unit included in the service providing system provides a web site to a system of a developer of an IoT node, and uses information about the IoT node provided by the developer's system through the web site Creating an IoT profile; And
The IoT profile providing unit included in the service providing system stores the IoT profile in the IoT profile database and provides the IoT profile to the system of the developer
Lt; / RTI >
(1) the IoT profile stored in the IoT profile database; (2) the IoT profile provided via the URL associated with the developer and provided to the system of the developer; or (3) Wherein the IoT node is registered with the IoT profile using the IoT profile included in the IoT node after being provided to the system of the developer through the IoT profile provider.
제1항에 있어서,
상기 IoT 노드에 대한 정보는, 상기 개발자의 시스템과 연관된 URL, 상기 IoT 프로파일과 연결된 프로세스 정보의 URL 중 적어도 하나를 포함하는 것을 특징으로 하는 서비스 제공 방법.
The method according to claim 1,
Wherein the information about the IoT node includes at least one of a URL associated with the developer's system and a URL of process information associated with the IoT profile.
제2항에 있어서,
상기 IoT 노드에 대한 정보는, 상기 IoT 노드가 생산하는 데이터스트림에 대한 정보로서, 단위, 최소값 및 최대값 중 적어도 하나를 더 포함하는 것을 특징으로 하는 서비스 제공 방법.
3. The method of claim 2,
Wherein the information about the IoT node is information on a data stream produced by the IoT node, and further comprises at least one of a unit, a minimum value, and a maximum value.
제1항에 있어서,
상기 IoT 프로파일을 생성하는 단계는,
상기 IoT 노드에 대한 정보를 기설정된 XML 스키마 정의(XML Schema Definition, XSD)에 따라 처리하여 상기 IoT 프로파일을 생성하는 것을 특징으로 하는 서비스 제공 방법.
The method according to claim 1,
Wherein the step of generating the IoT profile comprises:
And processing the information about the IoT node according to a predetermined XML Schema Definition (XSD) to generate the IoT profile.
제1항에 있어서,
상기 IoT 노드의 데이터스트림이 상기 인스턴스 호스팅 게이트웨이에서 상기 IoT 프로파일의 정보를 이용하여 생성된 외부 API를 통해 제공되는 것을 특징으로 하는 서비스 제공 방법.
The method according to claim 1,
Wherein the data stream of the IoT node is provided through an external API generated using the information of the IoT profile in the instance hosting gateway.
제1항에 있어서,
상기 IoT 노드의 데이터 로그(data log)가 JSON(JavaScript Object Notation) 또는 XML(eXtensible Markup Language) 형태로 제공되는 것을 특징으로 하는 서비스 제공 방법.
The method according to claim 1,
Wherein the data log of the IoT node is provided in JSON (JavaScript Object Notation) or XML (eXtensible Markup Language) format.
IoT(Internet of Things) 노드의 개발자의 시스템으로 웹사이트를 제공하고, 상기 개발자의 시스템이 상기 웹사이트를 통해 제공하는 상기 IoT 노드에 대한 정보를 이용하여 IoT 프로파일을 생성하는 IoT 프로파일 생성부;
상기 IoT 프로파일을 저장 및 관리하는 IoT 프로파일 데이터베이스; 및
상기 IoT 프로파일을 상기 개발자의 시스템으로 제공하거나 또는 상기 IoT노드가 접속하는 인스턴스 호스팅 게이트웨이로 제공하는 IoT 프로파일 제공부
를 포함하고,
상기 인스턴스 호스팅 게이트웨이에서, (1) 상기 인스턴스 호스팅 게이트웨이로 제공된 상기 IoT 프로파일, (2) 상기 개발자의 시스템으로 제공되어 상기 개발자의 시스템과 연관된 URL을 통해 제공되는 상기 IoT 프로파일 또는 (3) 상기 IoT 프로파일 제공부를 통해 상기 개발자의 시스템으로 제공된 후에, 상기 IoT 노드에 포함되는 상기 IoT 프로파일을 이용하여 상기 IoT 노드를 등록하는 것을 특징으로 하는 서비스 제공 시스템.
An IoT profile generating unit for providing a web site to a system of a developer of an Internet of Things (IOT) node and generating an IoT profile using information about the IoT node provided by the developer's system through the web site;
An IoT profile database for storing and managing the IoT profile; And
Providing the IoT profile to the system of the developer or providing the IoT profile to the instance hosting gateway to which the IoT node is connected,
Lt; / RTI >
(1) the IoT profile provided to the instance hosting gateway, (2) the IoT profile provided to the system of the developer and provided via a URL associated with the developer's system, or (3) the IoT profile Wherein the IoT node is registered in the IoT node using the IoT profile included in the IoT node after being provided to the system of the developer through the provision unit.
제7항에 있어서,
상기 IoT 노드에 대한 정보는, 상기 개발자의 시스템과 연관된 URL, 상기 IoT 프로파일과 연결된 프로세스 정보의 URL 중 적어도 하나를 포함하는 것을 특징으로 하는 서비스 제공 시스템.
8. The method of claim 7,
Wherein the information about the IoT node includes at least one of a URL associated with the developer's system and a URL of process information associated with the IoT profile.
제7항에 있어서,
상기 IoT 프로파일 생성부는,
상기 IoT 노드에 대한 정보를 기설정된 XML 스키마 정의에 따라 처리하여 상기 IoT 프로파일을 생성하는 것을 특징으로 하는 서비스 제공 시스템.
8. The method of claim 7,
Wherein the IoT profile generator comprises:
And the IoT profile is generated by processing the information about the IoT node according to a predetermined XML schema definition.
(1) 접속을 요청하는 IoT 노드, (2) 상기 IoT노드의 개발자의 시스템과 연관된 URL 또는 (3) 상기 IoT 노드의 IoT 프로파일을 생성하는 서버의 IoT 프로파일 데이터베이스를 통해, 상기 IoT 노드의 상기 IoT 프로파일을 수신하는 IoT 프로파일 수신부; 및
상기 IoT 프로파일에 기초하여 상기 접속을 요청하는 IoT 노드를 등록하는 IoT 노드 등록부
를 포함하고,
상기 IoT 프로파일은, 상기 서버에서 상기 IoT 노드의 개발자의 시스템으로 제공하는 웹사이트를 통해 상기 개발자의 시스템이 제공하는 상기 IoT 노드에 대한 정보 및 기설정된 XML 스키마 정의를 이용하여 상기 서버에서 생성되는 것을 특징으로 하는 인스턴스 호스팅 게이트웨이.
(1) an IoT node requesting a connection, (2) a URL associated with a developer's system of the IoT node, or (3) an IoT profile database of a server generating an IoT profile of the IoT node. An IoT profile receiving unit for receiving a profile; And
An IoT node registration unit for registering an IoT node requesting the connection based on the IoT profile;
Lt; / RTI >
The IoT profile may be generated in the server using information on the IoT node provided by the system of the developer and a predetermined XML schema definition through a website provided to the system of the developer of the IoT node in the server It features an instance hosting gateway.
제10항에 있어서,
상기 IoT 노드의 데이터스트림을 외부로 제공하기 위한 외부 API를 상기 IoT 프로파일을 이용하여 생성하는 외부 API 생성부
를 더 포함하는 인스턴스 호스팅 게이트웨이.
11. The method of claim 10,
An external API generation unit for generating an external API for providing the data stream of the IoT node to the outside using the IoT profile,
Further comprising an instance hosting gateway.
제10항에 있어서,
상기 IoT 노드의 데이터 로그를 JSON 또는 XML 형태로 외부에 제공하는 데이터 로그 제공부
를 더 포함하는 인스턴스 호스팅 게이트웨이.
11. The method of claim 10,
A data log provider for providing the data log of the IoT node to the outside in the form of JSON or XML
Further comprising an instance hosting gateway.
인스턴스 호스팅 게이트웨이가 수행하는 서비스 제공 방법에 있어서,
상기 인스턴스 호스팅 게이트웨이가 포함하는 수신부가, (1) 접속을 요청하는 IoT 노드, (2) 상기 IoT노드의 개발자의 시스템과 연관된 URL 또는 (3) 상기 IoT 노드의 IoT 프로파일을 생성하는 서버의 IoT 프로파일 데이터베이스를 통해, 상기 IoT 노드의 상기 IoT 프로파일을 수신하는 단계;
상기 인스턴스 호스팅 게이트웨이가 포함하는 IoT 노드 등록부가, 상기 IoT 프로파일에 기초하여 상기 접속을 요청하는 IoT 노드를 등록하는 단계; 및
상기 인스턴스 호스팅 게이트웨이가 포함하는 외부 API 생성부가, 상기 IoT 노드의 데이터스트림을 외부로 제공하기 위한 외부 API를 상기 IoT 프로파일을 이용하여 생성하는 단계
를 포함하고,
상기 IoT 프로파일은, 상기 서버에서 상기 IoT 노드의 개발자의 시스템으로 제공하는 웹사이트를 통해 상기 개발자의 시스템이 제공하는 상기 IoT 노드에 대한 정보를 이용하여 상기 서버에서 생성되는 것을 특징으로 하는 서비스 제공 방법.
In a service providing method performed by an instance hosting gateway,
(2) a URL associated with a system of a developer of the IoT node; or (3) an IoT profile of a server that generates an IoT profile of the IoT node. Receiving, via a database, the IoT profile of the IoT node;
Registering an IoT node registration unit included in the instance hosting gateway, the IoT node requesting the connection based on the IoT profile; And
An external API generation unit included in the instance hosting gateway, an external API for providing the data stream of the IoT node to outside using the IoT profile,
Lt; / RTI >
Wherein the IoT profile is generated in the server using information on the IoT node provided by the developer's system through a website provided by the server to the developer's system of the IoT node .
제13항에 있어서,
상기 IoT 프로파일은, 기설정된 XML 스키마 정의를 더 이용하여 상기 서버에서 생성되는 것을 특징으로 하는 서비스 제공 방법.
14. The method of claim 13,
Wherein the IoT profile is generated in the server by further using a predetermined XML schema definition.
제13항에 있어서,
상기 IoT 노드의 데이터 로그를 JSON 또는 XML 형태로 외부에 제공하는 단계
를 더 포함하는 서비스 제공 방법.
14. The method of claim 13,
Providing the data log of the IoT node to the outside in the form of JSON or XML
Further comprising the steps of:
KR20130037492A 2013-03-20 2013-04-05 Method and system for providing service based on profile according to node property in instance hosting environment KR101478902B1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
KR20130037492A KR101478902B1 (en) 2013-04-05 2013-04-05 Method and system for providing service based on profile according to node property in instance hosting environment
US14/159,821 US20140289366A1 (en) 2013-03-20 2014-01-21 Service providing method and system for instance hosting

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR20130037492A KR101478902B1 (en) 2013-04-05 2013-04-05 Method and system for providing service based on profile according to node property in instance hosting environment

Publications (2)

Publication Number Publication Date
KR20140121533A KR20140121533A (en) 2014-10-16
KR101478902B1 true KR101478902B1 (en) 2015-01-05

Family

ID=51992987

Family Applications (1)

Application Number Title Priority Date Filing Date
KR20130037492A KR101478902B1 (en) 2013-03-20 2013-04-05 Method and system for providing service based on profile according to node property in instance hosting environment

Country Status (1)

Country Link
KR (1) KR101478902B1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20190115515A (en) 2018-03-16 2019-10-14 주식회사 아도스 AUTHENTICATION METHOD AND SYSTEM OF IoT(Internet of Things) DEVICE BASED ON PUBLIC KEY INFRASTRUCTURE

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20160091624A (en) 2015-01-26 2016-08-03 한국전자통신연구원 System and method for sharing internet of things using social network, user terminal
WO2016122183A1 (en) * 2015-01-29 2016-08-04 (주)유브릿지 Method and system for brokering data transaction
KR101678795B1 (en) * 2015-11-30 2016-11-22 전삼구 Iot-basesd things management system and method using block chain authentification
KR102470122B1 (en) * 2016-10-19 2022-11-24 한국전자통신연구원 System and method for interfacing of devices using multi-protocol in internet of things
KR102019701B1 (en) * 2018-02-01 2019-09-09 충북대학교 산학협력단 Device profile based gateway platform system and method for integrated control and management of heterogeneous iot network

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20110117030A (en) * 2010-04-20 2011-10-26 삼성전자주식회사 Device management method and system for serving a machine to machine servece and apparatus thereof
KR20130004497A (en) * 2010-03-09 2013-01-10 인터디지탈 패튼 홀딩스, 인크 Method and apparatus for supporting machine-to-machine communications

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20130004497A (en) * 2010-03-09 2013-01-10 인터디지탈 패튼 홀딩스, 인크 Method and apparatus for supporting machine-to-machine communications
KR20110117030A (en) * 2010-04-20 2011-10-26 삼성전자주식회사 Device management method and system for serving a machine to machine servece and apparatus thereof

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20190115515A (en) 2018-03-16 2019-10-14 주식회사 아도스 AUTHENTICATION METHOD AND SYSTEM OF IoT(Internet of Things) DEVICE BASED ON PUBLIC KEY INFRASTRUCTURE

Also Published As

Publication number Publication date
KR20140121533A (en) 2014-10-16

Similar Documents

Publication Publication Date Title
US20140289366A1 (en) Service providing method and system for instance hosting
US10075500B2 (en) Service method and system using instance interface of virtualization object in internet of things environment
KR101605967B1 (en) Sevice method and system for managing transaction using application property
KR101478902B1 (en) Method and system for providing service based on profile according to node property in instance hosting environment
KR101478903B1 (en) Service providing method and system for processing information of node based on profile of node in instance hosting environment
CN111417925B (en) Code module selection for device design
KR102622652B1 (en) Method and apparatus for automatic software development for a group of controller-based devices
Poulter et al. Using the MEAN stack to implement a RESTful service for an Internet of Things application
KR102104899B1 (en) Method and apparatus for authenticating access authorization in wireless communication system
US9560087B2 (en) Providing machine-to-machine service
KR101850879B1 (en) Service enabler function
US20090249369A1 (en) Module-to-module association support method, program, and system
KR20190065372A (en) Service layer resource management for general interworking and scalability
JP6493126B2 (en) Method and non-transitory computer readable medium for dynamic device driver
Pötter et al. Adapting heterogeneous devices into an IoT context-aware infrastructure
US20210084112A1 (en) Profile based content and services
KR101493166B1 (en) Sevice method and system for providing web based user interface for managing instance of virtualization object in internet of things environment
KR101552768B1 (en) Sevice method and system using instance profile for creating virtualization object of things information
KR101570619B1 (en) Method and service system for improving performance in instance hosting environment
KR101494096B1 (en) Sevice method and system for providing running environment of virtualization object
KR101399800B1 (en) Service providing method and system for instance hosting
KR101478909B1 (en) Service providing method and system for connecting to external interface in instance hosting environment
Javed et al. Complex flows: Node-red
KR101494097B1 (en) Sevice method and system using instance interface of virtualization object in internet of things environment
CN118535140B (en) Multi-version control method, system, equipment and storage medium under API framework

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: 20171124

Year of fee payment: 4

FPAY Annual fee payment

Payment date: 20181203

Year of fee payment: 5

FPAY Annual fee payment

Payment date: 20191126

Year of fee payment: 6