WO2017039022A1 - Method for providing content through interworking with content centric networking and apparatus therefor - Google Patents

Method for providing content through interworking with content centric networking and apparatus therefor Download PDF

Info

Publication number
WO2017039022A1
WO2017039022A1 PCT/KR2015/009092 KR2015009092W WO2017039022A1 WO 2017039022 A1 WO2017039022 A1 WO 2017039022A1 KR 2015009092 W KR2015009092 W KR 2015009092W WO 2017039022 A1 WO2017039022 A1 WO 2017039022A1
Authority
WO
WIPO (PCT)
Prior art keywords
content
ccn
network
segment
streaming server
Prior art date
Application number
PCT/KR2015/009092
Other languages
French (fr)
Korean (ko)
Inventor
박우출
이윤주
Original Assignee
전자부품연구원
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 전자부품연구원 filed Critical 전자부품연구원
Publication of WO2017039022A1 publication Critical patent/WO2017039022A1/en

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/40Support for services or applications

Definitions

  • the present invention relates to a content providing method, and more particularly, to a content providing method and a device for interworking with a content-centric network that can provide content to a terminal through interworking with a content-centric network (CONTENT CENTRIC NETWORKING). .
  • Streaming refers to the transmission of content such as video or audio from a server to a client over a network such as the Internet. Data that is transmitted is treated as if it is flowing, called streaming.
  • the server splits the video into packets that can be sent to the network, and the client gathers the packets back, restores them to their original form, and plays them. At this time, playback and packet reception occur at the same time, and the associated series of packets is called a stream.
  • the server supporting the HLS scheme stores contents in chunks, and the terminal of the user appropriately requests the contents according to the user's environment.
  • a server supporting the HLS scheme stores content in chunk units having a small length of 5 to 15 seconds, and provides a playlist file to the terminal. You will request the content appropriately.
  • streaming services support TCP-based communication, resulting in an initial connection delay, inefficiency due to repetition of a procedure of periodically establishing and disconnecting a TCP session, and a waste of resources for maintaining session information.
  • CCN Content Centric Networking
  • the present invention has been proposed to solve the above-described problems, and in particular, a content-oriented network capable of providing a content providing system by integrating a content-oriented network into a streaming service without a separate design change for a terminal to use the content.
  • An object of the present invention is to provide a method for providing content and an apparatus therefor through interworking.
  • a content providing method through interworking with a content-centric network comprising: a CCN network including a plurality of CCN nodes capable of content-based network transmission and a connection to the CCN network. And a streaming server capable of transmitting TCP / IP-based content, the content providing system comprising: receiving, by the streaming server, a content segment request message requested by any one terminal; Converting the content segment request message into a CCN request packet and transmitting the converted content segment request message to a CCN network; Receiving a CCN response packet from the CCN network; Converting the CCN response packet into a content segment response message; And transmitting the content segment response message to the terminal.
  • the delivering to the CCN network may include: identifying a content name of metadata corresponding to the content; And converting the CCN request packet including the identified content name to the CCN network and transmitting the converted CCN request packet to the CCN network.
  • defining the content name may be further included.
  • receiving the CCN response packet may include: checking a content name for the content segment; And modifying the metadata such that the identified content name is reflected in the metadata of the content.
  • the content name may include at least one of name information, a content identifier, and a content segment identifier of a CCN node storing the corresponding content segment.
  • the present invention can provide a computer-readable recording medium recording a program for executing the content providing method through the content-centric network interworking as described above.
  • the CCN network including a plurality of CCN nodes capable of content-based network-based content transmission according to an embodiment of the present invention for achieving the above object, and streaming that is connected to the CCN network and can transmit TCP / IP-based content
  • the streaming server receives a content segment request message requested by one of the terminals, converts the content segment request message into a CCN request packet, and transmits the content segment request message to the CCN network.
  • a conversion processing module for receiving a CCN response packet from a network, converting the CCN response packet into a content segment response message, and transmitting the converted content segment response message to the terminal; And an MPD configuration module for checking a content name of the CCN response packet transmitted from the CCN network and modifying metadata so that the content name is reflected in metadata about the content.
  • the conversion processing module checks the content name described in the metadata for the content, converts the content segment request message into a CCN request packet including the content name, and delivers the content name to the CCN network. Can be.
  • a streaming server or a separate module device interoperable with the streaming server converts the content segment request message into a CCN request packet, the content of the CCN response packet By converting into a segment response message, it is possible to provide a streaming service combined with a content-centric network without a separate design change for the terminal.
  • FIG. 1 is a block diagram showing a content delivery system according to an embodiment of the present invention.
  • FIG. 2 is an exemplary view for explaining a process of processing a CCN request packet in a content center network according to an embodiment of the present invention.
  • FIG. 3 is a block diagram showing the main configuration of a terminal according to an embodiment of the present invention.
  • FIG. 4 is a block diagram showing the main configuration of a streaming server according to an embodiment of the present invention.
  • FIG. 5 is a flowchart illustrating a content using method in a terminal according to an exemplary embodiment of the present invention.
  • FIG. 6 is a flowchart illustrating a content providing method through interworking with a content-oriented network according to an exemplary embodiment of the present invention.
  • FIG. 7 is a data flow diagram illustrating in more detail a content providing method through content-centric network interworking according to an embodiment of the present invention.
  • FIG 8 is an exemplary view for explaining the structure of metadata according to an embodiment of the present invention.
  • first and second are used to describe various components, and are used only to distinguish one component from another component, and to limit the components. Not used.
  • the second component may be referred to as the first component, and similarly, the first component may also be referred to as the second component.
  • a component when referred to as being "connected” or “connected” to another component, it means that it may be connected or connected logically or physically. In other words, although a component may be directly connected or connected to other components, it should be understood that other components may exist in the middle, and may be connected or connected indirectly.
  • embodiments within the scope of the present invention include computer readable media having or conveying computer executable instructions or data structures stored on the computer readable medium.
  • Such computer readable media can be any available media that can be accessed by a general purpose or special purpose computer system.
  • Such computer readable media may be in the form of RAM, ROM, EPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage, or computer executable instructions, computer readable instructions or data structures. And may include, but are not limited to, any other medium that can be used to store or deliver certain program code means, and can be accessed by a general purpose or special purpose computer system. .
  • network is defined as one or more data links that enable the transfer of electronic data between computer systems and / or modules.
  • this connection can be understood as a computer-readable medium.
  • Computer-readable instructions include, for example, instructions and data that cause a general purpose or special purpose computer system to perform a particular function or group of functions.
  • the computer executable instructions may be, for example, binary, intermediate format instructions such as assembly language, or even source code.
  • the present invention relates to personal computers, laptop computers, handheld devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, mobile phones, PDAs, pagers It may be practiced in a network computing environment having various types of computer system configurations, including (pager) and the like.
  • the terminal described in the specification of the present invention may be implemented in various forms.
  • mobile terminals such as smart phones, tablet PCs, personal digital assistants, portable multimedia players, and MP3 players, as well as smart TVs and desktop computers.
  • a fixed terminal may be used, and any terminal can be used as a terminal of the present invention as long as the terminal can be used by uploading or downloading content to a content server through a network.
  • any content described in the specification of the present invention may be included in the content of the present invention as long as it can be expressed by a specific address (eg, a URL) on the network.
  • a specific address eg, a URL
  • the entire web site is represented by one URL, it can be distributed through the system of the present invention as one content.
  • the invention may also be practiced in distributed system environments where both local and remote computer systems that are linked via wired networks, wireless data links, or combinations of wired and wireless data links perform tasks.
  • program modules may be located in both local and remote memory storage devices.
  • FIG. 1 is a block diagram showing a content delivery system according to an embodiment of the present invention.
  • a content delivery system may include a terminal 100 and a streaming server 200.
  • the terminal 100 refers to a user's device that can request, receive, and use content from the streaming server 200 according to a user's request.
  • the terminal 100 of the present invention may be connected to the base station apparatus 310 located within a predetermined radius, and may support a process of connecting to the internet network 300 through the core network through the base station apparatus 310.
  • content may be requested to the streaming server 200 via the Internet network 300, and then received and played.
  • the request for the content may include an execution process of a browser, a playback application, etc. that can receive and use the content provided by the streaming server 200.
  • the terminal 100 receives metadata about the content from the streaming server 200, checks the location of the storage location holding the content based on the metadata, requests the content from the storage location, and receives the content. It may include the process of doing.
  • the terminal 100 may request and receive the content by segment unit upon request and receive the content, and may collect and play the content by the fragment unit, which is a plurality of sets of segments.
  • the terminal 100 may request and receive the content by segment unit upon request and receive the content, and may collect and play the content by the fragment unit, which is a plurality of sets of segments.
  • the terminal 100 may request and receive the content by segment unit upon request and receive the content, and may collect and play the content by the fragment unit, which is a plurality of sets of segments.
  • the terminal 100 may request and receive the content by segment unit upon request and receive the content, and may collect and play the content by the fragment unit, which is a plurality of sets of segments.
  • the terminal 100 may request and receive the content by segment unit upon request and receive the content, and may collect and play the content by the fragment unit, which is a plurality of sets of segments.
  • the terminal 100 may request and receive the content by segment unit upon request and receive the content, and may collect and play the content by the fragment unit, which is
  • the streaming server 200 is to provide various contents such as photographs, videos, audio, applications, etc. to the terminal 100, or to receive and provide contents related services.
  • the content provider (CP; Contents) At least one content is provided from the provider and managed, and serves to provide content to the plurality of terminals 100 through the Internet network 300.
  • the streaming server 200 of the present invention may support a process of providing content to the terminal 100 in association with the CCN adapter device 250.
  • the content request of the terminal 100 follows the HTTP protocol, so that the CCN network It cannot be passed to 400.
  • the streaming server 200 of the present invention converts the content segment request message of the terminal into a CCN request packet in cooperation with the CCN adapter device 250 and converts the content response packet transmitted from the CCN network 400 to the content segment response message. It can support the process of converting to and transmitting to the terminal 100.
  • the streaming server 200 of the present invention may serve to store and manage metadata about the content.
  • the metadata may be modified and distributed so that the delivered content name is reflected in the metadata of the corresponding content.
  • the CCN adapter device 250 serves to interwork the Internet network 300 and the CCN network 400, and may perform a function of converting a message conforming to the HTTP protocol into a CCN packet supporting the CCN protocol.
  • the streaming server 200 and the CCN adapter device 250 are illustrated as independent devices in the drawings, the present invention is not limited thereto, and the CCN adapter device 250 may exist as a module in the streaming server 200. .
  • CCN network 400 is a type of network that can distribute and provide content in response to content-centric network-based content requests and the like, for this purpose CCN node 410 may be distributed distributed on the CCN network 400 .
  • Content transmission through the CCN node 410 is made through a CCN packet.
  • the CCN packet transmits and receives contents using the name of the content as the address of the packet.
  • the CCN packet includes a CCN request packet for requesting the content and a CCN response packet corresponding to the response packet. It is composed.
  • the CCN nodes 410 should store a forwarding information base (FIB).
  • FIB forwarding information base
  • a method of providing content in the CCN network 400 will be described with reference to FIG. 2.
  • FIG. 2 is an exemplary view for explaining a process of processing a CCN request packet in a content center network according to an embodiment of the present invention.
  • the name of a content may serve as a compass to navigate to a node where content is stored and to distinguish the content from other content. Therefore, each content uses a unique name, and if the names of the two contents are different from each other, the same content can be treated as another content. For example, if two files having the same contents exist under different names, the two files may be processed with different contents.
  • one CCN node 400 receives a CCN request packet corresponding to, for example, '/ABC.com/SSS/abc.avi/v3/s3/' from face 0 101.
  • the content store 110 may be referred to as a contents cache.
  • the CCN node 410 returns the corresponding content to face 0 101 where the CCN request packet is received.
  • the face may also be expressed as an interface.
  • the CCN node 410 may have the same content name (here, '/ABC.com/SSS/abc. Pending Interest Table (PIT) 130). avi / v3 / s2 ') can check whether there is an entry saved. If there is an entry stored under the same content name, the CCN node 410 may add information on the face (here, face 0 101) in which the CCN request packet enters the corresponding entry in the pending interlist table 130.
  • the face here, face 0 101
  • the CCN node 410 performs a name lookup based on the content name in the forwarding information base (FIB) 150. You can do this to find the entry. In this case, the CCN node 410 may perform a search according to the longest prefix matching.
  • the CCN node 410 determines a face (for example, face 1 105) to deliver a CCN request packet based on information registered in the forwarding information base (FIB) 150, and determines the face (face 1 ( 105)) may transmit a CCN request packet.
  • the CCN node 410 may register the information '0' on the face (face 0 101) to which the CCN request packet is delivered to the interlist table (PIT) 130. This is for routing the CCN response packet to the node that requested the content when delivering the CCN response packet, which is a content response packet including the content corresponding to the CCN request packet, to the terminal 100 in the future.
  • the face where the CCN request packet is received here, face 0 101
  • the face where the CCN request packet is received may be excluded from the selection target.
  • the plurality of CCN nodes 410 determines another CCN node 410 to which the CCN request packet is to be delivered by referring to the FIB as described above, and uses the PIT to route the CCN response packet.
  • the CCN response packet may be delivered to the terminal 100 without a process.
  • the CCN response packet may be delivered to the CCN adapter device 250, and the CCN adapter device 250 may support a process of converting the CCN response packet into a content segment response message and then transmitting the same to the terminal 100. Can be.
  • one CCN node 410 stores a content segment changed from a storage location of the corresponding content segment or an origin server
  • information for defining a content name thereof is transmitted to the streaming server 200.
  • the streaming server 200 may perform a process of adding or modifying metadata after defining a content name.
  • the internet network 300 of the present invention may be connected through an access network (not shown) and a core network (not shown) connected through a plurality of base station devices 310.
  • An access network is an access network that performs wired or wireless communication with the terminal 100.
  • a plurality of base stations such as a base station (BS), a base transceiver station (BTS), a NodeB, an eNodeB, and a base station (BSC) It may be implemented as a base station controller such as a controller, a radio network controller (RNC).
  • a digital signal processor and a wireless signal processor which are integrally implemented in the base station, are divided into digital units (hereinafter referred to as DUs and radio units (hereinafter referred to as RUs)).
  • DUs and radio units hereinafter referred to as RUs
  • Each of the plurality of RUs may be installed in the region of the plurality, and the plurality of RUs (not shown) may be configured by connecting with a centralized DU (not shown).
  • the core network (not shown) constituting the network together with the access network (not shown) serves to connect the access network (not shown) and the external network, for example, the Internet network 300.
  • the core network is a network system that performs a main function for mobile communication services such as mobility control and switching between access networks (not shown), and includes circuit switching or packet switching. switching, and manages and controls the packet flow in the mobile network.
  • the core network may manage inter-frequency mobility, and may play a role for interworking with traffic in the access network (not shown) and the core network (not shown) and other networks such as the Internet network 310. have.
  • the core network may further include a mobile switching center (MSC), a home location register (HLR), a mobile mobility entity (MME), a home subscriber server (HSS), and the like.
  • the Internet network 310 refers to a conventional public communication network, that is, a public network, through which information is exchanged according to the TCP / IP protocol, and is connected to the streaming server 200 and provided from the streaming server 200.
  • the content providing system includes a cloud computing network that stores computing resources such as hardware and software, and provides computing resources required by a client to a corresponding terminal. can do.
  • cloud computing refers to a computer environment in which information is permanently stored on a server on the Internet and temporarily stored in client terminals such as desktops, tablet computers, laptops, netbooks, and smartphones. It refers to a computer environment access network that stores a server on the Internet and makes this information available anytime, anywhere through various IT devices.
  • Such an Internet network 300 is a closed network such as a local area network (LAN), a wide area network (WAN), an open network such as the Internet, as well as a code division multiple access (CDMA) and a wideband code (WCDMA).
  • This concept includes both Division Multiple Access (GSM), Global System for Mobile Communications (GSM), Long Term Evolution (LTE), and Evolved Packet Core (EPC), as well as next-generation and cloud computing networks. .
  • a processor mounted in each device may process a program command for executing a method according to the present invention.
  • this processor may be a single-threaded processor, and in another implementation, the processor may be a multithreaded processor.
  • the processor is capable of processing instructions stored on memory or storage devices.
  • FIG. 3 is a block diagram showing the main configuration of a terminal according to an embodiment of the present invention.
  • the terminal 100 includes a communication unit 110, an input unit 120, a control unit 130, an output unit 140, and a storage unit 150. Can be configured.
  • the communication unit 110 performs a role of transmitting and receiving information with the streaming server 200 through the Internet network (300).
  • the communication unit 110 of the present invention may perform a procedure for accessing the Internet network 300.
  • the base station apparatus 310 is located within a predetermined radius, and the access request of the found base station apparatus 310 is performed.
  • it can be connected to an access network (not shown).
  • the process of connecting the communication unit 110 of the terminal 100 to the base station apparatus 310 of the access network (not shown) may adopt a variety of well-known configuration, a detailed description thereof will be omitted.
  • the communication unit 110 may transmit user information when performing a communication procedure with the base station apparatus 310.
  • a terminal identification number such as an IMSI (International Mobile Subscriber Identity) or the like may be transmitted to the base station apparatus 310, and the terminal identification number while the base station apparatus 310 performs a connection procedure with a core network (not shown). Etc., subscriber information can be confirmed.
  • IMSI International Mobile Subscriber Identity
  • the communication unit 110 when the communication unit 110 according to an embodiment of the present invention normally connects to the core network (not shown) through the base station apparatus 310 of the access network (not shown), it is possible to request and receive content.
  • the input unit 120 transmits a variety of information such as numeric and text information input from a user, a signal input in connection with various function settings and function control of the terminal 100, to the controller 130.
  • the input unit 120 of the present invention may support a user input necessary for accessing the streaming server 200.
  • the input unit 120 includes a key input means such as a keyboard or a keypad, a touch input means such as a touch sensor or a touch pad, a voice input means, a gyro sensor, a geomagnetic sensor, an acceleration sensor and a proximity sensor, and a camera. It may also include a gesture input means comprising at least one or more.
  • it may include all types of input means that are currently under development or may be developed in the future.
  • the controller 130 performs overall control of the terminal 100, and includes at least one processor including a central processing unit (CPU) and an execution memory (eg, a register and at least one memory loading data) loaded in hardware. And / or a random access memory (RAM) and a bus that inputs and outputs at least one data into the processor and memory.
  • processor including a central processing unit (CPU) and an execution memory (eg, a register and at least one memory loading data) loaded in hardware. And / or a random access memory (RAM) and a bus that inputs and outputs at least one data into the processor and memory.
  • it may include a predetermined program routine (Routine) or program data that is loaded into the execution memory from a predetermined recording medium to be performed by the processor to perform a function defined in the terminal 100 by software.
  • a component that can be processed in software may be determined as the function of the controller 130.
  • the controller 130 of the present invention is functionally connected to at least one component provided for content transmission and playback processing according to an embodiment of the present invention. That is, the controller 130 is functionally connected to the communication unit 110, the input unit 120, the storage unit 140, and the output unit 150, and controls the flow of signals for supplying power and performing functions to the components. Control.
  • the controller 130 may include a content reproduction processing module 131.
  • the content reproduction processing module 131 controls overall contents related to content request, reception, and reproduction.
  • the content reproduction processing module 131 may execute a reproduction application.
  • the playback application performs a function of playing back the content provided by the streaming server 200.
  • it may be an application capable of playing high quality content provided by the streaming server 200.
  • the present invention is not limited thereto, and any application (for example, a browser) may be a playback application of the present invention as long as the streaming server 200 can play content provided by the streaming server 200.
  • the content reproduction processing module 131 checks the MPD information, which is metadata. Through the MPD, the content reproduction processing module 131 of the present invention may check address information (URL) for each segment, and may request and receive a content segment from the corresponding streaming server 200. In this case, the content reproduction processing module 131 of the present invention may check the identification information of each segment, and if the identification information is the same, request and receive a substream at the same time, and perform a process of processing the reproduction.
  • MPD information which is metadata.
  • the content reproduction processing module 131 of the present invention may check address information (URL) for each segment, and may request and receive a content segment from the corresponding streaming server 200. In this case, the content reproduction processing module 131 of the present invention may check the identification information of each segment, and if the identification information is the same, request and receive a substream at the same time, and perform a process of processing the reproduction.
  • URL address information
  • controller 130 of the present invention may further include a decoding module (not shown), and decodes the segment transmitted from the content reproduction processing module 131 and outputs the result of the content reproduction processing module 131. ) To play the content.
  • a decoding module not shown
  • the storage 140 may temporarily store various data generated during execution of the application program, including an application program required for operating a function according to an embodiment of the present invention.
  • the storage 140 may store and manage information related to the playback application 151 that can execute the content provided by the streaming server 200, and store the received content segment. Can be managed.
  • the storage 140 may largely include a program area and a data area.
  • the program area stores related information for driving the terminal 100 such as an operating system (OS) for booting the terminal 100.
  • the data area is an area in which data generated according to the use of the terminal 100 is stored, and as described above, the content segment delivered from the playback application and the internet network 300 may be stored.
  • the storage unit 140 may include a flash memory, a hard disk, a multimedia card micro type memory (eg, SD or XD memory, etc.), a RAM, a ROM, and the like. ROM) and a storage medium.
  • the output unit 150 displays information on a series of operation states and operation results that occur during the functioning of the terminal 100.
  • the output unit 150 of the present invention may display various information related to the execution of the playback application.
  • the output unit 150 may be implemented in the form of a single touch panel (or touch screen) together with the input unit 120, and when implemented together with the input unit 120, a user's touch operation.
  • Various information generated according to the present invention can be displayed.
  • the output unit 150 of the present invention is a liquid crystal display (LCD), thin film transistor LCD (TFT-LCD), organic light emitting diodes (OLED), light emitting diodes (LED), AMOLED (Active Matrix) Organic LED), a flexible display (Flexible display) and a three-dimensional display (3 Dimension) and the like.
  • LCD liquid crystal display
  • TFT-LCD thin film transistor LCD
  • OLED organic light emitting diodes
  • LED light emitting diodes
  • AMOLED Active Matrix Organic LED
  • a flexible display Flexible display
  • three-dimensional display 3 Dimension
  • Some of these displays may also be configured to be transparent or light transmissive so that they can be seen from the outside. It may be configured in the form of a transparent display including a transparent OLED (TOLED).
  • TOLED transparent OLED
  • the terminal 100 may further include a sound source output unit (not shown) for converting a sound source, which is an electrical signal, into an analog signal and outputting the analog signal.
  • a sound source output unit (not shown) for converting a sound source, which is an electrical signal, into an analog signal and outputting the analog signal.
  • the position of the main components of the terminal 100 shown in FIG. 3 may be changed for convenience or other reasons.
  • FIG. 4 is a block diagram showing the main configuration of a streaming server according to an embodiment of the present invention.
  • the streaming server 200 may include a server communication unit 210, a server control unit 220, and a server storage unit 230.
  • the server communication unit 210 serves to transmit and receive the necessary information with the terminal 100 through the communication network (300).
  • the server controller 220 includes an MPD configuration module 221, a conversion processing module 222, and a service support module 223.
  • the 'module' is a component that performs a predetermined function, respectively, can be implemented in hardware, software, or a combination of hardware and software.
  • the 'module' may mean a program module, which is executed by a processor to perform a predetermined function, software components, object-oriented software components, class components and Components such as task components, processes, functions, properties, procedures, subroutines, segments of program code, drivers, data, databases, data structures, tables, arrays , And variables.
  • the functionality provided in the components and 'modules' may be combined into a smaller number of components and ' ⁇ modules' or further separated into additional components and ' ⁇ modules'.
  • the MPD configuration module 221 generates and manages metadata about content.
  • the metadata may be modified and the process of distribution to the terminal 100 may be controlled.
  • the conversion processing module 222 is for explaining an embodiment in which the function of the CCN adapter device 250 illustrated in FIG. 1 is modularized and included in the server controller 220.
  • the request processing according to the HTTP protocol of the terminal 100 is performed.
  • the process of converting the request to the CCN protocol and converting the response to the CCN protocol into the response according to the HTTP protocol can be controlled.
  • the conversion processing module 222 of the present invention may be omitted when implemented as a separate CCN adapter device 250 as shown in FIG.
  • the service support module 223 may control the overall process for transmitting content to the terminal 100 at the request of the terminal 100. For example, if content is transmitted to registered users, membership authentication may be performed. In addition, it plays a role of transmitting metadata to the terminal 100 and may support a process of smoothly delivering the content segment to the terminal 100.
  • the server controller 220 of the present invention may further include an encoding module.
  • the server storage unit 230 stores information related to performance of the streaming server 200 of the present invention, and in particular, may store and manage the MPD information 231.
  • the streaming server 200 of the present invention provides a service to a registered user
  • personal information for membership registration and authentication may be stored and managed.
  • it may include a corresponding substream.
  • FIG. 5 is a flowchart illustrating a content using method in a terminal according to an exemplary embodiment of the present invention.
  • the terminal 100 of the present invention first executes a playback application to use the content provided by the streaming server 200 (S101).
  • the playback application performs a function of playing back the content provided by the streaming server 200.
  • it may be an application capable of playing high quality content provided by the streaming server 200.
  • the present invention is not limited thereto, and any application (for example, a browser) may be a playback application of the present invention as long as the streaming server 200 can play content provided by the streaming server 200.
  • the playback application of the present invention is preferably downloaded in advance from the streaming server 200 or a separate content store is installed in the terminal 100, but is not limited thereto, and may execute the playback application in a cloud manner. .
  • the terminal 100 of the present invention checks the MPD information, which is metadata (S203). Through the MPD, the terminal 100 may check address information (URL) for each content segment (S105), and transmit a content segment request message (HTTP REQUEST) to a device corresponding to the address information (S107). ).
  • MPD information which is metadata
  • the terminal 100 may check address information (URL) for each content segment (S105), and transmit a content segment request message (HTTP REQUEST) to a device corresponding to the address information (S107).
  • the content segment request message may be transmitted using the streaming server 200 as a destination address, and thereafter, a content segment response message (HTTP RESPONSE) is received from the streaming server 200 (S109), so that the content segment can be reproduced. (S111).
  • the terminal 100 of the present invention may process a process of decoding the content segment response message when it is encoded.
  • FIG. 6 is a flowchart illustrating a content providing method through interworking with a content-oriented network according to an exemplary embodiment of the present invention.
  • the streaming server 200 of the present invention includes the functions of the CCN adapter device 250 for convenience of description, but is not limited thereto.
  • the corresponding step may be implemented in the CCN adapter device 250.
  • the streaming server 200 of the present invention receives a content segment request message from the terminal 100 (S201).
  • the streaming server 200 of the present invention converts the received content segment request message into a CCN request packet to transmit to the CCN network 400 (S203).
  • the streaming server 200 of the present invention first checks whether it owns a content segment corresponding to the content segment request message, and if so, the terminal sends a content segment response message including the content segment to the terminal.
  • the process of transmitting to 100 may be performed.
  • the streaming server 200 of the present invention when the streaming server 200 of the present invention does not store the corresponding content segment, the streaming server 200 converts it into a CCN packet, which is a CCN packet, so that the CCN network 400 can process it.
  • the streaming server 200 of the present invention checks the metadata of the content, checks the content name corresponding to the corresponding content segment, and generates a CCN request packet including the content name.
  • the content name may include name information of a storage location storing the corresponding content segment, a content identifier, and a content segment identifier.
  • a plurality of CCN nodes located in the CCN network 400 may perform a routing process. That is, after checking whether the content segment corresponding to the content name is being stored and transmitting the content segment to the streaming server 200, the content segment corresponding to the content name is transmitted to the streaming server 200. If not, the content segment corresponding to the content name is the origin server.
  • the CCN request packet can be delivered to the storage location of the provider).
  • the CCN nodes that have received the CCN response packet from the content provider deliver this to the streaming server 200.
  • the streaming server 200 When the streaming server 200 receives the CCN response packet, which is a response packet for the CCN request packet, from the CCN network 400 (S207), the streaming server 200 converts the content segment response (HTTP RESPONSE) message to the terminal 100 for transmission. In operation S209, the content segment response message may be transmitted to the terminal 100 in operation S211.
  • the content segment response message may be transmitted to the terminal 100 in operation S211.
  • the streaming server 200 of the present invention can check the information on the CCN nodes holding the content segment in step S207 through the content name of the CCN response packet, the content name of the content metadata Can be stored in
  • the changed metadata may be transmitted to the terminal 100 to support a faster content provision.
  • Content providing method through the content-centric network interworking according to an embodiment of the present invention may be achieved through the interworking between the streaming server 200 and the CCN adapter device 250. That is, in FIG. 6, the function of the CCN adapter device 250 operates in a form included in the streaming server 200, but the function of the CCN adapter device 250 of the present invention may operate independently.
  • FIG. 7 is a data flow diagram illustrating in more detail a content providing method through content-centric network interworking according to an embodiment of the present invention.
  • the terminal 100 executes a playback application to use contents provided by the streaming server 200 (S301).
  • the playback application performs a function of playing back the content provided by the streaming server 200.
  • it may be an application capable of playing high quality content provided by the streaming server 200.
  • the present invention is not limited thereto, and any application (for example, a browser) may be a playback application of the present invention as long as the streaming server 200 can play content provided by the streaming server 200.
  • the playback application of the present invention is preferably downloaded in advance from the streaming server 200 or a separate content store is installed in the terminal 100, but is not limited thereto, and may execute the playback application in a cloud manner. .
  • the terminal 100 of the present invention checks the MPD information, which is metadata (S303).
  • the terminal 100 of the present invention through the MPD can check the address information (URL) for each content segment (S305), the content segment request message (HTTP REQUEST) to the streaming server 200 corresponding to the address information It transmits (S307).
  • URL address information
  • HTTP REQUEST content segment request message
  • the streaming server 200 receiving this is transmitted to the CCN adapter device 250 (S309).
  • the CCN adapter device 250 of the present invention serves to connect the Internet network 300 and the CCN network 400, and is a device capable of converting and processing a message conforming to the HTTP protocol into a packet form conforming to the CCN protocol. .
  • the CCN adapter device 250 of the present invention first checks the CCN content name in order to convert the content segment request message transmitted from the streaming server 200 into a CCN request packet (S311).
  • the name information may be achieved by checking metadata of the content.
  • the CCN adapter device 250 converts the CCN request packet to the CCN request packet including the checked content name (S313) and delivers the same to the CCN network 400.
  • a plurality of CCN nodes constituting the CCN network 400 performs a routing process by finding the CCN nodes storing the content segment corresponding to the content name (S317). If a corresponding content segment exists in one CCN node or the content segment exists in a content provider (S319), a CCN response packet may be transmitted to the CCN adapter device 250 through a routing process again.
  • the CCN response packet transmitted from the CCN network 400 may be delivered with the content itself including the content segment instead of the content segment. In this case, the CCN adapter device 250 divides the content into segments. Therefore, only the corresponding content segment requested by the terminal 100 may be controlled to be delivered to the terminal 100.
  • the CCN adapter device 250 of the present invention converts the CCN response packet transmitted from the CCN network 400 to the content segment response message (S323), and transmits the converted content segment response message to the streaming server 200. It is made (S325).
  • the CCN response packet includes a content name including information on the storage location of the content segment, the streaming server 200 of the present invention metadata to reflect the content name to be transmitted to the metadata for the content The process of modifying will be performed.
  • the distributed metadata may be distributed to the terminal 100 to support content provision according to the changed metadata later.
  • the terminal 100 of the present invention may receive the content segment and play back the content (S329).
  • the streaming server 200 of the present invention performs the process of modifying the metadata so that the content name transmitted from the CCN adapter device 250 is reflected in the metadata for the content. Do it.
  • FIG 8 is an exemplary view for explaining the structure of metadata according to an embodiment of the present invention.
  • Metadata of the present invention means media presentation description (MPD) of content.
  • MPD means a stylized description of a media presentation
  • the MPD of the present invention may be MPD of Dynamic and Adaptive HTTP Streaming of MEPG of MPEG.
  • the MPD may include a description of a representation 705 (or a representation) of media to be delivered to the terminal 100. That is, the MPD describes combinations of video, audio, and language that the terminal 100 can access.
  • the MPD may define a format 707 for informing resource identifiers for a segment.
  • the MPD may provide a context for the identified resources in the media presentation, where the resource identifiers are HTTP-URLs and may be limited by the byte range attribute.
  • Segment is a term for Generation Partnership Project (3GPP) adaptive HTTP streaming.
  • 3GPP Generation Partnership Project
  • the fragment responds to an HTTP / 1.1 GET request for an HTTP-URL (or a GET request for a portion indicated by a byte range), as defined in RFC 2616, for example.
  • Sub-segment means the smallest unit in the segments that can be indexed by the segment index at the segment level. can do.
  • one period 703 may include two or more fragment sets, and each of the sets of fragments may be referred to as a representation.
  • the representation may be referred to as an alternative.
  • Representation is a structured collection of one or more media components within one period.
  • Representation is an alternative to media content or a subset of media content, with different encoding choices, such as bitrate, resolution, language, codec, and the like. alternative) may be one of the choices. That is, the representation may represent a combination of video, audio, language, and the like that may constitute media.
  • the MPD (or MPD element) provides descriptive information that enables the terminal 100 to select one or more representations, in other words suitable for accessing segments and providing streaming services to the user. (appropriate) A document containing metadata required by the DASH client to construct HTTP-URLs. HTTP-URLs can be absolute or relative.
  • Such an MPD may be implemented in the form of an XML-document, and the MPD may include various MPD elements as described above, but may include only one MPD element.
  • the streaming server 200 of the present invention may transmit the metadata to the corresponding terminal 100.
  • the streaming server 200 of the present invention may perform a process of modifying the content name transmitted from the CCN adapter device 250 to be reflected in the metadata. That is, as indicated by 709 and 711, the content name can be specified in each metadata. As indicated by 711, the content segment identification information and the content identification information as defined by the 709 are defined as the content name. It can be described in.
  • the streaming server 200 distributes the modified metadata to the terminal 100 and when the content segment transmission request is transmitted from the terminal 100 which has been checked later, the content name of the metadata. By checking the information, it is possible to support a process of transmitting the corresponding content segment to the terminal 100 at the CCN node immediately without the routing process in the CCN network 400.
  • the streaming server 200 may generate a plurality of metadata corresponding to any one content.
  • the streaming server 200 of the present invention supports a scalable encoding method of generating a bitstream by layering content into a plurality of layers, decoding is selectively performed according to the performance or network state of the terminal 100. Information about this can be described in metadata.
  • Content providing method through the content-centric network interworking of the present invention includes a CCN network including a plurality of CCN nodes capable of content-based network-based content transmission, and a streaming server connected to the CCN network and capable of transmitting TCP / IP-based content
  • the streaming server receiving a content segment request message requested by any one terminal, converting the content segment request message to a CCN request packet and forwarding to the CCN network, from the CCN network Receiving a CCN response packet, converting the CCN response packet into a content segment response message, and transmitting the content segment response message to the terminal.
  • Such computer-readable media suitable for storing computer program instructions and data include, for example, recording media comprising magnetic media, such as hard disks, floppy disks, and magnetic tape, and compact disk read only memory (CD-ROM). , Optical media such as Digital Video Disk (DVD), magneto-optical media such as Floppy Disk, and ROM (Read Only Memory), RAM And a semiconductor memory such as a random access memory, a flash memory, an erasable programmable ROM (EPROM), and an electrically erasable programmable ROM (EEPROM).
  • the processor and memory can be supplemented by or integrated with special purpose logic circuitry.
  • the computer readable recording medium can also be distributed over network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
  • a functional program for implementing the present invention codes and code segments associated therewith may be used in consideration of a system environment of a computer that reads a recording medium and executes the program. It may be easily inferred or changed by.
  • the computer program recorded on the computer-readable recording medium as described above includes instructions for performing the functions as described above, distributed and distributed through the recording medium to be read and installed on a specific device, a specific computer, and executed.
  • the above functions can be executed.
  • the above-described computer program is a C, C ++ that can be read by the computer's processor (CPU) through the computer's device interface (Interface) Code for a program instruction coded in a computer language such as JAVA, machine language, or the like may be included.
  • Such code may include a function code associated with a function or the like that defines the above-described functions, and may include execution procedure-related control code necessary for a processor of the computer to execute the above-described functions according to a predetermined procedure.
  • the code may further include memory reference-related code for additional information or media required for a processor of the computer to execute the above-described functions at which location (address address) of the computer's internal or external memory. .
  • the code may be used to determine which computer the processor of the computer uses the communication module of the computer on the remote. It may further include communication-related codes such as how to communicate with other computers or servers, and what information or media should be transmitted and received during communication.
  • the present invention relates to a content providing method, and more particularly, to a content providing method and a device for interworking with a content-centric network that can provide content to a terminal through interworking with a content-centric network (CONTENT CENTRIC NETWORKING). .
  • a separate module device capable of interworking with a streaming server or a streaming server converts a content segment request message into a CCN request packet and converts a CCN response packet into a content segment response message, thereby designing a separate terminal for the terminal. It is possible to provide streaming services combined with content-oriented networks without change, thereby contributing to the development of the service industry.
  • the present invention has industrial applicability because the present invention is not only sufficiently commercially available or commercially viable, but also practically clearly implemented.

Abstract

The present invention relates to a method for providing content and, more particularly, to a method for providing content through interworking with content centric networking and an apparatus therefor, which can provide content to a terminal through interworking with content centric networking (CCN), wherein a streaming server or a separate module apparatus capable of being linked with the streaming server converts a content segment request message into a CCN request packet, and converts a CCN response packet into a content segment response message. Accordingly, the present invention can provide a streaming service combined with content centric networking without making a special change to the design of a terminal.

Description

컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법 및 이를 위한 장치Content providing method through content-oriented network interworking and apparatus therefor
본 발명은 컨텐츠 제공 방법에 관한 것으로, 더욱 상세하게는 컨텐츠 중심 네트워크(CONTENT CENTRIC NETWORKING)와의 연동을 통해 단말로 컨텐츠를 제공할 수 있는 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법 및 이를 위한 장치에 관한 것이다. The present invention relates to a content providing method, and more particularly, to a content providing method and a device for interworking with a content-centric network that can provide content to a terminal through interworking with a content-centric network (CONTENT CENTRIC NETWORKING). .
이 부분에 기술된 내용은 단순히 본 실시 예에 대한 배경 정보를 제공할 뿐 종래기술을 구성하는 것은 아니다.The contents described in this section merely provide background information on the present embodiment and do not constitute a prior art.
스트리밍(streaming)은 인터넷과 같은 네트워크를 통해 서버에서 클라이언트로 비디오 또는 오디오와 같은 컨텐츠를 전송하는 것을 의미한다. 전송되는 데이터가 마치 물이 흐르는 것처럼 처리된다고 해서 스트리밍이라고 한다. 서버는 비디오를 네트워크로 보낼 수 있도록 패킷으로 분리하며, 클라이언트는 그 패킷들을 다시 모아서 원래 형태로 복원한 후에 재생한다. 이때, 재생과 패킷 수신은 동시에 일어나며, 연관된 일련의 패킷들을 스트림(stream)이라고 한다.Streaming refers to the transmission of content such as video or audio from a server to a client over a network such as the Internet. Data that is transmitted is treated as if it is flowing, called streaming. The server splits the video into packets that can be sent to the network, and the client gathers the packets back, restores them to their original form, and plays them. At this time, playback and packet reception occur at the same time, and the associated series of packets is called a stream.
최근에는 HTTP 라이브 스트리밍(HTTP Live Streaming, 이하 HLS라고 명명함) 방식이 주로 사용되고 있다. HLS 방식을 지원하는 서버는 컨텐츠를 청크 단위로 저장하고, 사용자의 단말이 사용자의 환경에 따라 적절하게 컨텐츠를 요청하는 방식이다. 예를 들어, HLS 방식을 지원하는 서버는 컨텐츠를 일반적으로 5초에서 15초 정도의 작은 길이를 가지는 청크 단위로 구분하여 저장하며, 재생 목록 파일을 단말로 제공하면, 단말은 자신의 상황에 따라 적절하게 컨텐츠를 요청하게 된다. Recently, the HTTP live streaming (HTTP Live Streaming, HLS) method is mainly used. The server supporting the HLS scheme stores contents in chunks, and the terminal of the user appropriately requests the contents according to the user's environment. For example, a server supporting the HLS scheme stores content in chunk units having a small length of 5 to 15 seconds, and provides a playlist file to the terminal. You will request the content appropriately.
그러나, 현재까지의 스트리밍 서비스는 TCP 기반 통신을 지원함으로써, 초기 접속 지연이 발생되며, 주기적으로 TCP 세션을 맺고 끊는 절차의 반복으로 인한 비효율성과 세션 정보 유지를 위한 리소스 낭비가 발생된다는 문제점이 있다. However, up to now streaming services support TCP-based communication, resulting in an initial connection delay, inefficiency due to repetition of a procedure of periodically establishing and disconnecting a TCP session, and a waste of resources for maintaining session information.
따라서 이러한 문제점을 해결하기 위해 스트리밍 서비스에 컨텐츠 중심 네트워크(CCN; Content Centric Networking)를 적용하고자 하는 시도가 이뤄지고 있으나, 컨텐츠 중심 네트워크를 스트리밍 서비스에 적용하기 위해서는 단말이 컨텐츠 중심 네트워크 기술을 지원할 수 있는 모듈을 포함하고 있어야 한다는 문제점이 있다. Therefore, attempts have been made to apply Content Centric Networking (CCN) to streaming services to solve these problems.However, in order to apply content centric networks to streaming services, terminals can support content-centric network technologies. There is a problem that must include.
본 발명은 상기한 종래의 문제점을 해결하기 위해 제안된 것으로서, 특히 컨텐츠를 이용하고자 하는 단말에 대한 별도의 설계 변경 없이 스트리밍 서비스에 컨텐츠 중심 네트워크를 접목하여 컨텐츠 제공 시스템을 제공할 수 있는 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법 및 이를 위한 장치를 제공하는 데 목적이 있다. The present invention has been proposed to solve the above-described problems, and in particular, a content-oriented network capable of providing a content providing system by integrating a content-oriented network into a streaming service without a separate design change for a terminal to use the content. An object of the present invention is to provide a method for providing content and an apparatus therefor through interworking.
그러나, 이러한 본 발명의 목적은 상기의 목적으로 제한되지 않으며, 언급되지 않은 또 다른 목적들은 아래의 기재로부터 명확하게 이해될 수 있을 것이다.However, the object of the present invention is not limited to the above object, and other objects not mentioned will be clearly understood from the following description.
상술한 바와 같은 목적을 달성하기 위한 본 발명의 실시 예에 따른 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법은 컨텐츠 중심 네트워크 기반 컨텐츠 전송이 가능한 다수의 CCN 노드를 포함하는 CCN 망과, 상기 CCN 망에 연결되며 TCP/IP 기반 컨텐츠 전송이 가능한 스트리밍 서버를 포함하는 컨텐츠 제공 시스템에 있어서, 상기 스트리밍 서버가, 어느 하나의 단말이 요청한 컨텐츠 세그먼트 요청 메시지를 수신하는 단계; 상기 컨텐츠 세그먼트 요청 메시지를 CCN 요청 패킷으로 변환하여 CCN 망으로 전달하는 단계; 상기 CCN 망으로부터 CCN 응답 패킷을 수신하는 단계; 상기 CCN 응답 패킷을 컨텐츠 세그먼트 응답 메시지로 변환하는 단계; 및 상기 단말로 상기 컨텐츠 세그먼트 응답 메시지를 전송하는 단계;를 포함하여 이뤄질 수 있다. In accordance with an aspect of the present invention, there is provided a content providing method through interworking with a content-centric network, comprising: a CCN network including a plurality of CCN nodes capable of content-based network transmission and a connection to the CCN network. And a streaming server capable of transmitting TCP / IP-based content, the content providing system comprising: receiving, by the streaming server, a content segment request message requested by any one terminal; Converting the content segment request message into a CCN request packet and transmitting the converted content segment request message to a CCN network; Receiving a CCN response packet from the CCN network; Converting the CCN response packet into a content segment response message; And transmitting the content segment response message to the terminal.
이때, 상기 CCN 망으로 전달하는 단계는 상기 컨텐츠에 대응하는 메타데이터의 컨텐츠 이름을 확인하는 단계; 및 상기 확인된 컨텐츠 이름을 포함하는 CCN 요청 패킷으로 변환하여 CCN 망으로 전달하는 단계;를 포함하여 이뤄질 수 있다. In this case, the delivering to the CCN network may include: identifying a content name of metadata corresponding to the content; And converting the CCN request packet including the identified content name to the CCN network and transmitting the converted CCN request packet to the CCN network.
또한, 상기 컨텐츠에 대응하는 메타데이터의 컨텐츠 이름이 존재하지 않을 경우, 상기 컨텐츠 이름을 정의하는 단계;를 더 포함하여 이뤄질 수 있다. In addition, when the content name of the metadata corresponding to the content does not exist, defining the content name; may be further included.
이때, 상기 CCN 응답 패킷을 수신하는 단계는 상기 컨텐츠 세그먼트에 대한 컨텐츠 이름을 확인하는 단계; 및 상기 확인된 컨텐츠 이름이 상기 컨텐츠의 메타데이터에 반영되도록 상기 메타데이터를 수정하는 단계;를 더 포함하여 이뤄질 수 있다. In this case, receiving the CCN response packet may include: checking a content name for the content segment; And modifying the metadata such that the identified content name is reflected in the metadata of the content.
또한, 상기 컨텐츠 이름은 해당 컨텐츠 세그먼트를 저장하고 있는 CCN 노드의 이름 정보, 컨텐츠 식별자 및 컨텐츠 세그먼트 식별자 중 적어도 어느 하나 이상을 포함하여 구성될 수 있다. The content name may include at least one of name information, a content identifier, and a content segment identifier of a CCN node storing the corresponding content segment.
추가로 본 발명은 상술한 바와 같은 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법을 실행하는 프로그램을 기록한 컴퓨터 판독 가능한 기록 매체를 제공할 수 있다.In addition, the present invention can provide a computer-readable recording medium recording a program for executing the content providing method through the content-centric network interworking as described above.
상술한 바와 같은 목적을 달성하기 위한 본 발명의 실시 예에 따른 컨텐츠 중심 네트워크 기반 컨텐츠 전송이 가능한 다수의 CCN 노드를 포함하는 CCN 망과, 상기 CCN 망에 연결되며 TCP/IP 기반 컨텐츠 전송이 가능한 스트리밍 서버를 포함하는 컨텐츠 제공 시스템에 있어서, 상기 스트리밍 서버는, 어느 하나의 단말이 요청한 컨텐츠 세그먼트 요청 메시지를 수신하고, 상기 컨텐츠 세그먼트 요청 메시지를 CCN 요청 패킷으로 변환하여 상기 CCN 망으로 전달하며, 상기 CCN 망으로부터 CCN 응답 패킷을 수신하고, 상기 CCN 응답 패킷을 컨텐츠 세그먼트 응답 메시지로 변환한 후 상기 단말로 전송하는 변환 처리 모듈; 및 상기 CCN 망으로부터 전달된 상기 CCN 응답 패킷의 컨텐츠 이름을 확인하고, 상기 컨텐츠 이름이 상기 컨텐츠에 대한 메타데이터에 반영되도록 메타데이터를 수정하는 MPD 구성 모듈;을 포함하여 구성될 수 있다. CCN network including a plurality of CCN nodes capable of content-based network-based content transmission according to an embodiment of the present invention for achieving the above object, and streaming that is connected to the CCN network and can transmit TCP / IP-based content In a content providing system including a server, the streaming server receives a content segment request message requested by one of the terminals, converts the content segment request message into a CCN request packet, and transmits the content segment request message to the CCN network. A conversion processing module for receiving a CCN response packet from a network, converting the CCN response packet into a content segment response message, and transmitting the converted content segment response message to the terminal; And an MPD configuration module for checking a content name of the CCN response packet transmitted from the CCN network and modifying metadata so that the content name is reflected in metadata about the content.
이때, 상기 변환 처리 모듈은 상기 컨텐츠 세그먼트 요청 메시지를 상기 CCN 요청 패킷으로 변환 시 상기 컨텐츠에 대한 메타데이터에 기재된 컨텐츠 이름을 확인한 후 상기 컨텐츠 이름을 포함하는 CCN 요청 패킷으로 변환하여 상기 CCN 망으로 전달할 수 있다. In this case, when converting the content segment request message to the CCN request packet, the conversion processing module checks the content name described in the metadata for the content, converts the content segment request message into a CCN request packet including the content name, and delivers the content name to the CCN network. Can be.
본 발명의 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법 및 이를 위한 장치에 의하면, 스트리밍 서버 또는 스트리밍 서버와 연동가능한 별도의 모듈 장치가 컨텐츠 세그먼트 요청 메시지를 CCN 요청 패킷으로 변환 처리하고, CCN 응답 패킷을 컨텐츠 세그먼트 응답 메시지로 변환 처리함으로써, 단말에 대한 별도의 설계 변경 없이 컨텐츠 중심 네트워크와 접목된 스트리밍 서비스를 제공할 수 있게 된다. According to the content providing method and the apparatus therefor according to the content-oriented network interworking of the present invention, a streaming server or a separate module device interoperable with the streaming server converts the content segment request message into a CCN request packet, the content of the CCN response packet By converting into a segment response message, it is possible to provide a streaming service combined with a content-centric network without a separate design change for the terminal.
또한, CCN 망에서 실시간 변경되는 CCN 노드에 대한 정보를 전달받아 이를 메타데이터에 반영한 후 단말로 배포함으로써, 컨텐츠를 저장하고 있는 CCN 노드가 변경되더라도 보다 신속하게 해당 CCN 노드로부터 컨텐츠 세그먼트를 수신하여 이용할 수 있게 된다. In addition, by receiving information about the CCN node that is changed in real time in the CCN network, reflecting it in metadata and distributing it to the terminal, even if the CCN node that stores the content is changed to receive and use the content segment from the CCN node more quickly It becomes possible.
아울러, 상술한 효과 이외의 다양한 효과들이 후술될 본 발명의 실시 예에 따른 상세한 설명에서 직접적 또는 암시적으로 개시될 수 있다.In addition, various effects other than the above-described effects may be directly or implicitly disclosed in the detailed description according to the embodiment of the present invention to be described later.
도 1은 본 발명의 실시 예에 따른 컨텐츠 전송 시스템을 도시한 구성도이다. 1 is a block diagram showing a content delivery system according to an embodiment of the present invention.
도 2는 본 발명의 실시 예에 따른 컨테츠 중심 네트워크에서의 CCN 요청 패킷을 처리하는 과정을 설명하기 위한 예시도이다. 2 is an exemplary view for explaining a process of processing a CCN request packet in a content center network according to an embodiment of the present invention.
도 3은 본 발명의 실시 예에 따른 단말의 주요 구성을 도시한 블록도이다.3 is a block diagram showing the main configuration of a terminal according to an embodiment of the present invention.
도 4는 본 발명의 실시 예에 따른 스트리밍 서버의 주요 구성을 도시한 블록도이다. 4 is a block diagram showing the main configuration of a streaming server according to an embodiment of the present invention.
도 5는 본 발명의 실시 예에 따른 단말에서의 컨텐츠 이용 방법을 설명하기 위한 흐름도이다. 5 is a flowchart illustrating a content using method in a terminal according to an exemplary embodiment of the present invention.
도 6은 본 발명의 실시 예에 따른 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법을 설명하기 위한 흐름도이다. 6 is a flowchart illustrating a content providing method through interworking with a content-oriented network according to an exemplary embodiment of the present invention.
도 7은 본 발명의 실시 예에 따른 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법을 보다 더 구체적으로 설명한 데이터 흐름도이다. 7 is a data flow diagram illustrating in more detail a content providing method through content-centric network interworking according to an embodiment of the present invention.
도 8은 본 발명의 실시 예에 따른 메타데이터의 구조를 설명하기 위한 예시도이다. 8 is an exemplary view for explaining the structure of metadata according to an embodiment of the present invention.
본 발명의 과제 해결 수단의 특징 및 이점을 보다 명확히 하기 위하여, 첨부된 도면에 도시된 본 발명의 특정 실시 예를 참조하여 본 발명을 더 상세하게 설명한다. BRIEF DESCRIPTION OF THE DRAWINGS To make the features and advantages of the present invention more clear, the present invention will be described in more detail with reference to specific embodiments shown in the accompanying drawings.
다만, 하기의 설명 및 첨부된 도면에서 본 발명의 요지를 흐릴 수 있는 공지 기능 또는 구성에 대한 상세한 설명은 생략한다. 또한, 도면 전체에 걸쳐 동일한 구성 요소들은 가능한 한 동일한 도면 부호로 나타내고 있음에 유의하여야 한다.However, in the following description and the accompanying drawings, detailed descriptions of well-known functions or configurations that may obscure the subject matter of the present invention will be omitted. In addition, it should be noted that like elements are denoted by the same reference numerals as much as possible throughout the drawings.
이하의 설명 및 도면에서 사용된 용어나 단어는 통상적이거나 사전적인 의미로 한정해서 해석되어서는 아니 되며, 발명자는 그 자신의 발명을 가장 최선의 방법으로 설명하기 위한 용어의 개념으로 적절하게 정의할 수 있다는 원칙에 입각하여 본 발명의 기술적 사상에 부합하는 의미와 개념으로 해석되어야만 한다. 따라서 본 명세서에 기재된 실시 예와 도면에 도시된 구성은 본 발명의 가장 바람직한 일 실시 예에 불과할 뿐이고, 본 발명의 기술적 사상을 모두 대변하는 것은 아니므로, 본 출원시점에 있어서 이들을 대체할 수 있는 다양한 균등물과 변형 예들이 있을 수 있음을 이해하여야 한다.The terms or words used in the following description and drawings should not be construed as being limited to the ordinary or dictionary meanings, and the inventors may appropriately define the concept of terms for explaining their own invention in the best way. It should be interpreted as meaning and concept corresponding to the technical idea of the present invention based on the principle that the present invention. Therefore, the embodiments described in the present specification and the configuration shown in the drawings are only the most preferred embodiments of the present invention, and do not represent all of the technical ideas of the present invention, and various alternatives may be substituted at the time of the present application. It should be understood that there may be equivalents and variations.
또한, 제1, 제2 등과 같이 서수를 포함하는 용어는 다양한 구성요소들을 설명하기 위해 사용하는 것으로, 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 사용될 뿐, 상기 구성요소들을 한정하기 위해 사용되지 않는다. 예를 들어, 본 발명의 권리 범위를 벗어나지 않으면서 제2 구성요소는 제1 구성요소로 명명될 수 있고, 유사하게 제1 구성요소도 제2 구성요소로 명명될 수 있다.In addition, terms including ordinal numbers, such as first and second, are used to describe various components, and are used only to distinguish one component from another component, and to limit the components. Not used. For example, without departing from the scope of the present invention, the second component may be referred to as the first component, and similarly, the first component may also be referred to as the second component.
더하여, 어떤 구성요소가 다른 구성요소에 "연결되어" 있다거나 "접속되어" 있다고 언급할 경우, 이는 논리적 또는 물리적으로 연결되거나, 접속될 수 있음을 의미한다. 다시 말해, 구성요소가 다른 구성요소에 직접적으로 연결되거나 접속되어 있을 수 있지만, 중간에 다른 구성요소가 존재할 수도 있으며, 간접적으로 연결되거나 접속될 수도 있다고 이해되어야 할 것이다.In addition, when a component is referred to as being "connected" or "connected" to another component, it means that it may be connected or connected logically or physically. In other words, although a component may be directly connected or connected to other components, it should be understood that other components may exist in the middle, and may be connected or connected indirectly.
또한, 본 명세서에서 사용한 용어는 단지 특정한 실시 예를 설명하기 위해 사용된 것으로, 본 발명을 한정하려는 의도가 아니다. 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 또한, 본 명세서에서 기술되는 포함 한다" 또는 "가지다" 등의 용어는 명세서상에 기재된 특징, 숫자, 단계, 동작, 구성요소, 부품 또는 이들을 조합한 것이 존재함을 지정하려는 것이지, 하나 또는 그 이상의 다른 특징들이나 숫자, 단계, 동작, 구성요소, 부품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.In addition, the terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. Singular expressions include plural expressions unless the context clearly indicates otherwise. In addition, the terms "include" or "having" described herein are intended to indicate that there is a feature, number, step, operation, component, part, or combination thereof described in the specification, and one or more of them. It is to be understood that it does not exclude in advance the possibility of the presence or addition of other features or numbers, steps, operations, components, components or combinations thereof.
아울러, 본 발명의 범위 내의 실시 예들은 컴퓨터 실행가능 명령어 또는 컴퓨터 판독가능 매체에 저장된 데이터 구조를 가지거나 전달하는 컴퓨터 판독가능 매체를 포함한다. 이러한 컴퓨터 판독가능 매체는, 범용 또는 특수 목적의 컴퓨터 시스템에 의해 액세스 가능한 임의의 이용 가능한 매체일 수 있다. 예로서, 이러한 컴퓨터 판독가능 매체는 RAM, ROM, EPROM, CD-ROM 또는 기타 광 디스크 저장장치, 자기 디스크 저장장치 또는 기타 자기 저장장치, 또는 컴퓨터 실행가능 명령어, 컴퓨터 판독가능 명령어 또는 데이터 구조의 형태로 된 소정의 프로그램 코드 수단을 저장하거나 전달하는 데에 이용될 수 있고, 범용 또는 특수 목적 컴퓨터 시스템에 의해 액세스 될 수 있는 임의의 기타 매체와 같은 물리적 저장 매체를 포함할 수 있지만, 이에 한정되지 않는다.In addition, embodiments within the scope of the present invention include computer readable media having or conveying computer executable instructions or data structures stored on the computer readable medium. Such computer readable media can be any available media that can be accessed by a general purpose or special purpose computer system. By way of example, such computer readable media may be in the form of RAM, ROM, EPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage, or computer executable instructions, computer readable instructions or data structures. And may include, but are not limited to, any other medium that can be used to store or deliver certain program code means, and can be accessed by a general purpose or special purpose computer system. .
이하의 설명 및 특허 청구 범위에서, "네트워크"는 컴퓨터 시스템들 및/또는 모듈들 간의 전자 데이터를 전송할 수 있게 하는 하나 이상의 데이터 링크로서 정의된다. 정보가 네트워크 또는 다른 (유선, 무선, 또는 유선 또는 무선의 조합인) 통신 접속을 통하여 컴퓨터 시스템에 전송되거나 제공될 때, 이 접속은 컴퓨터-판독가능매체로서 이해될 수 있다. 컴퓨터 판독가능 명령어는, 예를 들면, 범용 컴퓨터 시스템 또는 특수 목적 컴퓨터 시스템이 특정 기능 또는 기능의 그룹을 수행하도록 하는 명령어 및 데이터를 포함한다. 컴퓨터 실행가능 명령어는, 예를 들면, 어셈블리어, 또는 심지어는 소스코드와 같은 이진, 중간 포맷 명령어일 수 있다.In the following description and claims, “network” is defined as one or more data links that enable the transfer of electronic data between computer systems and / or modules. When information is transmitted or provided to a computer system via a network or other (wired, wireless, or a combination of wired or wireless) communication connections, this connection can be understood as a computer-readable medium. Computer-readable instructions include, for example, instructions and data that cause a general purpose or special purpose computer system to perform a particular function or group of functions. The computer executable instructions may be, for example, binary, intermediate format instructions such as assembly language, or even source code.
아울러, 본 발명은 퍼스널 컴퓨터, 랩탑 컴퓨터, 핸드헬드 장치, 멀티프로세서 시스템, 마이크로프로세서-기반 또는 프로그램 가능한 가전제품(programmable consumer electronics), 네트워크 PC, 미니컴퓨터, 메인프레임 컴퓨터, 모바일 전화, PDA, 페이저(pager) 등을 포함하는 다양한 유형의 컴퓨터 시스템 구성을 가지는 네트워크 컴퓨팅 환경에서 실시될 수 있다. In addition, the present invention relates to personal computers, laptop computers, handheld devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, mobile phones, PDAs, pagers It may be practiced in a network computing environment having various types of computer system configurations, including (pager) and the like.
또한 본 발명의 명세서에서 기술되는 단말은 다양한 형태로 구현될 수 있다. 예를 들어, 스마트 폰(smart phone), 타블렛 PC(Tablet PC), PDA(Personal Digital Assistants), PMP(Portable Multimedia Player), MP3 Player 등의 이동 단말기는 물론, 스마트 TV(Smart TV), 데스크탑 컴퓨터 등과 같은 고정 단말기가 사용될 수 있으며, 네트워크를 통해 컨텐츠 서버로 컨텐츠를 업로드하거나 다운로드를 요청하여 이용할 수 있는 단말이라면, 그 어떠한 단말도 본 발명의 단말로 적용 가능하다.In addition, the terminal described in the specification of the present invention may be implemented in various forms. For example, mobile terminals such as smart phones, tablet PCs, personal digital assistants, portable multimedia players, and MP3 players, as well as smart TVs and desktop computers. A fixed terminal may be used, and any terminal can be used as a terminal of the present invention as long as the terminal can be used by uploading or downloading content to a content server through a network.
또한, 본 발명의 명세서에서 기술하는 컨텐츠는 네트워크 상에서 특정 주소(예컨대, URL)로 표현될 수 있는 것이라면 그 어떠한 것도 본 발명의 컨텐츠에 포함될 수 있다. 예컨대, 웹 사이트 전체도 하나의 URL로 표현되는 경우, 하나의 컨텐츠로써, 본 발명의 시스템을 통해 배포될 수 있다. In addition, any content described in the specification of the present invention may be included in the content of the present invention as long as it can be expressed by a specific address (eg, a URL) on the network. For example, when the entire web site is represented by one URL, it can be distributed through the system of the present invention as one content.
본 발명은 또한 네트워크를 통해 유선 데이터 링크, 무선 데이터 링크, 또는 유선 및 무선 데이터 링크의 조합으로 링크된 로컬 및 원격 컴퓨터 시스템 모두가 태스크를 수행하는 분산형 시스템 환경에서 실행될 수 있다. 분산형 시스템 환경에서, 프로그램 모듈은 로컬 및 원격 메모리 저장 장치에 위치될 수 있다.The invention may also be practiced in distributed system environments where both local and remote computer systems that are linked via wired networks, wireless data links, or combinations of wired and wireless data links perform tasks. In a distributed system environment, program modules may be located in both local and remote memory storage devices.
이제, 본 발명의 실시 예에 따른 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법 및 이를 위한 장치에 대하여 도면을 참조하여 상세하게 설명하도록 한다. Now, a content providing method and a device therefor through content-oriented network interworking according to an embodiment of the present invention will be described in detail with reference to the accompanying drawings.
먼저, 본 발명의 실시 예에 따른 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법을 지원하는 컨텐츠 전송 시스템에 대해 설명하도록 한다. First, a description will be given of a content delivery system supporting a content providing method through content-oriented network interworking according to an embodiment of the present invention.
도 1은 본 발명의 실시 예에 따른 컨텐츠 전송 시스템을 도시한 구성도이다. 1 is a block diagram showing a content delivery system according to an embodiment of the present invention.
도 1을 참조하면, 본 발명의 실시 예에 따른 컨텐츠 전송 시스템은 단말(100) 및 스트리밍 서버(200)를 포함하여 구성될 수 있다. Referring to FIG. 1, a content delivery system according to an exemplary embodiment of the present invention may include a terminal 100 and a streaming server 200.
먼저, 단말(100)은 사용자의 요청에 따라 스트리밍 서버(200)로 컨텐츠를 요청하고 수신하여 이용할 수 있는 사용자의 장치를 의미한다. 이를 위해 본 발명의 단말(100)은 일정 반경 내 위치하는 기지국 장치(310)와 연결되고, 상기 기지국 장치(310)를 통해 코어망을 거쳐 인터넷망(300)에 연결되는 과정을 지원할 수 있다. 그리고 사용자의 요청에 따라 인터넷망(300)을 거쳐 스트리밍 서버(200)로 컨텐츠를 요청하고 이를 수신하여 재생할 수 있다. 이때, 상기 컨텐츠에 대한 요청은 상기 스트리밍 서버(200)가 제공하는 컨텐츠를 수신하여 이용할 수 있는 브라우저, 재생 어플리케이션 등의 실행 과정을 포함할 수 있다. 이후 단말(100)은 스트리밍 서버(200)로부터 컨텐츠에 대한 메타데이터를 수신하며, 상기 메타데이터를 기초로 해당 컨텐츠를 보유하고 있는 저장 장소의 위치를 확인하고, 해당 저장 장소로 컨텐츠를 요청하여 수신하는 과정을 포함할 수 있다. First, the terminal 100 refers to a user's device that can request, receive, and use content from the streaming server 200 according to a user's request. To this end, the terminal 100 of the present invention may be connected to the base station apparatus 310 located within a predetermined radius, and may support a process of connecting to the internet network 300 through the core network through the base station apparatus 310. In response to a user's request, content may be requested to the streaming server 200 via the Internet network 300, and then received and played. In this case, the request for the content may include an execution process of a browser, a playback application, etc. that can receive and use the content provided by the streaming server 200. Thereafter, the terminal 100 receives metadata about the content from the streaming server 200, checks the location of the storage location holding the content based on the metadata, requests the content from the storage location, and receives the content. It may include the process of doing.
또한, 본 발명의 실시 예에 따른 단말(100)은 컨텐츠를 요청하여 수신 시 세그먼트 단위로 요청하고 이를 수신할 수 있으며, 세그먼트의 복수 개의 집합인 프래그먼트 단위로 컨텐츠를 모아 재생할 수도 있다. 또한, 상기 각 컨텐츠 세그먼트가 인코딩된 상태로 전송되는 경우 이를 디코딩하여 재생하는 과정을 지원할 수 있다. In addition, the terminal 100 according to an embodiment of the present invention may request and receive the content by segment unit upon request and receive the content, and may collect and play the content by the fragment unit, which is a plurality of sets of segments. In addition, when each content segment is transmitted in an encoded state, it may support a process of decoding and playing the content segment.
스트리밍 서버(200)는 단말(100)로 다양한 컨텐츠, 예컨대, 사진, 비디오, 오디오, 어플리케이션 등과 같은 다양한 컨텐츠를 제공하거나, 컨텐츠를 수신하고 이와 관련된 서비스를 제공하기 위한 것으로, 컨텐츠 제공자(CP; Contents Provider)로부터 적어도 하나의 컨텐츠를 제공받아 관리하며, 인터넷망(300)를 통해서 다수의 단말(100)로 컨텐츠를 제공하는 역할을 수행할 수 있다. 이때, 본 발명의 스트리밍 서버(200)는 CCN 어댑터 장치(250)와 연동하여 단말(100)로 컨텐츠를 제공하는 과정을 지원할 수 있다. 다시 말해, 본 발명의 컨텐츠를 저장하고 있는 위치가 CCN 망(400) 상의 위치하는 복수 개의 CCN 노드(410)에 분산 배치된 경우, 단말(100)의 컨텐츠 요청은 HTTP 프로토콜을 따르므로, CCN망(400)으로 전달될 수 없다. 따라서, 본 발명의 스트리밍 서버(200)는 CCN 어댑터 장치(250)와 연동하여 단말의 컨텐츠 세그먼트 요청 메시지를 CCN 요청 패킷으로 변환하고, CCN 망(400)으로부터 전달되는 컨텐츠 응답 패킷을 컨텐츠 세그먼트 응답 메시지로 변환하여 단말(100)로 전달하는 과정을 지원할 수 있다.The streaming server 200 is to provide various contents such as photographs, videos, audio, applications, etc. to the terminal 100, or to receive and provide contents related services. The content provider (CP; Contents) At least one content is provided from the provider and managed, and serves to provide content to the plurality of terminals 100 through the Internet network 300. In this case, the streaming server 200 of the present invention may support a process of providing content to the terminal 100 in association with the CCN adapter device 250. In other words, when the location storing the content of the present invention is distributed to a plurality of CCN nodes 410 located on the CCN network 400, the content request of the terminal 100 follows the HTTP protocol, so that the CCN network It cannot be passed to 400. Accordingly, the streaming server 200 of the present invention converts the content segment request message of the terminal into a CCN request packet in cooperation with the CCN adapter device 250 and converts the content response packet transmitted from the CCN network 400 to the content segment response message. It can support the process of converting to and transmitting to the terminal 100.
또한, 본 발명의 스트리밍 서버(200)는 컨텐츠에 대한 메타데이터를 저장하고 관리하는 역할을 수행할 수 있다. 그리고 CCN 망(400)을 거쳐 컨텐츠 세그먼트에 대한 컨텐츠 이름이 전달되면, 전달된 컨텐츠 이름이 해당 컨텐츠의 메타데이터에 반영되도록 메타데이터를 수정 및 배포하는 과정을 지원할 수 있다. In addition, the streaming server 200 of the present invention may serve to store and manage metadata about the content. When a content name for a content segment is delivered through the CCN network 400, the metadata may be modified and distributed so that the delivered content name is reflected in the metadata of the corresponding content.
CCN 어댑터 장치(250)는 인터넷망(300)과 CCN 망(400)을 연동하는 역할을 수행하는 것으로, HTTP 프로토콜을 따르는 메시지를 CCN 프로토콜을 지원하는 CCN 패킷으로 변환처리하는 기능을 수행할 수 있다. 아울러, 도면에서는 스트리밍 서버(200)와 CCN 어댑터 장치(250)를 독립적 장치 형태로 각각 도시하였으나, 이에 한정되는 것은 아니며 CCN 어댑터 장치(250)는 스트리밍 서버(200) 내의 일 모듈 형태로 존재할 수도 있다. The CCN adapter device 250 serves to interwork the Internet network 300 and the CCN network 400, and may perform a function of converting a message conforming to the HTTP protocol into a CCN packet supporting the CCN protocol. . In addition, although the streaming server 200 and the CCN adapter device 250 are illustrated as independent devices in the drawings, the present invention is not limited thereto, and the CCN adapter device 250 may exist as a module in the streaming server 200. .
CCN 망(400)은 컨텐츠 중심 네트워크 기반 컨텐츠 요청 및 이에 대한 응답으로 컨텐츠를 배포하고 제공할 수 있는 형태의 네트워크로, 이를 위해서는 CCN 노드(410)가 CCN 망(400) 상에 분산 배치될 수 있다. CCN network 400 is a type of network that can distribute and provide content in response to content-centric network-based content requests and the like, for this purpose CCN node 410 may be distributed distributed on the CCN network 400 .
CCN 노드(410)를 통한 컨텐츠 전송은 CCN 패킷을 통해 이뤄지게 된다. CCN 패킷은 컨텐츠의 이름을 패킷의 주소로 이용하여 컨텐츠를 송수신하게 되는데, 이러한 CCN 패킷은 컨텐츠를 요청하는 CCN 요청 패킷(Interest Packet)과 이에 대한 응답 패킷인 CCN 응답 패킷(Data Packet)을 포함하여 구성된다. Content transmission through the CCN node 410 is made through a CCN packet. The CCN packet transmits and receives contents using the name of the content as the address of the packet. The CCN packet includes a CCN request packet for requesting the content and a CCN response packet corresponding to the response packet. It is composed.
이때, CCN 응답 패킷은 CCN 요청 패킷이 전달된 경로를 역순으로 전송되므로 별도의 라우팅 과정이 불필요하나, CCN 요청 패킷은 어떤 CCN 노드(410)들을 거쳐 전송될 것인지 라우팅 정보를 저장하고 관리하는 과정이 필요하다. 이를 위해, CCN 노드(410)들은 FIB(Forwarding Information Base)를 저장하고 있어야 한다. In this case, since the CCN response packet is transmitted in the reverse order of the path through which the CCN request packet is transmitted, a separate routing process is unnecessary, but the process of storing and managing routing information about which CCN node 410 is to be transmitted through need. To this end, the CCN nodes 410 should store a forwarding information base (FIB).
CCN 망(400)에서의 컨텐츠 제공 방법에 대해 도 2를 참조하여 개략적으로 설명하도록 한다. A method of providing content in the CCN network 400 will be described with reference to FIG. 2.
도 2는 본 발명의 실시 예에 따른 컨테츠 중심 네트워크에서의 CCN 요청 패킷을 처리하는 과정을 설명하기 위한 예시도이다. 2 is an exemplary view for explaining a process of processing a CCN request packet in a content center network according to an embodiment of the present invention.
컨텐츠 중심 네트워크에서 컨텐츠의 이름은 컨텐츠가 저장된 노드를 찾아가기 위한 나침반 역할과 해당 컨텐츠를 다른 컨텐츠와 구분해 주는 역할을 할 수 있다. 그러므로, 각 컨텐츠는 고유한(unique) 이름을 사용하며, 두 컨텐츠의 이름이 서로 다르면, 같은 내용의 컨텐츠도 다른 컨텐츠로 취급할 수 있다. 예를 들어, 같은 내용으로 이루어진 두 파일이 각각 서로 다른 이름으로 존재할 경우, 두 파일은 서로 다른 컨텐츠로 처리될 수 있다. In a content-centric network, the name of a content may serve as a compass to navigate to a node where content is stored and to distinguish the content from other content. Therefore, each content uses a unique name, and if the names of the two contents are different from each other, the same content can be treated as another content. For example, if two files having the same contents exist under different names, the two files may be processed with different contents.
도 2에서, 어느 하나의 CCN 노드(400)가 페이스 0(101)으로부터 예를 들어, '/ABC.com/SSS/abc.avi/v3/s3/'에 해당하는 CCN 요청 패킷을 수신하게 되면, 상기 CCN 요청 패킷의 컨텐츠의 계층적 이름을 참조하여 해당 컨텐츠가 자신의 컨텐츠 스토어(Content Store)(110)에 있는 지 확인할 수 있다. 여기서, 컨텐츠 스토어(110)는 컨텐츠 캐시(Contents Cache)라고 불릴 수 있다. 확인 결과, 컨텐츠 스토어(110) 내에 해당 컨텐츠가 저장되어 있으면, CCN 노드(410)는 해당 컨텐츠를 CCN 요청 패킷이 수신된 페이스 0(101)로 반환한다. 이때, 페이스(face)는 인터페이스(interface)로도 표현될 수 있다.In FIG. 2, when one CCN node 400 receives a CCN request packet corresponding to, for example, '/ABC.com/SSS/abc.avi/v3/s3/' from face 0 101. By referring to the hierarchical name of the content of the CCN request packet, it can be checked whether the corresponding content is in its own content store 110. Here, the content store 110 may be referred to as a contents cache. As a result of the check, if the corresponding content is stored in the content store 110, the CCN node 410 returns the corresponding content to face 0 101 where the CCN request packet is received. In this case, the face may also be expressed as an interface.
해당 컨텐츠가 컨텐츠 스토어(110)에 저장되어 있지 않으면, CCN 노드(410)는 펜딩 인터리스트 테이블(Pending Interest Table; PIT)(130) 내에 동일한 컨텐츠 이름(여기서는 '/ABC.com/SSS/abc.avi/v3/s2')으로 저장된 엔트리 (entry)가 있는지 여부를 확인할 수 있다. CCN 노드(410)는 동일한 컨텐츠 이름으로 저장된 엔트리가 있으면, 펜딩 인터리스트 테이블(130) 내의 해당 엔트리에 CCN 요청 패킷이 들어온 페이스(여기서는 페이스 0(101))에 대한 정보를 추가할 수 있다.If the content is not stored in the content store 110, the CCN node 410 may have the same content name (here, '/ABC.com/SSS/abc. Pending Interest Table (PIT) 130). avi / v3 / s2 ') can check whether there is an entry saved. If there is an entry stored under the same content name, the CCN node 410 may add information on the face (here, face 0 101) in which the CCN request packet enters the corresponding entry in the pending interlist table 130.
반면, 펜딩 인터리스트 테이블(130) 내에 동일 컨텐츠 이름으로 등록된 엔트리가 없다면, CCN 노드(410)는 포워딩 정보 베이스(Forwarding Information Base; FIB)(150)에서 컨텐츠 이름에 기반한 검색(name lookup)을 수행하여 해당 엔트리(entry)를 찾을 수 있다. 이때, CCN 노드(410)는 최장 프리픽스 매칭(longest prefix matching)에 따라 검색을 수행할 수 있다.On the other hand, if there is no entry registered in the pending interlist table 130 with the same content name, the CCN node 410 performs a name lookup based on the content name in the forwarding information base (FIB) 150. You can do this to find the entry. In this case, the CCN node 410 may perform a search according to the longest prefix matching.
CCN 노드(410)는 포워딩 정보 베이스(FIB)(150)에 등록되어 있는 정보에 기초하여 CCN 요청 패킷을 전달할 페이스(예를 들어, 페이스 1(105))를 결정하고, 해당 페이스(페이스 1(105))로 CCN 요청 패킷을 전송할 수 있다. 이 과정에서 CCN 노드(410)는 CCN 요청 패킷이 전달되어 온 페이스(페이스 0(101))에 대한 정보('0')를 인터리스트 테이블(PIT)(130)에 등록할 수 있다. 이는 향후 CCN 요청 패킷에 대응되는, 컨텐츠를 포함하는 컨텐츠 응답 패킷인 CCN 응답 패킷을 단말(100)로 전달할 때, 해당 컨텐츠를 요청한 노드로 CCN 응답 패킷을 라우팅하기 위함이다. 여기서, 포워딩 정보 베이스(150)에 기초하여 CCN 요청 패킷을 전달할 페이스를 선택(결정)할 때, CCN 요청 패킷이 수신된 페이스(여기서는 페이스 0(101))는 선택 대상에서 제외될 수 있다.The CCN node 410 determines a face (for example, face 1 105) to deliver a CCN request packet based on information registered in the forwarding information base (FIB) 150, and determines the face (face 1 ( 105)) may transmit a CCN request packet. In this process, the CCN node 410 may register the information '0' on the face (face 0 101) to which the CCN request packet is delivered to the interlist table (PIT) 130. This is for routing the CCN response packet to the node that requested the content when delivering the CCN response packet, which is a content response packet including the content corresponding to the CCN request packet, to the terminal 100 in the future. Here, when selecting (determining) a face to which the CCN request packet is delivered based on the forwarding information base 150, the face where the CCN request packet is received (here, face 0 101) may be excluded from the selection target.
다시 도 1을 참조하면, 다수의 CCN 노드(410)는 전술한 바와 같이 FIB를 참조하여 CCN 요청 패킷을 전달하고자 하는 다른 CCN 노드(410)를 결정하고, PIT를 이용하여 CCN 응답 패킷에 대한 라우팅 과정 없이 단말(100)로 CCN 응답 패킷을 전달할 수 있다. Referring back to FIG. 1, the plurality of CCN nodes 410 determines another CCN node 410 to which the CCN request packet is to be delivered by referring to the FIB as described above, and uses the PIT to route the CCN response packet. The CCN response packet may be delivered to the terminal 100 without a process.
이러한 과정을 거쳐 CCN 응답 패킷은 CCN 어댑터 장치(250)로 전달될 수 있으며, CCN 어댑터 장치(250)는 CCN 응답 패킷을 컨텐츠 세그먼트 응답 메시지로 변환 처리한 후 단말(100)로 전송되는 과정을 지원할 수 있다. Through this process, the CCN response packet may be delivered to the CCN adapter device 250, and the CCN adapter device 250 may support a process of converting the CCN response packet into a content segment response message and then transmitting the same to the terminal 100. Can be.
또한, 해당 컨텐츠 세그먼트의 저장 장소가 변경되거나 오리진 서버로부터 전달되는 컨텐츠 세그먼트를 어느 하나의 CCN 노드(410)가 저장하는 경우, 이에 대한 컨텐츠 이름을 정의할 수 있는 정보를 스트리밍 서버(200)로 전달하고 스트리밍 서버(200)는 컨텐츠 이름을 정의한 후 메타데이터에 추가 또는 수정하는 과정을 수행할 수 있게 된다. In addition, when one CCN node 410 stores a content segment changed from a storage location of the corresponding content segment or an origin server, information for defining a content name thereof is transmitted to the streaming server 200. In addition, the streaming server 200 may perform a process of adding or modifying metadata after defining a content name.
본 발명의 인터넷망(300)은 다수의 기지국 장치(310)를 통해 연결되는 접속망(미도시) 및 코어망(미도시)을 거쳐 연결될 수 있다. 접속망(미도시)은 단말(100)과 유무선 통신을 수행하는 접속망으로서, 예를 들어, BS(Base Station), BTS(Base Transceiver Station), NodeB, eNodeB 등과 같은 다수의 기지국과, BSC(Base Station Controller), RNC(Radio Network Controller)와 같은 기지국 제어기로 구현될 수 있다.The internet network 300 of the present invention may be connected through an access network (not shown) and a core network (not shown) connected through a plurality of base station devices 310. An access network (not shown) is an access network that performs wired or wireless communication with the terminal 100. For example, a plurality of base stations such as a base station (BS), a base transceiver station (BTS), a NodeB, an eNodeB, and a base station (BSC) It may be implemented as a base station controller such as a controller, a radio network controller (RNC).
또 다른 방식으로는, 상기 기지국에 일체로 구현되어 있던 디지털 신호 처리부와 무선 신호 처리부를 각각 디지털 유니트(Digital Unit, 이하 DU라 함과 무선 유니트(Radio Unit, 이하 RU라 함)으로 구분하여, 다수의 영역에 각각 다수의 RU(미도시)를 설치하고, 다수의 RU(미도시)를 집중화된 DU(미도시)와 연결하여 구성할 수도 있다.As another method, a digital signal processor and a wireless signal processor, which are integrally implemented in the base station, are divided into digital units (hereinafter referred to as DUs and radio units (hereinafter referred to as RUs)). Each of the plurality of RUs (not shown) may be installed in the region of the plurality, and the plurality of RUs (not shown) may be configured by connecting with a centralized DU (not shown).
또한, 접속망(미도시)와 함께 망을 구성하는 코어망(미도시)은 접속망(미도시)과 외부 망, 예컨대, 인터넷망(300)을 연결하는 역할을 수행한다.In addition, the core network (not shown) constituting the network together with the access network (not shown) serves to connect the access network (not shown) and the external network, for example, the Internet network 300.
이러한 코어망(미도시)은 앞서 설명한 바와 같이, 접속망(미도시) 간의 이동성 제어 및 스위칭 등의 이동통신 서비스를 위한 주요 기능을 수행하는 네트워크 시스템으로서, 서킷 교환(circuit switching) 또는 패킷 교환(packet switching)을 수행하며, 모바일 망 내에서의 패킷 흐름을 관리 및 제어한다. 또한, 코어망(미도시)은 주파수간 이동성을 관리하고, 접속망(미도시) 및 코어망(미도시) 내의 트래픽 및 다른 네트워크, 예컨대 인터넷망(310)과의 연동을 위한 역할을 수행할 수도 있다. 코어망(미도시)은 상술한 구성 이외도 MSC(Mobile Switching Center), HLR(Home Location Register), MME(Mobile Mobility Entity)와 HSS(Home Subscriber Server) 등을 더 포함하여 구성될 수도 있다.As described above, the core network (not shown) is a network system that performs a main function for mobile communication services such as mobility control and switching between access networks (not shown), and includes circuit switching or packet switching. switching, and manages and controls the packet flow in the mobile network. In addition, the core network (not shown) may manage inter-frequency mobility, and may play a role for interworking with traffic in the access network (not shown) and the core network (not shown) and other networks such as the Internet network 310. have. In addition to the above-described configuration, the core network may further include a mobile switching center (MSC), a home location register (HLR), a mobile mobility entity (MME), a home subscriber server (HSS), and the like.
또한, 인터넷망(310)은 TCP/IP 프로토콜에 따라서 정보가 교환되는 통상의 공개된 통신망, 즉 공용망을 의미하는 것으로, 스트리밍 서버(200)와 연결되어, 스트리밍 서버(200)로부터 제공되는 컨텐츠를 코어망(미도시) 및 유무선 접속망(미도시)을 거쳐, 단말(100)로 제공하며, 단말(100)의 요청을 스트리밍 서버(200)로 전달하는 역할을 수행할 수 있다. In addition, the Internet network 310 refers to a conventional public communication network, that is, a public network, through which information is exchanged according to the TCP / IP protocol, and is connected to the streaming server 200 and provided from the streaming server 200. The core network (not shown) and the wired or wireless connection network (not shown), and may be provided to the terminal 100, and may transmit a request of the terminal 100 to the streaming server 200.
이상으로 본 발명의 컨텐츠 제공 시스템에 대해 간략히 설명하였으며, 이러한 컨텐츠 제공 시스템은 하드웨어, 소프트웨어 등의 컴퓨팅 자원을 저장하고, 클라이언트가 필요로 하는 컴퓨팅 자원을 해당 단말기로 제공할 수 있는 클라우드 컴퓨팅망을 포함할 수 있다. 여기서, 클라우드 컴퓨팅이란 정보가 인터넷 상의 서버에 영구적으로 저장되고, 데스크톱, 태블릿 컴퓨터, 노트북, 넷북, 스마트폰 등의 클라이언트 단말기에는 일시적으로 보관되는 컴퓨터 환경을 의미하며, 클라우드 컴퓨팅은 이용자의 모든 정보를 인터넷 상의 서버에 저장하고, 이 정보를 각종 IT 기기를 통하여 언제 어디서든 이용할 수 있도록 하는 컴퓨터 환경 접속망을 의미한다. 이러한, 인터넷망(300)은 LAN(Local Area Network), WAN(Wide Area Network) 등의 폐쇄형 네트워크, 인터넷(Internet)과 같은 개방형 네트워크뿐만 아니라, CDMA(Code Division Multiple Access), WCDMA(Wideband Code Division Multiple Access), GSM(Global System for Mobile Communications), 최근 주목 받고 있는 LTE(Long Term Evolution), EPC(Evolved Packet Core) 등의 네트워크와 향후 구현될 차세대 네트워크 및 클라우드 컴퓨팅 네트워크를 모두 포함하는 개념이다.As described above, the content providing system of the present invention has been briefly described. The content providing system includes a cloud computing network that stores computing resources such as hardware and software, and provides computing resources required by a client to a corresponding terminal. can do. Here, cloud computing refers to a computer environment in which information is permanently stored on a server on the Internet and temporarily stored in client terminals such as desktops, tablet computers, laptops, netbooks, and smartphones. It refers to a computer environment access network that stores a server on the Internet and makes this information available anytime, anywhere through various IT devices. Such an Internet network 300 is a closed network such as a local area network (LAN), a wide area network (WAN), an open network such as the Internet, as well as a code division multiple access (CDMA) and a wideband code (WCDMA). This concept includes both Division Multiple Access (GSM), Global System for Mobile Communications (GSM), Long Term Evolution (LTE), and Evolved Packet Core (EPC), as well as next-generation and cloud computing networks. .
또한, 본 발명의 실시 예에 따른 각 장치에 탑재되는 프로세서는 본 발명에 따른 방법을 실행하기 위한 프로그램 명령을 처리할 수 있다. 일 구현 예에서, 이 프로세서는 (Single-threaded) 프로세서일 수 있으며, 다른 구현 예에서 본 프로세서는 멀티 쓰레드(Multithreaded) 프로세서일 수 있다. 나아가 본 프로세서는 메모리 혹은 저장 장치 상에 저장된 명령을 처리하는 것이 가능하다.In addition, a processor mounted in each device according to an embodiment of the present invention may process a program command for executing a method according to the present invention. In one implementation, this processor may be a single-threaded processor, and in another implementation, the processor may be a multithreaded processor. Furthermore, the processor is capable of processing instructions stored on memory or storage devices.
이하, 본 발명의 실시 예에 따른 단말(100)의 구성 및 동작 방법에 대해 도 3을 참조하여 설명하도록 한다.Hereinafter, the configuration and operation method of the terminal 100 according to an embodiment of the present invention will be described with reference to FIG. 3.
도 3은 본 발명의 실시 예에 따른 단말의 주요 구성을 도시한 블록도이다.3 is a block diagram showing the main configuration of a terminal according to an embodiment of the present invention.
도 1 및 도 3을 참조하면, 본 발명의 실시 예에 따른 단말(100)은 통신부(110), 입력부(120), 제어부(130), 출력부(140) 및 저장부(150)를 포함하여 구성될 수 있다. 1 and 3, the terminal 100 according to an embodiment of the present invention includes a communication unit 110, an input unit 120, a control unit 130, an output unit 140, and a storage unit 150. Can be configured.
각 구성 요소에 대해 보다 구체적으로 설명하면, 먼저, 통신부(110)는 인터넷망(300)을 통해 스트리밍 서버(200)와 정보를 송수신하는 역할을 수행한다. 이를 위해 본 발명의 통신부(110)는 인터넷망(300)에 접속하는 절차를 수행할 수 있는데, 일정 반경 내 위치하는 기지국 장치(310)을 탐색하고, 탐색된 기지국 장치(310)의 접속 요청을 하여, 기지국 장치(310)에 접속되는 과정을 지원함으로써 접속망(미도시)에 접속될 수 있다. 여기서, 단말(100)의 통신부(110)가 접속망(미도시)의 기지국 장치(310)에 접속되는 과정은 공지된 다양한 구성을 채용할 수 있으므로, 구체적인 설명은 생략하도록 한다. 아울러, 통신부(110)가 기지국 장치(310)과 통신 절차를 수행 시 사용자 정보를 전송할 수 있다. 기본적으로 IMSI(International Mobile Subscriber Identity) 등과 같은 단말 식별번호 등을 기지국 장치(310)에 전송할 수 있으며, 기지국 장치(310)이 코어망(미도시)과의 접속 절차를 수행하는 동안, 단말 식별번호 등을 이용하여 가입자 정보를 확인할 수 있게 된다. Referring to each component in more detail, first, the communication unit 110 performs a role of transmitting and receiving information with the streaming server 200 through the Internet network (300). To this end, the communication unit 110 of the present invention may perform a procedure for accessing the Internet network 300. The base station apparatus 310 is located within a predetermined radius, and the access request of the found base station apparatus 310 is performed. Thus, by supporting the process of being connected to the base station apparatus 310, it can be connected to an access network (not shown). Here, the process of connecting the communication unit 110 of the terminal 100 to the base station apparatus 310 of the access network (not shown) may adopt a variety of well-known configuration, a detailed description thereof will be omitted. In addition, the communication unit 110 may transmit user information when performing a communication procedure with the base station apparatus 310. Basically, a terminal identification number such as an IMSI (International Mobile Subscriber Identity) or the like may be transmitted to the base station apparatus 310, and the terminal identification number while the base station apparatus 310 performs a connection procedure with a core network (not shown). Etc., subscriber information can be confirmed.
아울러, 본 발명의 실시 예에 따른 통신부(110)은 접속망(미도시)의 기지국 장치(310)을 통해 정상적으로 코어망(미도시)에 접속하게 되면, 컨텐츠를 요청하고 이를 수신할 수 있게 된다. In addition, when the communication unit 110 according to an embodiment of the present invention normally connects to the core network (not shown) through the base station apparatus 310 of the access network (not shown), it is possible to request and receive content.
입력부(120)는 사용자로부터 입력되는 숫자 및 문자 정보 등의 다양한 정보, 각종 기능 설정 및 단말(100)의 기능 제어와 관련하여 입력되는 신호를 제어부(130)로 전달한다. 특히, 본 발명의 입력부(120)는 스트리밍 서버(200)에 접속하기 위한 필요한 사용자 입력을 지원할 수 있다. The input unit 120 transmits a variety of information such as numeric and text information input from a user, a signal input in connection with various function settings and function control of the terminal 100, to the controller 130. In particular, the input unit 120 of the present invention may support a user input necessary for accessing the streaming server 200.
이러한 입력부(120)는 상술한 바와 같이, 키보드나 키패드와 같은 키 입력 수단, 터치센서나 터치 패드와 같은 터치 입력 수단, 음성 입력 수단, 자이로 센서, 지자기 센서, 가속도 센서와 근접 센서, 그리고 카메라 중 적어도 하나 이상을 포함하여 이루어지는 제스처 입력 수단을 포함할 수도 있다.As described above, the input unit 120 includes a key input means such as a keyboard or a keypad, a touch input means such as a touch sensor or a touch pad, a voice input means, a gyro sensor, a geomagnetic sensor, an acceleration sensor and a proximity sensor, and a camera. It may also include a gesture input means comprising at least one or more.
이 외에도 현재 개발 중이거나 향후 개발될 수 있는 모든 형태의 입력 수단이 포함될 수 있다.In addition, it may include all types of input means that are currently under development or may be developed in the future.
제어부(130)는 단말(100)의 전반적인 제어를 수행하는 것으로, 하드웨어적으로 CPU(Central Processing Unit)를 포함하는 적어도 하나 이상의 프로세서와 적어도 하나 이상의 메모리 로딩 데이터가 로딩되는 실행 메모리(예컨대, 레지스터 및/또는 RAM(Random Access Memory)) 및 상기 프로세서와 메모리로 적어도 하나 이상의 데이터들을 입출력하는 버스(BUS)를 포함하여 이루어질 수 있다. 또한 소프트웨어적으로 단말(100)에 정의된 기능을 수행하기 위해 소정의 기록매체로부터 상기 실행 메모리로 로딩되어 상기 프로세서에 의해 연산 처리되는 소정의 프로그램 루틴(Routine) 또는 프로그램 데이터를 포함하여 이루어질 수 있다. 다시 말해, 본 발명의 실시 예에 따른 컨텐츠 수신 및 재생 처리를 위해 단말(100)에 구비되는 기능 중 소프트웨어적으로 처리가 가능한 구성 요소를 제어부(130)의 기능으로 판단할 수 있다. The controller 130 performs overall control of the terminal 100, and includes at least one processor including a central processing unit (CPU) and an execution memory (eg, a register and at least one memory loading data) loaded in hardware. And / or a random access memory (RAM) and a bus that inputs and outputs at least one data into the processor and memory. In addition, it may include a predetermined program routine (Routine) or program data that is loaded into the execution memory from a predetermined recording medium to be performed by the processor to perform a function defined in the terminal 100 by software. . In other words, among the functions provided in the terminal 100 for the content receiving and playing process according to an embodiment of the present invention, a component that can be processed in software may be determined as the function of the controller 130.
이러한, 본 발명의 제어부(130)는 본 발명의 실시 예에 따른 컨텐츠 전송 및 재생 처리를 위해 구비되는 적어도 하나 이상의 구성 요소와 기능적으로 연결된다. 즉, 제어부(130)는 통신부(110), 입력부(120), 저장부(140) 및 출력부(150)와 기능적으로 연결되며, 상기 각 구성 요소에 전원 공급 및 기능 수행을 위한 신호의 흐름을 제어하게 된다.As such, the controller 130 of the present invention is functionally connected to at least one component provided for content transmission and playback processing according to an embodiment of the present invention. That is, the controller 130 is functionally connected to the communication unit 110, the input unit 120, the storage unit 140, and the output unit 150, and controls the flow of signals for supplying power and performing functions to the components. Control.
특히, 본 발명의 실시 예에 따른 제어부(130)는 컨텐츠 재생 처리 모듈(131)을 포함하여 구성될 수 있다. In particular, the controller 130 according to an embodiment of the present invention may include a content reproduction processing module 131.
컨텐츠 재생 처리 모듈(131)은 컨텐츠 요청 및 수신, 재생과 관련된 전반을 제어한다. 예컨대, 컨텐츠 재생 처리 모듈(131)은 재생 어플리케이션을 실행을 수행할 수 있다. 여기서 재생 어플리케이션은 스트리밍 서버(200)가 제공하는 컨텐츠를 재생할 수 있는 기능을 수행한다. 예를 들어, 스트리밍 서버(200)가 제공하는 고화질의 컨텐츠를 재생할 수 있는 어플리케이션이 될 수 있다. 그러나 이에 한정되는 것은 아니며 스트리밍 서버(200)가 제공하는 컨텐츠를 재생할 수 있는 것이라면 그 어떠한 어플리케이션(예컨대 브라우저)도 본 발명의 재생 어플리케이션이 될 수 있다. The content reproduction processing module 131 controls overall contents related to content request, reception, and reproduction. For example, the content reproduction processing module 131 may execute a reproduction application. Here, the playback application performs a function of playing back the content provided by the streaming server 200. For example, it may be an application capable of playing high quality content provided by the streaming server 200. However, the present invention is not limited thereto, and any application (for example, a browser) may be a playback application of the present invention as long as the streaming server 200 can play content provided by the streaming server 200.
그리고 컨텐츠 재생 처리 모듈(131)은 메타데이터인 MPD 정보를 확인한다. 상기 MPD를 통해 본 발명의 컨텐츠 재생 처리 모듈(131)은 각 세그먼트에 대한 주소 정보(URL)을 확인할 수 있으며, 해당 스트리밍 서버(200)로 컨텐츠 세그먼트를 요청하여 수신할 수 있다. 이때, 본 발명의 컨텐츠 재생 처리 모듈(131)은 각 세그먼트에 대한 식별 정보를 확인하고 식별 정보가 동일한 경우 동시에 서브스트림을 요청하여 수신하고, 이를 재생 처리하는 과정을 수행할 수 있다. The content reproduction processing module 131 checks the MPD information, which is metadata. Through the MPD, the content reproduction processing module 131 of the present invention may check address information (URL) for each segment, and may request and receive a content segment from the corresponding streaming server 200. In this case, the content reproduction processing module 131 of the present invention may check the identification information of each segment, and if the identification information is the same, request and receive a substream at the same time, and perform a process of processing the reproduction.
아울러, 본 발명의 제어부(130)는 디코딩 모듈(미도시)을 더 포함하여 구성될 수 있으며, 컨텐츠 재생 처리 모듈(131)로부터 전달되는 세그먼트를 디코딩 수행하고 이에 대한 결과를 컨텐츠 재생 처리 모듈(131)로 전달하여 컨텐츠가 재생되도록 지원하게 된다. In addition, the controller 130 of the present invention may further include a decoding module (not shown), and decodes the segment transmitted from the content reproduction processing module 131 and outputs the result of the content reproduction processing module 131. ) To play the content.
저장부(140)는 본 발명의 실시 예에 따른 기능 동작에 필요한 응용 프로그램을 비롯하여, 그 응용 프로그램 실행 중에 발생되는 다양한 데이터를 일시적으로 저장할 수 있다. 특히, 본 발명의 실시 예에 따른 저장부(140)는 스트리밍 서버(200)가 제공하는 컨텐츠를 실행할 수 있는 재생 어플리케이션(151)과 관련된 정보를 저장하고 관리할 수 있으며, 수신되는 컨텐츠 세그먼트를 저장하고 관리할 수 있다. The storage 140 may temporarily store various data generated during execution of the application program, including an application program required for operating a function according to an embodiment of the present invention. In particular, the storage 140 according to an embodiment of the present invention may store and manage information related to the playback application 151 that can execute the content provided by the streaming server 200, and store the received content segment. Can be managed.
이러한 저장부(140)는 크게 프로그램 영역과 데이터 영역을 포함할 수 있다. 프로그램 영역은 단말(100)을 부팅시키는 운영체제(OS)와 같은 단말(100) 구동을 위한 관련된 정보들을 저장한다. 데이터 영역은 단말(100)의 사용에 따라 발생되는 데이터가 저장되는 영역으로, 상술한 바와 같이 재생 어플리케이션 및 인터넷망(300)로부터 전달되는 컨텐츠 세그먼트가 저장될 수 있다. 이러한, 저장부(140)는 플래시 메모리(flash memory), 하드디스크(hard disk), 멀티미디어 카드 마이크로(multimedia card micro) 타입의 메모리(예컨대, SD 또는 XD 메모리 등), 램(RAM), 롬(ROM) 등의 저장매체를 포함하여 구성될 수 있다.The storage 140 may largely include a program area and a data area. The program area stores related information for driving the terminal 100 such as an operating system (OS) for booting the terminal 100. The data area is an area in which data generated according to the use of the terminal 100 is stored, and as described above, the content segment delivered from the playback application and the internet network 300 may be stored. The storage unit 140 may include a flash memory, a hard disk, a multimedia card micro type memory (eg, SD or XD memory, etc.), a RAM, a ROM, and the like. ROM) and a storage medium.
출력부(150)는 단말(100)의 기능 수행 중에 발생하는 일련의 동작 상태 및 동작 결과 등에 대한 정보를 표시한다. 특히, 본 발명의 출력부(150)는 재생 어플리케이션 실행과 관련된 다양한 정보를 표시할 수 있다. The output unit 150 displays information on a series of operation states and operation results that occur during the functioning of the terminal 100. In particular, the output unit 150 of the present invention may display various information related to the execution of the playback application.
이러한, 출력부(150)는 상술한 바와 같이 입력부(120)와 함께 하나의 터치패널(또는 터치스크린)의 형태로 구현될 수도 있으며, 상기 입력부(120)와 함께 구현되는 경우, 사용자의 터치 동작에 따라 발생되는 다양한 정보들을 표시할 수 있다.As described above, the output unit 150 may be implemented in the form of a single touch panel (or touch screen) together with the input unit 120, and when implemented together with the input unit 120, a user's touch operation. Various information generated according to the present invention can be displayed.
또한, 상술한 바와 같은 본 발명의 출력부(150)는 LCD(Liquid Crystal Display), TFT-LCD(Thin Film Transistor LCD), OLED(Organic Light Emitting Diodes), 발광다이오드(LED), AMOLED(Active Matrix Organic LED), 플렉시블 디스플레이(Flexible display) 및 3차원 디스플레이(3 Dimension) 등으로 구성될 수 있다. 또한 이들 중 일부 디스플레이는 그를 통해 외부를 볼 수 있도록 투명형 또는 광투과형으로 구성될 수 있다. 이는 TOLED(Transparant OLED)를 포함하는 투명 디스플레이 형태로 구성될 수 있다.In addition, the output unit 150 of the present invention as described above is a liquid crystal display (LCD), thin film transistor LCD (TFT-LCD), organic light emitting diodes (OLED), light emitting diodes (LED), AMOLED (Active Matrix) Organic LED), a flexible display (Flexible display) and a three-dimensional display (3 Dimension) and the like. Some of these displays may also be configured to be transparent or light transmissive so that they can be seen from the outside. It may be configured in the form of a transparent display including a transparent OLED (TOLED).
이와 같이, 도 3을 통해 단말(100)의 주요 구성요소에 대해 설명하였다. 그러나 도 3을 통해 도시된 구성요소가 모두 필수 구성요소인 것은 아니며, 도시된 구성요소보다 많은 구성 요소에 의해 단말(100)이 구현될 수도 있고, 그 보다 적은 구성요소에 의해 단말(100)이 구현될 수도 있다. 예컨대, 단말(100)은 전기적인 신호인 음원을 아날로그 신호로 변환하여 출력하는 음원 출력부(미도시)를 더 포함하여 구성될 수도 있다. As such, the main components of the terminal 100 have been described with reference to FIG. 3. However, not all components illustrated in FIG. 3 are essential components, and the terminal 100 may be implemented by more components than the illustrated components, and the terminal 100 may be implemented by fewer components. It may be implemented. For example, the terminal 100 may further include a sound source output unit (not shown) for converting a sound source, which is an electrical signal, into an analog signal and outputting the analog signal.
또한, 도 3을 통해 도시된 단말(100)의 주요 구성요소의 위치는 얼마든지 편의상 또는 다른 이유로 바뀔 수 있음이 물론이다. In addition, the position of the main components of the terminal 100 shown in FIG. 3 may be changed for convenience or other reasons.
또한, 본 발명의 실시 예에 따른 단말(100)의 구체적인 동작은 후술하는 흐름도를 통해 보다 명확하게 이해될 수 있을 것이다. In addition, the specific operation of the terminal 100 according to an embodiment of the present invention will be more clearly understood through the flowchart described below.
이하, 본 발명의 실시 예에 따른 스트리밍 서버(200)의 주요 구성 및 동작 방법에 대해 설명하도록 한다. Hereinafter, the main configuration and operation method of the streaming server 200 according to an embodiment of the present invention.
도 4는 본 발명의 실시 예에 따른 스트리밍 서버의 주요 구성을 도시한 블록도이다. 4 is a block diagram showing the main configuration of a streaming server according to an embodiment of the present invention.
먼저, 도 1 및 도 4를 참조하면, 본 발명의 실시 예에 따른 스트리밍 서버(200)는 서버 통신부(210), 서버 제어부(220) 및 서버 저장부(230)를 포함하여 구성될 수 있다.First, referring to FIGS. 1 and 4, the streaming server 200 according to an embodiment of the present invention may include a server communication unit 210, a server control unit 220, and a server storage unit 230.
각 구성 요소에 대해 보다 구체적으로 설명하면, 서버 통신부(210)는 통신망(300)을 통해 단말(100)과 필요한 정보를 송수신하는 역할을 수행한다. In more detail with respect to each component, the server communication unit 210 serves to transmit and receive the necessary information with the terminal 100 through the communication network (300).
서버 제어부(220)는 MPD 구성 모듈(221), 변환 처리 모듈(222) 및 서비스 지원 모듈(223)을 포함하여 구성된다. The server controller 220 includes an MPD configuration module 221, a conversion processing module 222, and a service support module 223.
여기서, '모듈'은 각각 소정의 기능을 수행하는 구성 요소로서, 하드웨어, 소프트웨어, 혹은 하드웨어와 소프트웨어의 조합으로 구현될 수 있다. 예를 들어, 상기 '모듈'은 프로그램 모듈을 의미할 수 있으며, 이는 프로세서(Processor)에 의해 실행되어 소정의 기능을 수행하는, 소프트웨어 구성요소들, 객체지향 소프트웨어 구성요소들, 클래스 구성요소들 및 태스크 구성요소들과 같은 구성요소들과, 프로세스들, 함수들, 속성들, 프로시저들, 서브루틴들, 프로그램 코드의 세그먼트들, 드라이버들, 데이터, 데이터베이스, 데이터 구조들, 테이블들, 어레이들, 및 변수들을 포함한다. 또한, 구성요소들과 '모듈'들 안에서 제공되는 기능은 더 작은 수의 구성요소들 및 '~모듈'들로 결합되거나 추가적인 구성요소들과 '~모듈'들로 더 분리될 수 있다.Here, the 'module' is a component that performs a predetermined function, respectively, can be implemented in hardware, software, or a combination of hardware and software. For example, the 'module' may mean a program module, which is executed by a processor to perform a predetermined function, software components, object-oriented software components, class components and Components such as task components, processes, functions, properties, procedures, subroutines, segments of program code, drivers, data, databases, data structures, tables, arrays , And variables. In addition, the functionality provided in the components and 'modules' may be combined into a smaller number of components and '~ modules' or further separated into additional components and '~ modules'.
먼저 MPD 구성 모듈(221)은 컨텐츠에 대한 메타데이터를 생성하고 관리한다. 또한 메타데이터를 수정하고 단말(100)로 배포되는 과정을 제어할 수 있다. First, the MPD configuration module 221 generates and manages metadata about content. In addition, the metadata may be modified and the process of distribution to the terminal 100 may be controlled.
변환 처리 모듈(222)은 도 1에 도시된 CCN 어댑터 장치(250)의 기능이 모듈화하여 서버 제어부(220)내 포함되는 실시 예를 설명하기 위한 것으로, 단말(100)의 HTTP 프로토콜에 따른 요청을 CCN 프로토콜에 대한 요청으로 변환처리하고, CCN 프로토콜에 대한 응답을 HTTP 프로토콜에 따른 응답으로 변환처리하는 과정 전반을 제어할 수 있다. The conversion processing module 222 is for explaining an embodiment in which the function of the CCN adapter device 250 illustrated in FIG. 1 is modularized and included in the server controller 220. The request processing according to the HTTP protocol of the terminal 100 is performed. The process of converting the request to the CCN protocol and converting the response to the CCN protocol into the response according to the HTTP protocol can be controlled.
이러한 본 발명의 변환 처리 모듈(222)은 도 1에 도시된 바와 같이 독립된 CCN 어댑터 장치(250)로 구현되는 경우 생략될 수 있다. The conversion processing module 222 of the present invention may be omitted when implemented as a separate CCN adapter device 250 as shown in FIG.
서비스 지원 모듈(223)은 단말(100)의 요청에 따라 상기 단말(100)로 컨텐츠를 전송하기 위한 과정 전반을 제어할 수 있다. 예를 들어, 등록된 사용자를 대상으로 컨텐츠를 전송한다면 회원 가입 인증을 수행할 수 있다. 또한, 단말(100)로 메타데이터를 전달하는 역할을 수행하며, 컨텐츠 세그먼트가 단말(100)로 원활히 전달되는 과정을 지원할 수 있다. The service support module 223 may control the overall process for transmitting content to the terminal 100 at the request of the terminal 100. For example, if content is transmitted to registered users, membership authentication may be performed. In addition, it plays a role of transmitting metadata to the terminal 100 and may support a process of smoothly delivering the content segment to the terminal 100.
아울러, 본 발명의 서버 제어부(220)는 인코딩 과정을 수행하는 경우, 인코딩 모듈을 더 포함하여 구성될 수도 있다. In addition, when performing the encoding process, the server controller 220 of the present invention may further include an encoding module.
서버 저장부(230)는 본 발명의 스트리밍 서버(200)의 동작 수행과 관련된 정보를 저장하는 것으로 특히, MPD 정보(231)을 저장하고 관리할 수 있다. The server storage unit 230 stores information related to performance of the streaming server 200 of the present invention, and in particular, may store and manage the MPD information 231.
또한, 도면에는 도시되지 않았으나, 본 발명의 스트리밍 서버(200)가 등록된 사용자를 대상으로 서비스를 제공하는 경우, 회원 가입 및 인증을 위한 인적 정보 등을 저장하고 관리할 수 있다. 또한 본 발명의 스트리밍 서버(2000 내 저장 장소에 컨텐츠 세그먼트를 저장하고 관리할 경우, 해당 서브스트림을 포함할 수 있다. In addition, although not shown in the drawing, when the streaming server 200 of the present invention provides a service to a registered user, personal information for membership registration and authentication may be stored and managed. In addition, when storing and managing a content segment in a storage location in the streaming server 2000 of the present invention, it may include a corresponding substream.
이러한 본 발명의 실시 예에 따른 스트리밍 서버(200)의 구체적인 동작은 후술하는 흐름도를 통해 보다 명확하게 이해될 수 있을 것이다. The specific operation of the streaming server 200 according to an embodiment of the present invention will be more clearly understood through the flow chart described below.
이하, 본 발명의 실시 예에 따른 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법을 설명하도록 한다. Hereinafter, a content providing method through content-oriented network interworking according to an embodiment of the present invention will be described.
도 5는 본 발명의 실시 예에 따른 단말에서의 컨텐츠 이용 방법을 설명하기 위한 흐름도이다. 5 is a flowchart illustrating a content using method in a terminal according to an exemplary embodiment of the present invention.
도 1 및 도 5를 참조하면, 본 발명의 단말(100)은 스트리밍 서버(200)가 제공하는 컨텐츠를 이용하기 위해 먼저 재생 어플리케이션을 실행한다(S101).1 and 5, the terminal 100 of the present invention first executes a playback application to use the content provided by the streaming server 200 (S101).
여기서 재생 어플리케이션은 스트리밍 서버(200)가 제공하는 컨텐츠를 재생할 수 있는 기능을 수행한다. 예를 들어, 스트리밍 서버(200)가 제공하는 고화질의 컨텐츠를 재생할 수 있는 어플리케이션이 될 수 있다. 그러나 이에 한정되는 것은 아니며 스트리밍 서버(200)가 제공하는 컨텐츠를 재생할 수 있는 것이라면 그 어떠한 어플리케이션(예컨대 브라우저)도 본 발명의 재생 어플리케이션이 될 수 있다. Here, the playback application performs a function of playing back the content provided by the streaming server 200. For example, it may be an application capable of playing high quality content provided by the streaming server 200. However, the present invention is not limited thereto, and any application (for example, a browser) may be a playback application of the present invention as long as the streaming server 200 can play content provided by the streaming server 200.
아울러, 본 발명의 재생 어플리케이션은 미리 스트리밍 서버(200) 또는 별도의 컨텐츠 스토어로부터 미리 다운로드 받아 단말(100) 내 설치된 상태인 것이 바람직하나 이에 한정되는 것은 아니며, 클라우드 방식으로 상기 재생 어플리케이션을 실행할 수도 있다. In addition, the playback application of the present invention is preferably downloaded in advance from the streaming server 200 or a separate content store is installed in the terminal 100, but is not limited thereto, and may execute the playback application in a cloud manner. .
이후에 본 발명의 단말(100)은 메타데이터인 MPD 정보를 확인한다(S203). 상기 MPD를 통해 본 발명의 단말(100)은 각 컨텐츠 세그먼트별로 주소 정보(URL)를 확인할 수 있으며(S105), 해당 주소 정보에 대응하는 장치로 컨텐츠 세그먼트 요청 메시지(HTTP REQUEST)를 전송한다(S107).Thereafter, the terminal 100 of the present invention checks the MPD information, which is metadata (S203). Through the MPD, the terminal 100 may check address information (URL) for each content segment (S105), and transmit a content segment request message (HTTP REQUEST) to a device corresponding to the address information (S107). ).
이때, 상기 컨텐츠 세그먼트 요청 메시지는 스트리밍 서버(200)를 목적지 주소로 하여 전송될 수 있으며, 이후에 스트리밍 서버(200)로부터 컨텐츠 세그먼트 응답 메시지(HTTP RESPONSE)를 수신하여(S109), 이를 재생할 수 있게 된다(S111). 이때, 본 발명의 단말(100)은 상기 컨텐츠 세그먼트 응답 메시지가 인코딩된 경우 이를 디코딩하는 과정을 처리할 수 있다. In this case, the content segment request message may be transmitted using the streaming server 200 as a destination address, and thereafter, a content segment response message (HTTP RESPONSE) is received from the streaming server 200 (S109), so that the content segment can be reproduced. (S111). In this case, the terminal 100 of the present invention may process a process of decoding the content segment response message when it is encoded.
이하, 본 발명의 실시 예에 따른 스트리밍 서버에서의 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법을 설명하도록 한다. Hereinafter, a content providing method through content-oriented network interworking in a streaming server according to an exemplary embodiment of the present invention will be described.
도 6은 본 발명의 실시 예에 따른 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법을 설명하기 위한 흐름도이다. 6 is a flowchart illustrating a content providing method through interworking with a content-oriented network according to an exemplary embodiment of the present invention.
도 6을 참조하여 설명하기에 앞서, 설명의 편의를 위해 본 발명의 스트리밍 서버(200)가 CCN 어댑터 장치(250)의 기능을 포함하여 구성되는 것을 가정하여 설명하도록 하나, 이에 한정되는 것은 아니며, CCN 어댑터 장치(250)에서 해당 단계가 구현될 수도 있다.Before describing with reference to FIG. 6, it is assumed that the streaming server 200 of the present invention includes the functions of the CCN adapter device 250 for convenience of description, but is not limited thereto. The corresponding step may be implemented in the CCN adapter device 250.
도 1 및 도 6을 참조하면, 본 발명의 스트리밍 서버(200)는 단말(100)로부터 컨텐츠 세그먼트 요청 메시지를 수신한다(S201). 본 발명의 스트리밍 서버(200)는 수신된 컨텐츠 세그먼트 요청 메시지를 CCN 망(400)으로 전달하기 위해 CCN 요청 패킷으로 변환한다(S203). 1 and 6, the streaming server 200 of the present invention receives a content segment request message from the terminal 100 (S201). The streaming server 200 of the present invention converts the received content segment request message into a CCN request packet to transmit to the CCN network 400 (S203).
이때, 본 발명의 스트리밍 서버(200)는 먼저 상기 컨텐츠 세그먼트 요청 메시지에 대응하는 컨텐츠 세그먼트를 자신이 보유하고 있는 지 확인하고, 보유하고 있을 경우, 해당 컨텐츠 세그먼트를 포함하는 컨텐츠 세그먼트 응답 메시지를 상기 단말(100)로 전송하는 과정을 수행할 수 있다. In this case, the streaming server 200 of the present invention first checks whether it owns a content segment corresponding to the content segment request message, and if so, the terminal sends a content segment response message including the content segment to the terminal. The process of transmitting to 100 may be performed.
아울러, 본 발명의 스트리밍 서버(200)는 해당 컨텐츠 세그먼트를 자신이 저장하고 있지 않을 경우, 이를 CCN 망(400)에서 처리 가능하도록 CCN 패킷인 CCN 요청 패킷으로 변환하게 된다. 이를 위해 본 발명의 스트리밍 서버(200)는 컨텐츠의 메타데이터를 확인하여, 해당 컨텐츠 세그먼트에 대응하는 컨텐츠 이름을 확인하고 컨텐츠 이름을 포함하는 CCN 요청 패킷을 생성하게 된다. 여기서 컨텐츠 이름은 해당 컨텐츠 세그먼트를 저장하고 있는 저장 장소의 이름 정보, 컨텐츠 식별자 및 컨텐츠 세그먼트 식별자로 구성될 수 있다. In addition, when the streaming server 200 of the present invention does not store the corresponding content segment, the streaming server 200 converts it into a CCN packet, which is a CCN packet, so that the CCN network 400 can process it. To this end, the streaming server 200 of the present invention checks the metadata of the content, checks the content name corresponding to the corresponding content segment, and generates a CCN request packet including the content name. Here, the content name may include name information of a storage location storing the corresponding content segment, a content identifier, and a content segment identifier.
CCN 요청 패킷이 CCN 망(400)으로 전달되면(S205), CCN 망(400)에 위치하는 복수 개의 CCN 노드들은 라우팅 과정을 수행할 수 있다. 즉, 상기 컨텐츠 이름에 대응하는 컨텐츠 세그먼트를 자신이 저장하고 있는 지 여부를 확인한 후 저장하고 있을 경우 이를 스트리밍 서버(200)로 전달하며 그렇지 않을 경우, 오리진(origin) 서버인 컨텐츠 제공자(CP; Contents Provider)의 저장 장소까지 해당 CCN 요청 패킷은 전달될 수 있다. 그리고 컨텐츠 제공자로부터 CCN 응답 패킷을 전달받은 CCN 노드들은 이를 스트리밍 서버(200)론 전달하게 된다. When the CCN request packet is delivered to the CCN network 400 (S205), a plurality of CCN nodes located in the CCN network 400 may perform a routing process. That is, after checking whether the content segment corresponding to the content name is being stored and transmitting the content segment to the streaming server 200, the content segment corresponding to the content name is transmitted to the streaming server 200. If not, the content segment corresponding to the content name is the origin server. The CCN request packet can be delivered to the storage location of the provider). The CCN nodes that have received the CCN response packet from the content provider deliver this to the streaming server 200.
스트리밍 서버(200)는 CCN 요청 패킷에 대한 응답 패킷인 CCN 응답 패킷을 CCN 망(400)으로부터 수신하게 되면(S207), 이를 단말(100)로 전송하기 위해 컨텐츠 세그먼트 응답(HTTP RESPONSE) 메시지로 변환하게 되고(S209), 단말(100)로 컨텐츠 세그먼트 응답 메시지를 전송할 수 있다(S211).When the streaming server 200 receives the CCN response packet, which is a response packet for the CCN request packet, from the CCN network 400 (S207), the streaming server 200 converts the content segment response (HTTP RESPONSE) message to the terminal 100 for transmission. In operation S209, the content segment response message may be transmitted to the terminal 100 in operation S211.
아울러, 본 발명의 스트리밍 서버(200)는 S207 단계에서 해당 컨텐츠 세그먼트를 보유하고 있는 CCN 노드들에 대한 정보를 상기 CCN 응답 패킷의 컨텐츠 이름을 통해 확인할 수 있으며, 상기 컨텐츠 이름을 상기 컨텐츠의 메타데이터에 저장할 수 있다. 그리고 변경된 메타데이터를 단말(100)로 전송하여 보다 신속한 컨텐츠 제공이 가능하도록 지원할 수 있다. In addition, the streaming server 200 of the present invention can check the information on the CCN nodes holding the content segment in step S207 through the content name of the CCN response packet, the content name of the content metadata Can be stored in In addition, the changed metadata may be transmitted to the terminal 100 to support a faster content provision.
본 발명의 실시 예에 따른 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법은 스트리밍 서버(200)와 CCN 어댑터 장치(250) 간의 연동을 통해 이뤄질 수 있다. 즉, 도 6에서는 CCN 어댑터 장치(250)의 기능이 스트리밍 서버(200) 내에 포함된 형태로 동작하는 것을 기술하였는데, 본 발명의 CCN 어댑터 장치(250)의 기능은 독립적으로 동작할 수도 있다. Content providing method through the content-centric network interworking according to an embodiment of the present invention may be achieved through the interworking between the streaming server 200 and the CCN adapter device 250. That is, in FIG. 6, the function of the CCN adapter device 250 operates in a form included in the streaming server 200, but the function of the CCN adapter device 250 of the present invention may operate independently.
이에 대해 도 7을 참조하여 설명하도록 한다. This will be described with reference to FIG. 7.
도 7은 본 발명의 실시 예에 따른 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법을 보다 더 구체적으로 설명한 데이터 흐름도이다. 7 is a data flow diagram illustrating in more detail a content providing method through content-centric network interworking according to an embodiment of the present invention.
도 7을 참조하면, 먼저 단말(100)은 스트리밍 서버(200)가 제공하는 컨텐츠를 이용하기 위해 재생 어플리케이션을 실행한다(S301).Referring to FIG. 7, first, the terminal 100 executes a playback application to use contents provided by the streaming server 200 (S301).
여기서 재생 어플리케이션은 스트리밍 서버(200)가 제공하는 컨텐츠를 재생할 수 있는 기능을 수행한다. 예를 들어, 스트리밍 서버(200)가 제공하는 고화질의 컨텐츠를 재생할 수 있는 어플리케이션이 될 수 있다. 그러나 이에 한정되는 것은 아니며 스트리밍 서버(200)가 제공하는 컨텐츠를 재생할 수 있는 것이라면 그 어떠한 어플리케이션(예컨대 브라우저)도 본 발명의 재생 어플리케이션이 될 수 있다. Here, the playback application performs a function of playing back the content provided by the streaming server 200. For example, it may be an application capable of playing high quality content provided by the streaming server 200. However, the present invention is not limited thereto, and any application (for example, a browser) may be a playback application of the present invention as long as the streaming server 200 can play content provided by the streaming server 200.
아울러, 본 발명의 재생 어플리케이션은 미리 스트리밍 서버(200) 또는 별도의 컨텐츠 스토어로부터 미리 다운로드 받아 단말(100) 내 설치된 상태인 것이 바람직하나 이에 한정되는 것은 아니며, 클라우드 방식으로 상기 재생 어플리케이션을 실행할 수도 있다. In addition, the playback application of the present invention is preferably downloaded in advance from the streaming server 200 or a separate content store is installed in the terminal 100, but is not limited thereto, and may execute the playback application in a cloud manner. .
이후에 본 발명의 단말(100)은 메타데이터인 MPD 정보를 확인한다(S303). 상기 MPD를 통해 본 발명의 단말(100)은 각 컨텐츠 세그먼트별로 주소 정보(URL)를 확인할 수 있으며(S305), 해당 주소 정보에 대응하는 스트리밍 서버(200)로 컨텐츠 세그먼트 요청 메시지(HTTP REQUEST)를 전송한다(S307).Thereafter, the terminal 100 of the present invention checks the MPD information, which is metadata (S303). The terminal 100 of the present invention through the MPD can check the address information (URL) for each content segment (S305), the content segment request message (HTTP REQUEST) to the streaming server 200 corresponding to the address information It transmits (S307).
이를 수신한 스트리밍 서버(200)는 CCN 어댑터 장치(250)로 전달하게 된다(S309). 본 발명의 CCN 어댑터 장치(250)는 인터넷망(300)과 CCN 망(400)을 연결하는 역할을 수행하는 것으로, HTTP 프로토콜을 따르는 메시지를 CCN 프로토콜을 따르는 패킷 형태로 변환 처리할 수 있는 장치이다. The streaming server 200 receiving this is transmitted to the CCN adapter device 250 (S309). The CCN adapter device 250 of the present invention serves to connect the Internet network 300 and the CCN network 400, and is a device capable of converting and processing a message conforming to the HTTP protocol into a packet form conforming to the CCN protocol. .
이러한 본 발명의 CCN 어댑터 장치(250)는 스트리밍 서버(200)로부터 전달된 컨텐츠 세그먼트 요청 메시지를 CCN 요청 패킷으로 변환하기 위해, 먼저 CCN 컨텐츠 이름을 확인한다(S311). 상기 이름 정보는 상기 컨텐츠의 메타데이터를 확인하여 이뤄질 수 있다. The CCN adapter device 250 of the present invention first checks the CCN content name in order to convert the content segment request message transmitted from the streaming server 200 into a CCN request packet (S311). The name information may be achieved by checking metadata of the content.
그리고 CCN 어댑터 장치(250)는 확인된 컨텐츠 이름을 포함하여 CCN 요청 패킷으로 변환하고(S313), 이를 CCN 망(400)으로 전달한다. CCN 망(400)을 구성하는 복수 개의 CCN 노드들은 상기 컨텐츠 이름에 해당하는 컨텐츠 세그먼트를 저장하고 있는 CCN 노드들을 찾아 라우팅 과정을 수행하게 된다(S317). 그리고 어느 하나의 CCN 노드에 해당 컨텐츠 세그먼트가 존재하거나 컨텐츠 제공자에 상기 컨텐츠 세그먼트가 존재하는 경우(S319), 다시 라우팅 과정을 거쳐 CCN 어댑터 장치(250)로 CCN 응답 패킷이 전송될 수 있다. 반면, 상기 CCN 망(400)으로부터 전달되는 CCN 응답 패킷은 컨텐츠 세그먼트가 아닌 상기 컨텐츠 세그먼트를 포함하는 컨텐츠 자체가 전달될 수 있으며, 이 경우, CCN 어댑터 장치(250)는 상기 컨텐츠를 세그먼트 단위로 분할하여 단말(100)이 요청한 해당 컨텐츠 세그먼트만이 단말(100)로 전달되도록 제어할 수도 있다. The CCN adapter device 250 converts the CCN request packet to the CCN request packet including the checked content name (S313) and delivers the same to the CCN network 400. A plurality of CCN nodes constituting the CCN network 400 performs a routing process by finding the CCN nodes storing the content segment corresponding to the content name (S317). If a corresponding content segment exists in one CCN node or the content segment exists in a content provider (S319), a CCN response packet may be transmitted to the CCN adapter device 250 through a routing process again. On the other hand, the CCN response packet transmitted from the CCN network 400 may be delivered with the content itself including the content segment instead of the content segment. In this case, the CCN adapter device 250 divides the content into segments. Therefore, only the corresponding content segment requested by the terminal 100 may be controlled to be delivered to the terminal 100.
아울러, 본 발명의 CCN 어댑터 장치(250)는 CCN 망(400)으로부터 전달된 CCN 응답 패킷을 컨텐츠 세그먼트 응답 메시지로 변환하게 되며(S323), 변환된 컨텐츠 세그먼트 응답 메시지를 스트리밍 서버(200)로 전송하게 된다(S325). 아울러, 상기 CCN 응답 패킷은 상기 컨텐츠 세그먼트의 저장 장소에 대한 정보를 포함하는 컨텐츠 이름을 포함하며, 본 발명의 스트리밍 서버(200)는 전달되는 컨텐츠 이름을 상기 컨텐츠에 대한 메타데이터에 반영되도록 메타데이터를 수정하는 과정을 수행하게 된다. In addition, the CCN adapter device 250 of the present invention converts the CCN response packet transmitted from the CCN network 400 to the content segment response message (S323), and transmits the converted content segment response message to the streaming server 200. It is made (S325). In addition, the CCN response packet includes a content name including information on the storage location of the content segment, the streaming server 200 of the present invention metadata to reflect the content name to be transmitted to the metadata for the content The process of modifying will be performed.
그리고 수행된 메타데이터를 단말(100)로 배포하여 추후 변경된 메타데이터에 따라 컨텐츠 제공이 이뤄지도록 지원할 수 있다. The distributed metadata may be distributed to the terminal 100 to support content provision according to the changed metadata later.
아울러, 본 발명의 단말(100)은 스트리밍 서버(200)로부터 컨텐츠 세그먼트 응답 메시지가 전송되면(S327), 이를 수신하여 컨텐츠를 재생할 수 있다(S329). In addition, when the content segment response message is transmitted from the streaming server 200 (S327), the terminal 100 of the present invention may receive the content segment and play back the content (S329).
본 발명의 스트리밍 서버(200)는 CCN 어댑터 장치(250)로부터 전달되는 컨텐츠 이름이 상기 컨텐츠에 대한 메타데이터에 반영되도록 메타데이터를 수정하는 과정을 수행하게 되는 데 이에 대해 도 8을 참조하여 부연 설명하도록 한다. The streaming server 200 of the present invention performs the process of modifying the metadata so that the content name transmitted from the CCN adapter device 250 is reflected in the metadata for the content. Do it.
도 8은 본 발명의 실시 예에 따른 메타데이터의 구조를 설명하기 위한 예시도이다. 8 is an exemplary view for explaining the structure of metadata according to an embodiment of the present invention.
도 8을 참조하면, 본 발명의 메타데이터는 컨텐츠의 미디어 정보(MPD; Media Presentation description)를 의미한다. 여기서 MPD는 미디어 프리젠테이션의 양식화된 설명(description)을 의미하는 것으로, 본 발명의 MPD는 MPEG의 동적 및 적응적 HTTP 스트리밍(DASH; Dynamic and Adaptive HTTP Streaming of MEPG)의 MPD일 수 있다. Referring to FIG. 8, metadata of the present invention means media presentation description (MPD) of content. Here, MPD means a stylized description of a media presentation, and the MPD of the present invention may be MPD of Dynamic and Adaptive HTTP Streaming of MEPG of MPEG.
MPD는 전술한 바와 같이 단말(100)에 전달하고자 하는 미디어의 리프리젠테이션(representation, 705)(또는, 표현)의 설명(description)을 포함할 수 있다. 즉, MPD는 단말(100)이 접근할 수 있는 비디오, 오디오 및 언어 등의 조합들을 설명하고 있다. As described above, the MPD may include a description of a representation 705 (or a representation) of media to be delivered to the terminal 100. That is, the MPD describes combinations of video, audio, and language that the terminal 100 can access.
MPD는 세그먼트(segment)를 위한 자원 식별자들을 알리기 위한 포맷(707)을 정의할 수 있다. MPD는 미디어 프리젠테이션 내에서의 식별된 자원들에 대한 컨텍스트(context)를 제공할 수 있으며 이때의 자원 식별자들은 HTTP-URL이며, 바이트 범위(byte range) 속성에 의해 제한될 수 있다.The MPD may define a format 707 for informing resource identifiers for a segment. The MPD may provide a context for the identified resources in the media presentation, where the resource identifiers are HTTP-URLs and may be limited by the byte range attribute.
각 주기(period)는 프래그먼트(fragment)들로 나뉘어지며, 여기서 프래그먼트는 세그먼트(segment)는 동일한 의미로 사용될 수 있다. 세그먼트는 3GPP(Generation Partnership Project) 적응적 HTTP 스트리밍의 용어이다. Each period is divided into fragments, where fragments may be used in the same sense. Segment is a term for Generation Partnership Project (3GPP) adaptive HTTP streaming.
프래그먼트(세그먼트, 707)는 예컨대 RFC 2616에서 정의된, HTTP-URL에 대한 HTTP/1.1 GET 요청(또는, 바이트 범위(range)에 의해 가리켜진(indicated) 일부에 대한 GET 요청)에 대한 응답(response)의 객체(entity) 바디(body)를 의미하며, 부(sub)-세그먼트는 세그먼트 레벨에서의 세그먼트 인덱스(index)에 의해 인덱스될 수 있는 세그먼트들 내의 가장 작은(smallest) 유닛(unit)을 의미할 수 있다.The fragment (segment, 707) responds to an HTTP / 1.1 GET request for an HTTP-URL (or a GET request for a portion indicated by a byte range), as defined in RFC 2616, for example. Sub-segment means the smallest unit in the segments that can be indexed by the segment index at the segment level. can do.
또한 하나의 주기(period, 703)는 두 개 이상의 프래그먼트 집합을 포함할 수 있으며, 프래그먼트의 집합들 각각을 리프리젠테이션(Representation)으로 지칭할 수 있다. 아울러 상기 리프리젠테이션(representation)은 대안(alternative)으로 지칭될 수도 있다. In addition, one period 703 may include two or more fragment sets, and each of the sets of fragments may be referred to as a representation. In addition, the representation may be referred to as an alternative.
리프리젠테이션은 하나의 주기 내의 하나 이상의 미디어 컴포넌트들의 구조화된(structured) 컬렉션이다. 리프리젠테이션은, 비트레이트(bitrate), 해상도(resolution), 언어(language) 및 코덱(codec) 등과 같은 인코딩(encoding) 선택(choice)이 상이한, 미디어 콘텐츠 또는 미디어 콘텐츠의 부분집합의 대안적인(alternative) 선택(choice)들 중 하나일 수 있다. 즉, 리프리젠테이션은 미디어를 구성할 수 있는 비디오, 오디오 및 언어 등의 조합을 나타낼 수 있다.Representation is a structured collection of one or more media components within one period. Representation is an alternative to media content or a subset of media content, with different encoding choices, such as bitrate, resolution, language, codec, and the like. alternative) may be one of the choices. That is, the representation may represent a combination of video, audio, language, and the like that may constitute media.
MPD(또는, MPD 요소)는 단말(100)이 하나 이상의 리프리젠테이션을 선택하는 것을 가능하게 하는 설명적인 정보를 제공하는 것으로, 다시 말해, 세그먼트들을 접근하고, 사용자에게 스트리밍 서비스를 제공하기 위해 적합한(appropriate) HTTP-URL들을 구성하기 위해 DASH 클라이언트에게 요구되는 메타데이터를 포함하는 문서이다. HTTP-URL들은 절대적이거나 상대적일 수 있다. 이러한 MPD는 XML-문서 형태로 구현될 수 있으며, MPD는 상술한 바와 같은 다양한 MPD 요소(element)를 포함할 수 있으며, 반면에 어느 하나의 MPD 요소만을 포함할 수도 있다. The MPD (or MPD element) provides descriptive information that enables the terminal 100 to select one or more representations, in other words suitable for accessing segments and providing streaming services to the user. (appropriate) A document containing metadata required by the DASH client to construct HTTP-URLs. HTTP-URLs can be absolute or relative. Such an MPD may be implemented in the form of an XML-document, and the MPD may include various MPD elements as described above, but may include only one MPD element.
이러한 메타데이터 생성이 완료되면, 본 발명의 스트리밍 서버(200)는 해당 단말(100)로 메타데이터를 전송할 수 있다. 이때, 본 발명의 스트리밍 서버(200)는 CCN 어댑터 장치(250)로부터 전달되는 컨텐츠 이름이 상기 메타데이터에 반영되도록 수정하는 과정을 수행할 수 있다. 즉, 709 및 711이 지시하는 바와 같이 각 메타데이터에 컨텐츠 이름을 명시할 수 있으며, 711이 지시하는 바와 같이 컨텐츠 세그먼트 식별 정보와 709가 지시하는 바와 같이 컨텐츠 식별 정보를 컨텐츠 이름으로 정의하여 메타데이터에 기재할 수 있다. When the metadata generation is completed, the streaming server 200 of the present invention may transmit the metadata to the corresponding terminal 100. In this case, the streaming server 200 of the present invention may perform a process of modifying the content name transmitted from the CCN adapter device 250 to be reflected in the metadata. That is, as indicated by 709 and 711, the content name can be specified in each metadata. As indicated by 711, the content segment identification information and the content identification information as defined by the 709 are defined as the content name. It can be described in.
아울러, 본 발명의 실시 예에 따른 스트리밍 서버(200)는 수정된 메타데이터를 단말(100)로 배포하여 추후 이를 확인한 단말(100)로부터 컨텐츠 세그먼트 전송 요청이 전달되는 경우, 해당 메타데이터의 컨텐츠 이름 정보를 확인하여 CCN 망(400)에서의 라우팅 과정없이 즉시 CCN 노드에서 해당 컨텐츠 세그먼트가 단말(100)로 전송되는 과정을 지원할 수 있게 된다. In addition, the streaming server 200 according to an embodiment of the present invention distributes the modified metadata to the terminal 100 and when the content segment transmission request is transmitted from the terminal 100 which has been checked later, the content name of the metadata. By checking the information, it is possible to support a process of transmitting the corresponding content segment to the terminal 100 at the CCN node immediately without the routing process in the CCN network 400.
아울러, 본 발명의 실시 예에 따른 스트리밍 서버(200)는 어느 하나의 컨텐츠에 대응하여 복수 개의 메타데이터를 생성할 수도 있다. 예를 들어 본 발명의 스트리밍 서버(200)가 컨텐츠를 복수 개의 레이어로 계층화하여 비트스트림을 생성하는 스케일러블 인코딩 방식을 지원하는 경우, 단말(100)의 성능 또는 네트워크 상태에 따라 선택적으로 디코딩이 수행되도록 이에 대한 정보를 메타데이터에 기술할 수 있다. In addition, the streaming server 200 according to an embodiment of the present invention may generate a plurality of metadata corresponding to any one content. For example, when the streaming server 200 of the present invention supports a scalable encoding method of generating a bitstream by layering content into a plurality of layers, decoding is selectively performed according to the performance or network state of the terminal 100. Information about this can be described in metadata.
이상으로 본 발명의 실시 예에 따른 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법에 대해 설명하였다. In the above, the content providing method through the content-oriented network interworking according to an embodiment of the present invention has been described.
본 발명의 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법은 컨텐츠 중심 네트워크 기반 컨텐츠 전송이 가능한 다수의 CCN 노드를 포함하는 CCN 망과, 상기 CCN 망에 연결되며 TCP/IP 기반 컨텐츠 전송이 가능한 스트리밍 서버를 포함하는 컨텐츠 제공 시스템에 있어서, 상기 스트리밍 서버가, 어느 하나의 단말이 요청한 컨텐츠 세그먼트 요청 메시지를 수신하는 단계, 상기 컨텐츠 세그먼트 요청 메시지를 CCN 요청 패킷으로 변환하여 CCN 망으로 전달하는 단계, 상기 CCN 망으로부터 CCN 응답 패킷을 수신하는 단계, 상기 CCN 응답 패킷을 컨텐츠 세그먼트 응답 메시지로 변환하는 단계 및 상기 단말로 상기 컨텐츠 세그먼트 응답 메시지를 전송하는 단계 등을 실행할 수 있다. Content providing method through the content-centric network interworking of the present invention includes a CCN network including a plurality of CCN nodes capable of content-based network-based content transmission, and a streaming server connected to the CCN network and capable of transmitting TCP / IP-based content In the content providing system, the streaming server, receiving a content segment request message requested by any one terminal, converting the content segment request message to a CCN request packet and forwarding to the CCN network, from the CCN network Receiving a CCN response packet, converting the CCN response packet into a content segment response message, and transmitting the content segment response message to the terminal.
이러한, 컴퓨터 프로그램 명령어와 데이터를 저장하기에 적합한 컴퓨터로 판독 가능한 매체는, 예컨대 기록매체는 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체(Magnetic Media), CD-ROM(Compact Disk Read Only Memory), DVD(Digital Video Disk)와 같은 광 기록 매체(Optical Media), 플롭티컬 디스크(Floptical Disk)와 같은 자기-광 매체(Magneto-Optical Media), 및 롬(ROM, Read Only Memory), 램(RAM, Random Access Memory), 플래시 메모리, EPROM(Erasable Programmable ROM), EEPROM(Electrically Erasable Programmable ROM)과 같은 반도체 메모리를 포함한다. 프로세서와 메모리는 특수 목적의 논리 회로에 의해 보충되거나, 그것에 통합될 수 있다. Such computer-readable media suitable for storing computer program instructions and data include, for example, recording media comprising magnetic media, such as hard disks, floppy disks, and magnetic tape, and compact disk read only memory (CD-ROM). , Optical media such as Digital Video Disk (DVD), magneto-optical media such as Floppy Disk, and ROM (Read Only Memory), RAM And a semiconductor memory such as a random access memory, a flash memory, an erasable programmable ROM (EPROM), and an electrically erasable programmable ROM (EEPROM). The processor and memory can be supplemented by or integrated with special purpose logic circuitry.
또한 컴퓨터가 읽을 수 있는 기록매체는 네트워크로 연결된 컴퓨터 시스템에 분산되어, 분산방식으로 컴퓨터가 읽을 수 있는 코드가 저장되고 실행될 수 있다. 그리고, 본 발명을 구현하기 위한 기능적인(Functional) 프로그램과 이와 관련된 코드 및 코드 세그먼트 등은, 기록매체를 읽어서 프로그램을 실행시키는 컴퓨터의 시스템 환경 등을 고려하여, 본 발명이 속하는 기술분야의 프로그래머들에 의해 용이하게 추론되거나 변경될 수도 있다.The computer readable recording medium can also be distributed over network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion. In addition, a functional program for implementing the present invention, codes and code segments associated therewith may be used in consideration of a system environment of a computer that reads a recording medium and executes the program. It may be easily inferred or changed by.
아울러, 상술한 바와 같은 컴퓨터가 읽을 수 있는 기록매체에 기록된 컴퓨터 프로그램은 상술한 바와 같은 기능을 수행하는 명령어를 포함하며 기록매체를 통해 배포되고 유통되어 특정 장치, 특정 컴퓨터에 읽히어 설치되고 실행됨으로써 전술한 기능들을 실행할 수 있다. In addition, the computer program recorded on the computer-readable recording medium as described above includes instructions for performing the functions as described above, distributed and distributed through the recording medium to be read and installed on a specific device, a specific computer, and executed. Thus, the above functions can be executed.
여기서, 컴퓨터가 기록매체에 기록된 프로그램을 읽어 들여 프로그램으로 구현된 기능들을 실행시키기 위하여, 전술한 컴퓨터 프로그램은 컴퓨터의 프로세서(CPU)가 컴퓨터의 장치 인터페이스(Interface)를 통해 읽힐 수 있는 C, C++, JAVA, 기계어 등의 컴퓨터 언어로 코드화된 프로그램 명령어에 대한 코드(Code)를 포함할 수 있다. Here, in order for a computer to read a program recorded on a recording medium and execute functions implemented as a program, the above-described computer program is a C, C ++ that can be read by the computer's processor (CPU) through the computer's device interface (Interface) Code for a program instruction coded in a computer language such as JAVA, machine language, or the like may be included.
이러한 코드는 전술한 기능들을 정의한 함수 등과 관련된 기능적인 코드(Function Code)를 포함할 수 있고, 전술한 기능들을 컴퓨터의 프로세서가 소정의 절차대로 실행시키는데 필요한 실행 절차 관련 제어 코드를 포함할 수도 있다. 또한, 이러한 코드는 전술한 기능들을 컴퓨터의 프로세서가 실행시키는데 필요한 추가 정보나 미디어가 컴퓨터의 내부 또는 외부 메모리의 어느 위치(주소 번지)에서 참조 되어야 하는지에 대한 메모리 참조 관련 코드를 더 포함할 수 있다. 또한, 컴퓨터의 프로세서가 전술한 기능들을 실행시키기 위하여 원격(Remote)에 있는 어떠한 다른 컴퓨터나 서버 등과 통신이 필요한 경우, 코드는 컴퓨터의 프로세서가 컴퓨터의 통신 모듈을 이용하여 원격(Remote)에 있는 어떠한 다른 컴퓨터나 서버 등과 어떻게 통신해야만 하는지, 통신 시 어떠한 정보나 미디어를 송수신해야 하는지 등에 대한 통신 관련 코드를 더 포함할 수도 있다.Such code may include a function code associated with a function or the like that defines the above-described functions, and may include execution procedure-related control code necessary for a processor of the computer to execute the above-described functions according to a predetermined procedure. In addition, the code may further include memory reference-related code for additional information or media required for a processor of the computer to execute the above-described functions at which location (address address) of the computer's internal or external memory. . In addition, if the processor of the computer needs to communicate with any other computer or server on the remote in order to execute the above functions, the code may be used to determine which computer the processor of the computer uses the communication module of the computer on the remote. It may further include communication-related codes such as how to communicate with other computers or servers, and what information or media should be transmitted and received during communication.
본 명세서는 다수의 특정한 구현물의 세부사항들을 포함하지만, 이들은 어떠한 발명이나 청구 가능한 것의 범위에 대해서도 제한적인 것으로서 이해되어서는 안되며, 오히려 특정한 발명의 특정한 실시형태에 특유할 수 있는 특징들에 대한 설명으로서 이해되어야 한다. 개별적인 실시형태의 문맥에서 본 명세서에 기술된 특정한 특징들은 단일 실시형태에서 조합하여 구현될 수도 있다. 반대로, 단일 실시형태의 문맥에서 기술한 다양한 특징들 역시 개별적으로 혹은 어떠한 적절한 하위 조합으로도 복수의 실시형태에서 구현 가능하다. 나아가, 특징들이 특정한 조합으로 동작하고 초기에 그와 같이 청구된 바와 같이 묘사될 수 있지만, 청구된 조합으로부터의 하나 이상의 특징들은 일부 경우에 그 조합으로부터 배제될 수 있으며, 그 청구된 조합은 하위 조합이나 하위 조합의 변형물로 변경될 수 있다.Although the specification includes numerous specific implementation details, these should not be construed as limiting to any invention or the scope of the claims, but rather as a description of features that may be specific to a particular embodiment of a particular invention. It must be understood. Certain features that are described in this specification in the context of separate embodiments may be implemented in combination in a single embodiment. Conversely, various features that are described in the context of a single embodiment can also be implemented in multiple embodiments individually or in any suitable subcombination. Furthermore, while the features may operate in a particular combination and may be initially depicted as so claimed, one or more features from the claimed combination may in some cases be excluded from the combination, the claimed combination being a subcombination Or a combination of subcombinations.
마찬가지로, 특정한 순서로 도면에서 동작들을 묘사하고 있지만, 이는 바람직한 결과를 얻기 위하여 도시된 그 특정한 순서나 순차적인 순서대로 그러한 동작들을 수행하여야 한다거나 모든 도시된 동작들이 수행되어야 하는 것으로 이해되어서는 안 된다. 특정한 경우, 멀티태스킹과 병렬 프로세싱이 유리할 수 있다. 또한, 상술한 실시형태의 다양한 시스템 컴포넌트의 분리는 그러한 분리를 모든 실시형태에서 요구하는 것으로 이해되어서는 안되며, 설명한 프로그램 컴포넌트와 시스템들은 일반적으로 단일의 소프트웨어 제품으로 함께 통합되거나 다중 소프트웨어 제품에 패키징 될 수 있다는 점을 이해하여야 한다.Likewise, although the operations are depicted in the drawings in a specific order, it should not be understood that such operations must be performed in the specific order or sequential order shown in order to obtain desirable results or that all illustrated operations must be performed. In certain cases, multitasking and parallel processing may be advantageous. Moreover, the separation of the various system components of the above-described embodiments should not be understood as requiring such separation in all embodiments, and the described program components and systems will generally be integrated together into a single software product or packaged into multiple software products. It should be understood that it can.
본 발명은 컨텐츠 제공 방법에 관한 것으로, 더욱 상세하게는 컨텐츠 중심 네트워크(CONTENT CENTRIC NETWORKING)와의 연동을 통해 단말로 컨텐츠를 제공할 수 있는 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법 및 이를 위한 장치에 관한 것이다. The present invention relates to a content providing method, and more particularly, to a content providing method and a device for interworking with a content-centric network that can provide content to a terminal through interworking with a content-centric network (CONTENT CENTRIC NETWORKING). .
본 발명에 의하면, 스트리밍 서버 또는 스트리밍 서버와 연동가능한 별도의 모듈 장치가 컨텐츠 세그먼트 요청 메시지를 CCN 요청 패킷으로 변환 처리하고, CCN 응답 패킷을 컨텐츠 세그먼트 응답 메시지로 변환 처리함으로써, 단말에 대한 별도의 설계 변경 없이 컨텐츠 중심 네트워크와 접목된 스트리밍 서비스를 제공할 수 있으며, 이를 통해 서비스 산업의 발전에 이바지할 수 있다.According to the present invention, a separate module device capable of interworking with a streaming server or a streaming server converts a content segment request message into a CCN request packet and converts a CCN response packet into a content segment response message, thereby designing a separate terminal for the terminal. It is possible to provide streaming services combined with content-oriented networks without change, thereby contributing to the development of the service industry.
더불어, 본 발명은 시판 또는 영업의 가능성이 충분할 뿐만 아니라 현실적으로 명백하게 실시할 수 있는 정도이므로 산업상 이용가능성이 있다.In addition, the present invention has industrial applicability because the present invention is not only sufficiently commercially available or commercially viable, but also practically clearly implemented.

Claims (8)

  1. 컨텐츠 중심 네트워크 기반 컨텐츠 전송이 가능한 다수의 CCN 노드를 포함하는 CCN 망과, 상기 CCN 망에 연결되며 TCP/IP 기반 컨텐츠 전송이 가능한 스트리밍 서버를 포함하는 컨텐츠 제공 시스템에 있어서, A content providing system including a CCN network including a plurality of CCN nodes capable of content-based network-based content transmission, and a streaming server connected to the CCN network and capable of transmitting TCP / IP-based content.
    상기 스트리밍 서버가,The streaming server,
    어느 하나의 단말이 요청한 컨텐츠 세그먼트 요청 메시지를 수신하는 단계;Receiving a content segment request message requested by any one terminal;
    상기 컨텐츠 세그먼트 요청 메시지를 CCN 요청 패킷으로 변환하여 CCN 망으로 전달하는 단계;Converting the content segment request message into a CCN request packet and transmitting the converted content segment request message to a CCN network;
    상기 CCN 망으로부터 CCN 응답 패킷을 수신하는 단계;Receiving a CCN response packet from the CCN network;
    상기 CCN 응답 패킷을 컨텐츠 세그먼트 응답 메시지로 변환하는 단계; 및Converting the CCN response packet into a content segment response message; And
    상기 단말로 상기 컨텐츠 세그먼트 응답 메시지를 전송하는 단계;Transmitting the content segment response message to the terminal;
    를 포함하는 것을 특징으로 하는 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법.Content providing method through the content-centric network interworking, comprising a.
  2. 제1항에 있어서, The method of claim 1,
    상기 CCN 망으로 전달하는 단계는Delivering to the CCN network
    상기 컨텐츠에 대응하는 메타데이터의 컨텐츠 이름을 확인하는 단계; 및Checking a content name of metadata corresponding to the content; And
    상기 확인된 컨텐츠 이름을 포함하는 CCN 요청 패킷으로 변환하여 CCN 망으로 전달하는 단계;Converting the CCN request packet including the identified content name to a CCN network;
    를 포함하는 것을 특징으로 하는 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법.Content providing method through the content-centric network interworking, comprising a.
  3. 제2항에 있어서, The method of claim 2,
    상기 컨텐츠에 대응하는 메타데이터의 컨텐츠 이름이 존재하지 않을 경우, 상기 컨텐츠 이름을 정의하는 단계;If a content name of metadata corresponding to the content does not exist, defining the content name;
    를 더 포함하는 것을 특징으로 하는 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법.Content providing method through the content-centric network interworking further comprising a.
  4. 제1항에 있어서, The method of claim 1,
    상기 CCN 응답 패킷을 수신하는 단계는Receiving the CCN response packet
    상기 컨텐츠 세그먼트에 대한 컨텐츠 이름을 확인하는 단계; 및Identifying a content name for the content segment; And
    상기 확인된 컨텐츠 이름이 상기 컨텐츠의 메타데이터에 반영되도록 상기 메타데이터를 수정하는 단계;Modifying the metadata such that the identified content name is reflected in the metadata of the content;
    를 더 포함하는 것을 특징으로 하는 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법.Content providing method through the content-centric network interworking further comprising a.
  5. 제4항에 있어서, The method of claim 4, wherein
    상기 컨텐츠 이름은The content name is
    해당 컨텐츠 세그먼트를 저장하고 있는 CCN 노드의 이름 정보, 컨텐츠 식별자 및 컨텐츠 세그먼트 식별자 중 적어도 어느 하나 이상을 포함하여 구성되는 것을 특징으로 하는 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법.And at least one of name information, a content identifier, and a content segment identifier of the CCN node storing the corresponding content segment.
  6. 제1항 내지 제6항 중 어느 하나의 항에 기재된 컨텐츠 중심 네트워크 연동을 통한 컨텐츠 제공 방법을 실행하는 프로그램을 기록한 컴퓨터 판독 가능한 기록매체.A computer-readable recording medium having recorded thereon a program for executing the content providing method through the content-oriented network interworking according to any one of claims 1 to 6.
  7. 컨텐츠 중심 네트워크 기반 컨텐츠 전송이 가능한 다수의 CCN 노드를 포함하는 CCN 망과, 상기 CCN 망에 연결되며 TCP/IP 기반 컨텐츠 전송이 가능한 스트리밍 서버를 포함하는 컨텐츠 제공 시스템에 있어서, A content providing system including a CCN network including a plurality of CCN nodes capable of content-based network-based content transmission, and a streaming server connected to the CCN network and capable of transmitting TCP / IP-based content.
    상기 스트리밍 서버는, The streaming server,
    어느 하나의 단말이 요청한 컨텐츠 세그먼트 요청 메시지를 수신하고, 상기 컨텐츠 세그먼트 요청 메시지를 CCN 요청 패킷으로 변환하여 상기 CCN 망으로 전달하며, 상기 CCN 망으로부터 CCN 응답 패킷을 수신하고, 상기 CCN 응답 패킷을 컨텐츠 세그먼트 응답 메시지로 변환한 후 상기 단말로 전송하는 변환 처리 모듈; 및Receives a content segment request message requested by one of the terminals, converts the content segment request message into a CCN request packet and delivers the CCN network to the CCN network, receives a CCN response packet from the CCN network, and sends the CCN response packet to the content. A conversion processing module converting the segment response message and transmitting the converted segment response message; And
    상기 CCN 망으로부터 전달된 상기 CCN 응답 패킷의 컨텐츠 이름을 확인하고, 상기 컨텐츠 이름이 상기 컨텐츠에 대한 메타데이터에 반영되도록 메타데이터를 수정하는 MPD 구성 모듈; An MPD configuration module for identifying a content name of the CCN response packet transmitted from the CCN network and modifying metadata so that the content name is reflected in metadata about the content;
    을 포함하는 것을 특징으로 하는 스트리밍 서버.Streaming server comprising a.
  8. 제7항에 있어서, The method of claim 7, wherein
    상기 변환 처리 모듈은 상기 컨텐츠 세그먼트 요청 메시지를 상기 CCN 요청 패킷으로 변환 시 상기 컨텐츠에 대한 메타데이터에 기재된 컨텐츠 이름을 확인한 후 상기 컨텐츠 이름을 포함하는 CCN 요청 패킷으로 변환하여 상기 CCN 망으로 전달하는 것을 특징으로 하는 스트리밍 서버.The conversion processing module, after converting the content segment request message into the CCN request packet, checks the content name described in the metadata for the content, converts the content segment request message into a CCN request packet including the content name, and transmits the converted content to the CCN network. A streaming server characterized by the above.
PCT/KR2015/009092 2015-08-28 2015-08-28 Method for providing content through interworking with content centric networking and apparatus therefor WO2017039022A1 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
KR10-2015-0121786 2015-08-28
KR1020150121786A KR102228762B1 (en) 2015-08-28 2015-08-28 Method for providing of contents withd content centrci networking and apparatus therefor

Publications (1)

Publication Number Publication Date
WO2017039022A1 true WO2017039022A1 (en) 2017-03-09

Family

ID=58187755

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/KR2015/009092 WO2017039022A1 (en) 2015-08-28 2015-08-28 Method for providing content through interworking with content centric networking and apparatus therefor

Country Status (2)

Country Link
KR (1) KR102228762B1 (en)
WO (1) WO2017039022A1 (en)

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130060962A1 (en) * 2011-09-01 2013-03-07 Futurewei Technologies, Inc. Generalized Dual-Mode Data Forwarding Plane for Information-Centric Network
KR20140009931A (en) * 2012-07-13 2014-01-23 삼성전자주식회사 Communication method of contents requester and contents provider for providing contents and real-time streaming contents in a contents centric network based on contents name
KR20140035801A (en) * 2012-09-14 2014-03-24 한국전자통신연구원 Information centric network node based in switching and network process using the node
KR20150053217A (en) * 2013-11-07 2015-05-15 경희대학교 산학협력단 Method for transmitting packet of real-time streaming service in content centric network
KR20150057478A (en) * 2013-11-19 2015-05-28 삼성전자주식회사 Server, user terminal apparatus and method for streaming data service

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101750049B1 (en) 2009-11-13 2017-06-22 삼성전자주식회사 Method and apparatus for adaptive streaming

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130060962A1 (en) * 2011-09-01 2013-03-07 Futurewei Technologies, Inc. Generalized Dual-Mode Data Forwarding Plane for Information-Centric Network
KR20140009931A (en) * 2012-07-13 2014-01-23 삼성전자주식회사 Communication method of contents requester and contents provider for providing contents and real-time streaming contents in a contents centric network based on contents name
KR20140035801A (en) * 2012-09-14 2014-03-24 한국전자통신연구원 Information centric network node based in switching and network process using the node
KR20150053217A (en) * 2013-11-07 2015-05-15 경희대학교 산학협력단 Method for transmitting packet of real-time streaming service in content centric network
KR20150057478A (en) * 2013-11-19 2015-05-28 삼성전자주식회사 Server, user terminal apparatus and method for streaming data service

Also Published As

Publication number Publication date
KR102228762B1 (en) 2021-03-18
KR20170026810A (en) 2017-03-09

Similar Documents

Publication Publication Date Title
WO2016129963A1 (en) Multi-view streaming service supporting method, and device for supporting same
WO2014038916A1 (en) System and method of controlling external apparatus connected with device
WO2011129635A2 (en) Method and apparatus for providing application service in a mobile communication system
WO2013118988A1 (en) Method and apparatus for interoperably performing services and system supporting the same
WO2015030364A1 (en) Method for sharing media data and electronic device thereof
WO2013151374A1 (en) Method and system for transfering data between plurality of devices
WO2016018048A1 (en) Method for transmitting content between terminals through service control device link
EP3304942A1 (en) Method and apparatus for sharing application
WO2020224246A1 (en) Block chain-based data management method and apparatus, device and storage medium
WO2016200018A1 (en) Method and apparatus for sharing application
WO2019156506A1 (en) System and method for providing conversational contents
WO2013154406A1 (en) Method and system for establishing wireless local area network link between portable terminals
WO2014035171A1 (en) Method and apparatus for transmitting file during video call in electronic device
WO2013024966A1 (en) Method and device for receiving content
WO2016137185A1 (en) Electronic device and method for providing drm content by the electronic device
WO2020101133A1 (en) Method and apparatus for providing services in local area data network
WO2016192589A1 (en) Information transmission method, apparatus and system
WO2016064074A1 (en) Device-to-device content providing method
CN112995005B (en) Virtual network data exchange method and device
WO2016129965A1 (en) Method for providing streaming data through base station interworking node, and base station interworking node therefor
WO2020180072A1 (en) Apparatus and method for controlling application relocation in edge computing environment
WO2013125920A1 (en) Method, apparatus, and system for performing unsolicited location-based download
WO2017039022A1 (en) Method for providing content through interworking with content centric networking and apparatus therefor
WO2017200319A1 (en) Method providing for adaptive streaming service, and device therefor
WO2019190023A1 (en) System and method for streaming video data

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 15903083

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

122 Ep: pct application non-entry in european phase

Ref document number: 15903083

Country of ref document: EP

Kind code of ref document: A1