KR20150050669A - Apparatus and Method for Multi-source downloading - Google Patents

Apparatus and Method for Multi-source downloading Download PDF

Info

Publication number
KR20150050669A
KR20150050669A KR1020130129918A KR20130129918A KR20150050669A KR 20150050669 A KR20150050669 A KR 20150050669A KR 1020130129918 A KR1020130129918 A KR 1020130129918A KR 20130129918 A KR20130129918 A KR 20130129918A KR 20150050669 A KR20150050669 A KR 20150050669A
Authority
KR
South Korea
Prior art keywords
terminal
content
peer
providing server
user terminal
Prior art date
Application number
KR1020130129918A
Other languages
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 에스케이플래닛 주식회사
Priority to KR1020130129918A priority Critical patent/KR20150050669A/en
Publication of KR20150050669A publication Critical patent/KR20150050669A/en

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/234Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
    • H04N21/2343Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/61Network physical structure; Signal processing
    • H04N21/6106Network physical structure; Signal processing specially adapted to the downstream path of the transmission network
    • H04N21/6131Network physical structure; Signal processing specially adapted to the downstream path of the transmission network involving transmission via a mobile phone network

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

The present invention relates to a multi-source downloading system and a method for the same, wherein a user terminal downloads corresponding contents from multiple contents sources. In particular, when a user terminal requests for downloading contents to a contents providing server, the contents providing server searches a peer terminal capable of transmitting corresponding contents to the user terminal. When data packets to be transmitted by the contents providing server and searched peer terminal are assigned, the contents providing server and peer terminal correspondingly transmit the respectively assigned data packets to the user terminal.

Description

멀티소스(multi-source) 다운로드 시스템 및 그 방법 {Apparatus and Method for Multi-source downloading}[0001] Multi-source downloading system and method [0002]

본 발명은 사용자 단말이 다수의 컨텐츠 소스로부터 해당 컨텐츠를 다운로드 받는 멀티소스 다운로드 시스템 및 그 방법에 관한 것이다. 구체적으로는, 사용자 단말이 컨텐츠 제공 서버에 대해 컨텐츠 다운로드 요청을 하면 컨텐츠 제공 서버는 해당 컨텐츠를 사용자 단말로 전송할 수 있는 피어단말을 검색하고, 이 후 컨텐츠 제공 서버 및 검색된 피어단말이 전송할 데이터 패킷이 할당되면 이에 따라 컨텐츠 제공 서버 및 피어단말이 각각 할당된 데이터 패킷을 사용자 단말로 전송하는 멀티소스 다운로드 시스템 및 그 방법에 관한 것이다.
The present invention relates to a multi-source download system and method in which a user terminal downloads corresponding content from a plurality of content sources. Specifically, when a user terminal requests a content download to a content providing server, the content providing server searches for a peer terminal capable of transmitting the content to the user terminal, and then transmits a data packet to be transmitted by the content providing server and the retrieved peer terminal And transmits the data packet allocated by the content providing server and the peer terminal to the user terminal, respectively, when it is allocated, and a method thereof.

네트워크 인프라가 비약적으로 발달함에 따라 다양한 컨텐츠들이 수 많은 단말기 간에 전송되고 있으며, 이와 동시에 네트워크 상에서 컨텐츠를 업로드하거나 다운로드 하는 방법론에 대한 연구도 활발하게 이루어지고 있다. As the network infrastructure has developed dramatically, various contents are being transmitted among a large number of terminals. At the same time, a methodology for uploading or downloading contents on the network has been actively studied.

한편, 오늘날 소비자들에게 판매되는 단말기에는 고사양의 마이크로 프로세서, 그래픽 처리장치 등을 탑재시킴으로써 소비자가 양질의 컨텐츠를 즐길 수 있는 환경을 제공하고 있으며, 이에 따라 해당 단말기에서 구동될 수 있는 소프트웨어, 컨텐츠 역시 대용량으로 제작, 배포되고 있다. On the other hand, today's high-end microprocessors and graphic processing devices are mounted on the handsets to provide consumers with an environment in which they can enjoy high-quality contents. Accordingly, software and contents It is produced and distributed in large capacity.

일 예로서, 현재 스마트폰 등의 사용자 단말이 앱 스토어 등을 통해 다운로드 받는 애플리케이션, 영화 등의 컨텐츠 중에는 수십 메가바이트 또는 수백 메가바이트로 된 대용량의 것들이 적지 않음을 쉽게 확인할 수 있다. As an example, it can be easily confirmed that a large number of contents, such as applications and movies, which are currently downloaded from a user terminal such as a smart phone through an app store, have a size of tens of megabytes or hundreds of megabytes.

한편, 현재 스마트폰과 같은 사용자 단말이 앱 스토어로부터 컨텐츠를 다운로드 받는 방식은 사용자 단말과 컨텐츠 제공 서버가 1:1로 연결되어 컨텐츠 제공 서버로부터 컨텐츠 파일의 모든 데이터 패킷을 전송받는 형식으로 이루어지고 있다. Meanwhile, a method in which a user terminal such as a smart phone downloads content from an application store is a format in which a user terminal and a content providing server are connected in a one-to-one manner and all data packets of a content file are transmitted from a content providing server .

그러나 이와 같은 다운로드 방식은 대용량 컨텐츠 전송 건수가 급증하고 있는 최근의 네트워크 환경을 고려할 때 많은 문제점을 안고 있다. 구체적으로, 컨텐츠 제공 서버 입장에서는 많은 수의 사용자 단말들로 각각의 컨텐츠를 전송하기 위한 네트워크 대역폭을 확보해야 하는 문제, 데이터 처리량이 급증하는 문제 등이 존재한다. 또한, 사용자 단말의 입장에서는 컨텐츠 제공 서버로부터만 컨텐츠를 수신할 수 있어 컨텐츠 제공 서버가 불안정한 경우 데이터 다운로드가 어려운 문제, 다운로드 속도가 저하되는 문제 등이 존재한다.However, such a downloading method has many problems in consideration of the recent network environment in which the number of large-volume contents transmission is rapidly increasing. Specifically, there is a problem that a network bandwidth for transmitting each content to a large number of user terminals must be ensured, and a data processing amount is rapidly increased in the content providing server. In addition, in the case of a user terminal, contents can be received only from a contents providing server, and there is a problem that downloading of data is difficult when the contents providing server is unstable, and a problem that downloading speed is lowered.

한편, 위와 같은 문제점들을 해결하기 위해 서버의 개수를 늘리거나 네트워크 환경을 개선하는 방안도 고려되고 있으나, 이러한 해결방법은 비용이 과도하게 요구된다는 문제가 있다. 또한, 사용자들에게 제공되는 컨텐츠의 종류가 다양해지고 용량이 증가하고 있는 오늘날의 추세에 비추어 볼 때, 단순히 서버의 용량을 늘리거나 네트워크 환경을 개선하는 방식으로는 위와 같은 문제점들을 해결하는 데에 한계가 있다. Meanwhile, in order to solve the above problems, it is considered to increase the number of servers or to improve the network environment. However, such a solution has a problem that the cost is excessively required. In addition, in view of the increasing trend of the types of contents provided to users and the increase in capacity, merely increasing the capacity of the server or improving the network environment has limitations in solving the above problems .

이에 따라 과도한 비용을 필요로 하지 않으면서도 사용자 단말로의 컨텐츠 전송을 효율적으로 할 수 있는 새로운 데이터 전송방식에 대한 필요성이 증가하고 있다. Accordingly, there is a growing need for a new data transmission scheme that can efficiently transmit content to a user terminal without requiring excessive cost.

한편, 관련 선행기술로서 국내공개특허 제10-2009-0060912호 (“다운로딩 기반 수신제한시스템에서 복수 개의 수신제어소프트웨어 객체들의 실행 관리가 가능한 수신기 및 실행관리방법”)이 존재한다. 선행기술은 소프트웨어 다운로딩 기반의 수신제한 기능을 구비한 멀티미디어 컨텐츠 수신기에 있어서, 복수 개의 수신제어 소프트웨어 다운로드, 실행, 상태제어 및 종료를 포함한 전반적 관리를 수행하는 수신제어 소프트웨어 관리 수단과, 상기 수신제어 소프트웨어 관리 수단의 요청에 응하여 외부 서버로부터 상기 수신제어 소프트웨어를 다운로드하는 다운로드 수단, 스크램블된 멀티미디어 컨텐츠 및 수신제어 메시지를 수신하고, 상기 수신제어 메시지를 상기 수신제어 소프트웨어 관리 수단으로 전달하는 디먹서, 상기 수신제어 메시지로부터 추출한 디스크램블링 키를 전달받아 상기 스크램블된 컨텐츠를 디스크램블하는 디스크램블러를 포함하는 것을 특징으로 하며, 이에 따르면 컨텐츠를 다운로드 할 시 복수 개의 수신제어 소프트웨어를 구동함으로써 데이터를 여러 경로로 전송하는 것이 가능하다. On the other hand, as related prior arts, there is a publicly known Japanese Patent Laid-Open No. 10-2009-0060912 (" receiver and execution management method capable of executing management of a plurality of reception control software objects in a downloading-based reception limiting system "). The present invention relates to a multimedia content receiver having a reception restriction function based on software downloading, comprising: reception control software management means for performing overall management including downloading, execution, status control and termination of a plurality of reception control software; A download unit for downloading the reception control software from an external server in response to a request from the software management unit, a scrambled multimedia content and a reception control message, and delivering the reception control message to the reception control software management unit; And a descrambler for receiving the descrambling key extracted from the reception control message and descrambling the scrambled contents. According to the descrambler, a plurality of reception control software It is possible to transmit data by various paths by driving.

선행기술은 하나의 컨텐츠를 여러 개로 나누어 전송하는 방식을 취하고 있다는 점에서 이 건 출원발명과 유사하다. 그러나, 선행기술은 소프트웨어를 이용하여 하나의 컨텐츠를 여러 개로 나누어 수신하는 방법을 제안하고 있으며, 이러한 방법은 물리적인 하드웨어, 즉 서버 또는 네트워크 인프라가 부담하게 되는 데이터 처리량 문제에 대한 근본적인 해결책이 될 수 없다는 문제가 있다.
This prior art is similar to the present invention in that it takes a method of dividing one content into several pieces and transmitting it. However, the prior art proposes a method of receiving one piece of content by using software, and this method can be a fundamental solution to the problem of data throughput that physical hardware, server or network infrastructure, is burdened There is no problem.

공개특허 제10-2009-0060912호 (2009.06.15. 공개)Open Patent No. 10-2009-0060912 (published on June 15, 2009)

본 발명은 위와 같은 문제점을 해결하기 위해 제안된 것으로서, 사용자 단말이 하나의 컨텐츠를 다운로드 함에 있어 컨텐츠 제공 서버 및 하나 이상의 피어단말로부터 각각 할당된 데이터 패킷을 전송받을 수 있는 멀티소스 다운로드 시스템 및 그 방법을 제공한다.SUMMARY OF THE INVENTION The present invention has been proposed in order to solve the above-mentioned problems, and it is an object of the present invention to provide a multi-source download system in which a user terminal can receive a data packet allocated from a content providing server and one or more peer terminals, .

또한 본 발명은, 사용자 단말과 피어단말 사이의 네트워크 대역폭에 따라 전송하고자 하는 컨텐츠 파일의 데이터 패킷을 할당함으로써 효율적인 컨텐츠 다운로드가 이루어질 수 있는 멀티소스 다운로드 시스템 및 그 방법을 제공한다.The present invention also provides a multi-source downloading system and method for efficiently downloading content by allocating a data packet of a content file to be transmitted according to a network bandwidth between a user terminal and a peer terminal.

또한 본 발명은, 복수 개의 피어단말을 컨텐츠 제공 소스로 활용함으로써 별도의 컨텐츠 제공 서버 용량 확보 없이도 원활한 컨텐츠 다운로드가 가능한 멀티소스 다운로드 시스템 및 그 방법을 제공한다. The present invention also provides a multi-source downloading system and method for seamlessly downloading content without securing a separate content providing server capacity by utilizing a plurality of peer terminals as a content providing source.

또한 본 발명은, 컨텐츠 제공에 있어 피어단말의 다운로드 기여도를 산출하고, 상기 산출된 기여도에 따라 각각의 피어단말에 별도의 보상을 지급함으로써 피어단말의 소스참여를 유도하며, 이에 따라 보다 원활한 컨텐츠 다운로드를 가능하게 하는 멀티소스 다운로드 시스템 및 그 방법을 제공한다. Further, the present invention calculates the download contribution of the peer terminal in content provision and induces the peer terminal to participate in the source by paying a separate compensation to each peer terminal according to the calculated contribution, The present invention provides a multi-source download system and method thereof.

또한 본 발명은, 컨텐츠 제공 서버로 하여금 직접 보안 패킷을 전송데이터 내에 삽입시키는 등 사용자 단말로 제공되는 컨텐츠 파일에 대한 보안을 직접 관리하게 함으로써 신속하고 안전한 컨텐츠 다운로드를 가능하게 하는 멀티소스 다운로드 시스템 및 그 방법을 제공한다.
In addition, the present invention provides a multi-source downloading system that enables rapid and secure content downloading by allowing a content providing server to directly manage the security of a content file provided to a user terminal, such as inserting a security packet directly into transmission data, ≪ / RTI >

본 발명은 상기와 같은 과제를 해결하기 위한 수단으로 멀티소스 다운로드 서비스 제공을 위한 서비스 제공 서버, 피어단말, 사용자 단말, 멀티소스 다운로드 시스템 및 그 방법을 제공한다. 다만, 이러한 발명의 카테고리들은 단어 그 자체에 의해 한정되지 않으며, 이하에서 살펴볼 기술 사상을 포함하는 범위 내에서 다양하게 확장 해석될 수 있다.The present invention provides a service providing server, a peer terminal, a user terminal, a multi-source downloading system, and a method thereof for providing a multi-source download service as means for solving the above problems. However, the categories of the present invention are not limited to the words themselves, and can be variously extended within the scope of technical ideas to be discussed below.

먼저, 상기와 같은 과제를 해결하기 위한 본 발명의 일 실시예에 따른 컨텐츠 제공 서버는, 사용자 단말로부터 컨텐츠 다운로드 요청을 수신하는 컨텐츠요청 수신부; 상기 사용자 단말로의 컨텐츠 전송이 가능한 피어단말을 검색하는 피어단말 검색부; 컨텐츠 제공 서버 및 피어단말이 상기 사용자 단말로 전송할 데이터 패킷을 할당하는 전송데이터 할당부; 상기 전송데이터 할당부에 의해 할당된 데이터 패킷을 상기 사용자 단말로 전송하는 데이터 전송부; 상기 피어단말로 데이터 패킷 전송 제어를 위한 제어신호를 전송하는 피어단말 제어부; 및 상기 컨텐츠요청 수신부, 피어단말 검색부, 전송데이터 할당부, 데이터 전송부 및 피어단말 제어부를 제어하는 제어부;를 포함한다.According to an aspect of the present invention, there is provided a content providing server including: a content request receiving unit for receiving a content download request from a user terminal; A peer terminal searching unit searching for a peer terminal capable of transmitting content to the user terminal; A transmission data allocation unit for allocating a data packet to be transmitted to the user terminal by the content providing server and the peer terminal; A data transmission unit for transmitting a data packet allocated by the transmission data allocation unit to the user terminal; A peer terminal controller for transmitting a control signal for data packet transmission control to the peer terminal; And a controller for controlling the content request receiving unit, the peer terminal searching unit, the transmission data allocating unit, the data transmitting unit, and the peer terminal controlling unit.

또한, 상기 컨텐츠 제공 서버에 있어서 상기 전송데이터 할당부는, 사용자 단말과 피어 단말 사이의 네트워크 대역폭에 따라 전송데이터 패킷을 할당할 수 있다.In the content providing server, the transmission data allocation unit may allocate a transmission data packet according to a network bandwidth between the user terminal and the peer terminal.

또한, 상기 컨텐츠 제공 서버에 있어서 상기 피어단말 검색부는 복수 개의 피어단말로 응답요청신호를 전송하고, 상기 응답요청신호에 응답한 피어단말로부터 수신한 단말정보를 바탕으로 상기 사용자 단말로의 컨텐츠 전송이 가능한 피어단말을 검색할 수 있다.In the content providing server, the peer terminal searching unit transmits a response request signal to a plurality of peer terminals, and based on the terminal information received from the peer terminal in response to the response request signal, It is possible to search for a possible peer terminal.

또한, 상기 컨텐츠 제공 서버에 있어서 상기 전송데이터 할당부는, 상기 데이터 전송부가 사용자 단말 측으로 전송하는 데이터 패킷에 보안 패킷을 부가적으로 삽입할 수도 있다.In the content providing server, the transmission data allocation unit may additionally insert a security packet into a data packet transmitted by the data transmission unit to the user terminal.

또한, 상기 컨텐츠 제공 서버에 있어서 상기 피어단말 제어부는, 피어단말의 다운로드 기여도를 산출하고, 상기 기여도에 따라 보상을 지급할 수 있다.In the content providing server, the peer terminal control unit may calculate a download contribution of the peer terminal and pay compensation according to the contribution.

다음으로, 상기와 같은 과제를 해결하기 위한 본 발명의 다른 실시예에 따른 피어단말은 컨텐츠 제공 서버로부터 전송되는 제어신호를 수신하는 제어신호 수신부; 컨텐츠 제공 서버측으로 당해 피어단말에 대한 단말정보를 생성하여 전송하는 단말정보 제공부; 컨텐츠 제공 서버로부터 수신한 제어신호에 따라 지정된 사용자 단말로 할당된 데이터 패킷을 전송하는 데이터 전송부; 및According to another aspect of the present invention, there is provided a peer terminal comprising: a control signal receiver for receiving a control signal transmitted from a content providing server; A terminal information provider for generating and transmitting terminal information for the peer terminal to the content providing server; A data transmission unit for transmitting a data packet allocated to a designated user terminal according to a control signal received from a content providing server; And

상기 제어신호 수신부, 단말정보 제공부 및 데이터 전송부를 제어하는 제어부; 를 포함한다.A control unit for controlling the control signal receiving unit, the terminal information providing unit and the data transmitting unit; .

한편, 상기 피어단말에 있어서 상기 단말정보는 피어단말이 저장하고 있는 컨텐츠 정보, 지정된 사용자 단말로의 데이터 전송 가능여부 또는 피어단말의 사양정보 중 적어도 어느 하나를 포함할 수 있다.Meanwhile, in the peer terminal, the terminal information may include at least one of content information stored in the peer terminal, whether data can be transmitted to the designated user terminal, or specification information of the peer terminal.

다음으로, 상기와 같은 과제를 해결하기 위한 본 발명의 또 다른 실시예에 따른 사용자 단말은 컨텐츠 제공 서버에 대하여 특정 컨텐츠에 대한 다운로드를 요청하는 컨텐츠 요청부; 컨텐츠 제공 서버 및 하나 이상의 피어단말로부터 데이터 패킷을 수신하는 데이터 수신부; 수신한 데이터 패킷을 조합하여 하나의 완성된 컨텐츠로 복원하는 데이터 합성부; 및 상기 컨텐츠 요청부, 데이터 수신부 및 데이터 합성부를 제어하는 제어부;를 포함한다.According to another aspect of the present invention, there is provided a user terminal comprising: a content request unit for requesting a content providing server to download a specific content; A data receiving unit for receiving a data packet from a content providing server and one or more peer terminals; A data synthesizer for combining the received data packets and restoring them into one complete content; And a controller for controlling the content requesting unit, the data receiving unit, and the data synthesizing unit.

한편, 상기 사용자 단말은, 컨텐츠 제공 서버 및 하나 이상의 피어단말로부터 데이터 패킷을 수신한 이후 누락된 데이터 패킷이 존재하는지 여부를 확인하는 데이터 확인부;를 더 포함할 수 있다.The user terminal may further include a data checking unit for checking whether there is a missing data packet after receiving the data packet from the content providing server and one or more peer terminals.

다음으로, 상기와 같은 과제를 해결하기 위한 본 발명의 또 다른 실시예에 따른 멀티소스 다운로드 시스템은 컨텐츠 제공 서버에 대해 컨텐츠 다운로드 요청을 하고, 상기 컨텐츠 제공 서버 및 하나 이상의 피어단말로부터 데이터 패킷을 수신하여 하나의 완성된 컨텐츠로 복원하는 사용자 단말; 사용자 단말로부터 특정 컨텐츠에 대한 다운로드 요청이 수신되면 상기 사용자 단말로의 해당 컨텐츠 전송이 가능한 피어단말을 검색하고, 당해 컨텐츠 제공 서버 및 피어단말이 전송할 데이터 패킷을 할당하며, 할당된 데이터 패킷을 사용자 단말로 전송하고, 상기 피어단말로 데이터 패킷 전송 제어를 위한 제어신호를 전송하는 컨텐츠 제공 서버; 및 컨텐츠 제공 서버의 제어신호에 따라 할당받은 데이터 패킷을 상기 사용자 단말로 전송하는 하나 이상의 피어단말;를 포함한다.According to another aspect of the present invention, there is provided a multi-source download system for providing a content download request to a content providing server and receiving a data packet from the content providing server and one or more peer terminals A user terminal for restoring the content into one complete content; A download request for a specific content is received from the user terminal, a search is made for a peer terminal capable of transmitting the corresponding content to the user terminal, a data packet to be transmitted by the content providing server and the peer terminal is allocated, And transmits a control signal for control of data packet transmission to the peer terminal; And at least one peer terminal for transmitting the allocated data packet to the user terminal according to a control signal of the content providing server.

다음으로, 상기와 같은 과제를 해결하기 위한 본 발명의 또 다른 실시예에 따른 컨텐츠 제공 서버의 멀티소스 다운로드 서비스 제공 방법은, 컨텐츠 제공 서버가 (a) 사용자 단말로부터 컨텐츠 다운로드 요청을 수신하는 단계;According to another aspect of the present invention, there is provided a method of providing a multi-source download service for a content providing server, the method comprising: (a) receiving a content download request from a user terminal;

(b) 상기 사용자 단말로의 컨텐츠 전송이 가능한 피어단말을 검색하는 단계;(b) searching for a peer terminal capable of transmitting content to the user terminal;

(c) 상기 (b)단계에서의 검색결과를 바탕으로 당해 컨텐츠 제공 서버 및 하나 이상의 피어단말이 전송할 데이터 패킷을 할당하는 단계; (d) 상기 피어단말로 제어신호를 전송하는 단계; (e) 상기 (c)단계에서 할당된 데이터 패킷을 상기 사용자 단말로 전송하는 단계; 를 포함한다.(c) allocating a data packet to be transmitted by the content providing server and the one or more peer terminals based on the search result in the step (b); (d) transmitting a control signal to the peer terminal; (e) transmitting the data packet allocated in the step (c) to the user terminal; .

다음으로, 상기와 같은 과제를 해결하기 위한 본 발명의 또 다른 실시예에 따른 멀티소스 다운로드 방법은 (a) 사용자 단말이 컨텐츠 제공 서버에 대해 컨텐츠 다운로드 요청을 하는 단계; (b) 컨텐츠 제공 서버가 사용자 단말로부터 컨텐츠 다운로드 요청을 수신한 이후 상기 사용자 단말로의 해당 컨텐츠 전송이 가능한 피어단말을 검색하는 단계; (c) 컨텐츠 제공 서버가 상기 (b)단계에서의 검색결과를 바탕으로 당해 컨텐츠 제공 서버 및 하나 이상의 피어단말이 전송할 데이터 패킷을 할당하는 단계; (d) 컨텐츠 제공 서버가 상기 피어단말로 데이터 패킷 전송 제어를 위한 제어신호를 전송하는 단계; 및 (e) 컨텐츠 제공 서버 및 하나 이상의 피어 단말이 상기 사용자 단말로 각 할당된 데이터 패킷을 전송하는 단계; 를 포함한다.According to another aspect of the present invention, there is provided a method for downloading a multi-source according to the present invention, the method comprising: (a) requesting a user terminal to download a content to a content providing server; (b) searching the peer terminal capable of transmitting the content to the user terminal after the content providing server receives the content download request from the user terminal; (c) allocating a data packet to be transmitted by the content providing server and the one or more peer terminals based on the search result in the step (b); (d) transmitting, by the content providing server, a control signal for controlling data packet transmission to the peer terminal; And (e) transmitting each allocated data packet to the user terminal by the content providing server and the one or more peer terminals; .

한편, 상기 멀티소스 다운로드 방법은 (e)단계 이후, 사용자 단말이 수신한 데이터 패킷을 조합하여 하나의 완성된 컨텐츠로 복원하는 단계;를 더 포함할 수 있다.The multi-source downloading method may further include, after step (e), combining the data packets received by the user terminal and restoring the received data into one complete content.

또 다른 한편, 상기 멀티소스 다운로드 방법은 (e)단계 이후, 사용자 단말이 누락된 데이터 패킷의 존재여부를 확인하는 단계; 사용자 단말의 확인결과 누락된 데이터 패킷이 존재하면 컨텐츠 제공 서버 측으로 누락된 데이터 패킷정보를 전송하는 단계; 및 컨텐츠 제공 서버가 사용자 단말로 누락된 데이터 패킷을 전송하는 단계;를 더 포함할 수도 있다.On the other hand, in the multi-source download method, after the step (e), the user terminal confirms whether a missing data packet exists; Transmitting missing data packet information to a content providing server if a missing data packet exists as a result of the confirmation of the user terminal; And transmitting the missing data packet to the user terminal by the content providing server.

나아가, 상기 멀티소스 다운로드 방법은 컨텐츠 제공 서버가 피어단말의 다운로드 기여도를 산출하고 상기 기여도에 따라 보상을 지급하는 단계;Further, the multi-source downloading method may include: a step in which the content providing server calculates the download contribution of the peer terminal and pays the reward according to the contribution;

를 더 포함할 수도 있다.
As shown in FIG.

본 발명에 의하면, 사용자 단말로서는 컨텐츠 제공 서버 및 피어단말로부터 원하는 컨텐츠 파일을 전송받을 수 있으므로 복수의 소스로부터 신속하게 컨텐츠를 다운로드 할 수 있는 효과가 있다.According to the present invention, as a user terminal, a desired content file can be received from a content providing server and a peer terminal, so that contents can be downloaded quickly from a plurality of sources.

또한 본 발명에 의하면, 컨텐츠 제공 서버 또는 피어단말의 네트워크 전송 상태가 불안정하더라도 다른 소스로부터의 데이터 전송이 가능하므로 데이터 전송의 안정성을 향상시킬 수 있는 효과가 있다. According to the present invention, even if the network transmission state of the content providing server or the peer terminal is unstable, data can be transmitted from another source, thereby improving the stability of data transmission.

또한 본 발명에 의하면, 사용자 단말과 피어단말 사이의 네트워크 대역폭에 따라 전송하고자 하는 컨텐츠 파일의 데이터 패킷을 할당함으로써 보다 효율적인 컨텐츠 다운로드 서비스를 제공할 수 있다.According to the present invention, a more efficient content download service can be provided by allocating a data packet of a content file to be transmitted according to the network bandwidth between the user terminal and the peer terminal.

또한 본 발명에 의하면, 복수 개의 피어단말을 컨텐츠 제공 소스로 활용함으로써 별도의 컨텐츠 제공 서버 용량 확보 없이도 원활하게 컨텐츠를 제공할 수 있는 효과가 있다. According to the present invention, a plurality of peer terminals are used as a content providing source, so that content can be smoothly provided without securing the capacity of a separate content providing server.

또한 본 발명에 의하면, 컨텐츠 제공에 있어 피어단말로서의 기여도를 산출하고 상기 산출된 기여도에 따라 각각의 피어단말에 대해 별도의 보상을 지급함으로써 피어단말의 소스참여를 유도하는 효과가 있다. According to the present invention, there is an effect that the contribution of the peer terminal is calculated by calculating the contribution of the peer terminal in the provision of the content, and the compensation is paid to each peer terminal according to the calculated contribution.

또한 본 발명에 의하면, 컨텐츠 제공 서버로 하여금 직접 보안 패킷을 전송데이터 내에 삽입시키는 등 사용자 단말로 제공되는 컨텐츠 파일에 대한 보안을 직접 관리하게 함으로써 신속하고 안전하게 컨텐츠를 제공할 수 있는 효과가 있다.
According to the present invention, the content providing server directly inspects the security of the content file provided to the user terminal by inserting the security packet directly into the transmission data, thereby providing the content quickly and safely.

도 1은 본 발명의 일 실시예에 따른 멀티소스 다운로드 시스템을 개략적으로 도시한 것이다.
도 2는 사용자 단말로 전송되는 하나의 컨텐츠 파일이 각각 컨텐츠 제공 서버 및 피어단말에 의해 전송될 데이터 패킷으로 할당된 모습을 나타낸 것이다.
도 3는 본 발명의 일실시예에 따른 컨텐츠 제공 서버의 세부구성을 나타낸 블록도이다.
도 4는 본 발명의 일 실시예에 따른 피어단말의 세부구성을 나타낸 블록도이다.
도 5는 본 발명의 일 실시예에 따른 사용자 단말의 세부구성을 나타낸 블록도이다.
도 6은 본 발명의 일 실시예에 따른 멀티소스 다운로드 방법을 순서에 따르 나타낸 흐름도이다.
도 7은 본 발명의 또 다른 일 실시예에 따른 멀티소스 다운로드 방법을 순서에 따라 나타낸 흐름도이다.
1 schematically illustrates a multi-source download system in accordance with an embodiment of the present invention.
FIG. 2 is a view showing a state in which one content file transmitted to a user terminal is allocated as a data packet to be transmitted by a content providing server and a peer terminal, respectively.
3 is a block diagram illustrating a detailed configuration of a content providing server according to an embodiment of the present invention.
4 is a block diagram illustrating a detailed configuration of a peer terminal according to an embodiment of the present invention.
5 is a block diagram illustrating a detailed configuration of a user terminal according to an embodiment of the present invention.
6 is a flowchart illustrating a method of downloading a multi-source according to an embodiment of the present invention.
7 is a flowchart illustrating a method of downloading a multi-source according to another embodiment of the present invention.

본 발명의 목적과 기술적 구성 및 그에 따른 작용 효과에 관한 자세한 사항은 본 발명의 명세서에 첨부된 도면에 의거한 이하의 상세한 설명에 의해 보다 명확하게 이해될 것이다. 첨부된 도면을 참조하여 본 발명에 따른 실시예를 상세하게 설명한다.DETAILED DESCRIPTION OF THE EMBODIMENTS Reference will now be made in detail to the preferred embodiments of the present invention, examples of which are illustrated in the accompanying drawings, wherein like reference numerals refer to the like elements throughout. DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS An embodiment according to the present invention will be described in detail with reference to the accompanying drawings.

본 명세서에서 개시되는 실시예들은 본 발명의 범위를 한정하는 것으로 해석되거나 이용되지 않아야 할 것이다. 이 분야의 통상의 기술자에게 본 명세서의 실시예를 포함한 설명은 다양한 응용을 갖는다는 것이 당연하다. 따라서, 본 발명의 상세한 설명에 기재된 임의의 실시예들은 본 발명을 보다 잘 설명하기 위한 예시적인 것이며 본 발명의 범위가 실시예들로 한정되는 것을 의도하지 않는다.The embodiments disclosed herein should not be construed or interpreted as limiting the scope of the present invention. It will be apparent to those of ordinary skill in the art that the description including the embodiments of the present specification has various applications. Accordingly, any embodiment described in the Detailed Description of the Invention is illustrative for a better understanding of the invention and is not intended to limit the scope of the invention to embodiments.

도면에 표시되고 아래에 설명되는 기능 블록들은 가능한 구현의 예들일 뿐이다. 다른 구현들에서는 상세한 설명의 사상 및 범위를 벗어나지 않는 범위에서 다른 기능 블록들이 사용될 수 있다. 또한, 본 발명의 하나 이상의 기능 블록이 개별 블록들로 표시되지만, 본 발명의 기능 블록들 중 하나 이상은 동일 기능을 실행하는 다양한 하드웨어 및 소프트웨어 구성들의 조합일 수 있다.The functional blocks shown in the drawings and described below are merely examples of possible implementations. In other implementations, other functional blocks may be used without departing from the spirit and scope of the following detailed description. Also, although one or more functional blocks of the present invention are represented as discrete blocks, one or more of the functional blocks of the present invention may be a combination of various hardware and software configurations that perform the same function.

또한, 어떤 구성요소들을 포함한다는 표현은 “개방형”의 표현으로서 해당 구성요소들이 존재하는 것을 단순히 지칭할 뿐이며, 추가적인 구성요소들을 배제하는 것으로 이해되어서는 안 된다.Furthermore, the expression "including an element" is merely referred to as an "open" expression, and the element should not be understood as excluding the additional elements.

나아가 어떤 구성요소가 다른 구성요소에 “연결되어” 있다거나 “접속되어” 있다고 언급될 때에는, 그 다른 구성요소에 직접적으로 연결 또는 접속되어 있을 수도 있지만, 중간에 다른 구성요소가 존재할 수도 있다고 이해되어야 한다. Further, when an element is referred to as being "connected" or "connected" to another element, it may be directly connected or connected to the other element, but it should be understood that other elements may be present in between do.

이하 도 1을 참조하여 본 발명의 일 실시예에 따른 개략적인 전체 멀티소스 다운로드 시스템을 살펴본다.Hereinafter, a schematic overall multi-source download system according to an embodiment of the present invention will be described with reference to FIG.

도1은 본 발명에 따른 멀티소스 다운로드 시스템의 개략적인 구성도를 나타낸 것이다. 도1에 따르면, 본 발명은 컨텐츠 제공 서버(100), 하나 이상의 피어단말(200) 및 사용자 단말(300)을 포함한다.1 shows a schematic configuration diagram of a multi-source download system according to the present invention. Referring to FIG. 1, the present invention includes a content providing server 100, one or more peer terminals 200, and a user terminal 300.

우선 사용자 단말(300)은 컨텐츠 제공 서버(100)에 대해 컨텐츠 다운로드를 요청하고, 이후 상기 컨텐츠 제공 서버(100) 및 그 외 하나 이상의 피어단말(200)로부터 데이터 패킷을 수신하며, 수신된 데이터 패킷을 조합하여 하나의 완성된 컨텐츠를 복원하는 기능을 한다.The user terminal 300 first requests a content download to the content providing server 100 and then receives a data packet from the content providing server 100 and the other one or more peer terminals 200, To restore one complete content.

한편, 이 때 사용자 단말(300)은 PMP, MP3플레이어, 컴퓨터 등 네트워크 통신망을 통해 데이터를 송수신 할 수 있는 수단을 구비한 모든 종류의 단말기를 의미하며, 바람직하게는 스마트 폰과 같이 이동통신망을 이용하여 데이터를 송수신할 수 있는 단말기를 의미한다. The user terminal 300 may be any type of terminal having means for transmitting and receiving data through a network communication network such as a PMP, an MP3 player, and a computer. Preferably, the user terminal 300 uses a mobile communication network such as a smart phone And can transmit and receive data.

다음으로 컨텐츠 제공 서버(100)는, 상기 사용자 단말(300)로부터 특정 컨텐츠에 대한 다운로드 요청을 수신한 경우, 상기 사용자 단말(300)로의 해당 컨텐츠 전송이 가능한 피어단말(200)을 검색하고, 당해 컨텐츠 제공 서버(100) 및 피어단말(200)이 전송할 데이터 패킷을 할당하며, 할당된 데이터 패킷을 사용자 단말(300)로 전송함과 동시에 상기 피어단말(200)에 대해 제어신호를 전송한다. 이 때, 상기 피어단말(200)로 전송되는 제어신호는 피어단말(200)로 하여금 사용자 단말(300)로 할당된 데이터 패킷을 전송하도록 제어하기 위한 제어정보, 예를 들어 피어단말(200) 인증정보, 전송하고자 하는 사용자 단말(300)의 식별정보, 컨텐츠 파일 식별정보, 할당된 데이터 패킷정보 등이 포함될 수 있다. Next, the content providing server 100 searches for the peer terminal 200 capable of transmitting the corresponding content to the user terminal 300 when receiving the download request for the specific content from the user terminal 300, The content providing server 100 and the peer terminal 200 allocate data packets to be transmitted and transmit the allocated data packets to the user terminal 300 and control signals to the peer terminal 200. The control signal transmitted to the peer terminal 200 may include control information for controlling the peer terminal 200 to transmit a data packet allocated to the user terminal 300, Identification information of the user terminal 300 to be transmitted, content file identification information, allocated data packet information, and the like.

한편, 상기 컨텐츠 제공 서버(100)는 사용자 단말(300)이 요청한 컨텐츠 파일을 여러 개의 데이터 패킷으로 구분하여 앞서 검색된 피어단말(200) 및 컨텐츠 제공 서버(100) 자신에게 할당한다. 데이터 패킷을 할당하는 과정에는 다양한 요소가 고려될 수 있으며, 바람직하게는 컨텐츠 파일의 용량, 피어단말(200)의 데이터 처리능력, 컨텐츠 제공 서버(100) 또는 피어단말(200)과 사용자 단말(300) 사이의 네트워크 대역폭 등과 같이 데이터 패킷 전송 영향을 미칠 수 있는 요소들이 고려될 수 있다. Meanwhile, the content providing server 100 divides the content file requested by the user terminal 300 into a plurality of data packets, and allocates the same to the searched peer terminal 200 and the content providing server 100 itself. The capacity of the content file, the data processing capability of the peer terminal 200, the capacity of the content providing server 100 or the peer terminal 200 and the user terminal 300 Such as the network bandwidth between the < RTI ID = 0.0 > and / or < / RTI >

도 2는 상기 컨텐츠 제공 서버(100)에 의해 하나의 컨텐츠 파일이 여러 개의 데이터 패킷으로 할당된 모습을 도시한 예시도이다. 2 is a diagram illustrating an example in which one content file is allocated by the content providing server 100 as a plurality of data packets.

패킷(packet)이란 데이터 전송에서 송신측과 수신측에 의하여 하나의 단위로 취급되어 전송되는 집합체를 의미하며, 분할된 각각의 패킷에는 별도의 순번, 목적지의 주소 또는 에러 체크 정보가 포함될 수 있다.A packet refers to an aggregate that is handled as a unit by a sender and a receiver in data transmission, and each segmented packet may include a separate sequence number, a destination address, or error check information.

한편, 패킷은 하나의 데이터 파일을 여러 개로 분할하여 전송하고, 수신측에서는 원래의 데이터 파일로 재조합될 수 있는 특징을 가진다. 또한 일반적으로 패킷은 헤더, 데이터, 테일러로 구성되어 있으며, 헤더에는 데이터가 전달되는 주소 및 순서가 저장될 수 있고, 테일러에는 에러가 발생했는지 여부를 구별할 수 있는 에러 정보가 기록될 수 있다. On the other hand, a packet is divided into a plurality of data files for transmission, and the receiving side can be recombined into an original data file. Generally, a packet is composed of a header, data, and a tailer. The header may store an address and an order in which data is transmitted, and error information may be recorded in the tailor to distinguish whether or not an error has occurred.

또 다른 한편, 패킷은 내부적으로 전달하고자 하는 목적지를 저장할 수 있고 에러가 발생했는지를 체크할 수 있는 정보도 포함하고 있어 신뢰도가 높은 고품질의 데이터 전송을 구현할 수 있다. 또한, 패킷을 이용함으로써 네트워크망을 경제적으로 활용할 수 있다는 이점도 있다. On the other hand, the packet includes information that can internally store a destination to be transmitted and can check whether an error has occurred, thereby realizing reliable and high-quality data transmission. In addition, there is an advantage that a network can be economically utilized by using a packet.

도 2는 앞서 설명한 데이터 패킷을 이용하여 하나의 컨텐츠 파일을 복수 개로 할당한 예시를 개념적으로 나타낸 것이다. 살펴보면, 사용자 단말(300)이 다운로드 하고자 하는 컨텐츠 파일은 복수개의 데이터 패킷으로 분할되어 컨텐츠 제공 서버(100) 및 피어단말(200) 1,2,3에 각각 할당될 수 있다. 이 때, 데이터 패킷의 크기는 반드시 같은 크기로 분할될 필요는 없으며, 각 피어단말(200) 또는 컨텐츠 제공 서버(100)의 데이터 처리능력, 네트워크 대역폭 등을 고려하여 서로 다른 크기의 데이터 패킷으로 분할될 수도 있다. FIG. 2 conceptually shows an example in which a plurality of content files are allocated using the above-described data packet. The content file to be downloaded by the user terminal 300 may be divided into a plurality of data packets and allocated to the content providing server 100 and the peer terminals 200, In this case, the size of the data packet does not necessarily have to be divided into the same size, but is divided into data packets of different sizes in consideration of the data processing capability, network bandwidth, etc. of each peer terminal 200 or the content providing server 100 .

또한, 하나의 컨텐츠 파일은 복수 개의 데이터 패킷 이외에 컨텐츠 보안을 위한 정보를 포함하는 별도의 패킷을 더 포함할 수 있으며, 상기 보안용 패킷은 컨텐츠 암호화 또는 컨텐츠 DRM에 대한 정보를 포함할 수 있다.In addition, one content file may further include a separate packet including information for content security, in addition to a plurality of data packets, and the security packet may include content encryption or content DRM information.

다음으로 피어단말(200)은 상기 컨텐츠 제공 서버(100)로부터 수신한 제어신호에 따라 각각 할당받은 데이터 패킷을 처음 컨텐츠 다운로드 요청을 한 사용자 단말(300)로 전송한다. Next, the peer terminal 200 transmits the data packets allocated according to the control signal received from the content providing server 100 to the user terminal 300 that has requested the content download for the first time.

한편, 상기 피어단말(200)은 앞서 설명한 사용자 단말(300)과 마찬가지로 네트워크 통신망을 통해 데이터를 송수신할 수 있는 모든 종류의 단말기를 의미하며, 바람직하게는 이동통신망을 이용해 데이터를 송수신할 수 있는 스마트폰 등의 이동통신 단말기를 의미한다. As with the user terminal 300 described above, the peer terminal 200 refers to any type of terminal capable of transmitting and receiving data through a network communication network. Preferably, the peer terminal 200 is a smart phone capable of transmitting and receiving data using a mobile communication network. A mobile communication terminal such as a cellular phone.

이하 도 3을 참조하여 본 발명의 일 실시예에 따른 컨텐츠 제공 서버(100)에 대해 보다 상세하게 살펴본다. 도 3에 의하면 본 발명에 따른 컨텐츠 제공 서버(100)는 컨텐츠요청 수신부(110), 피어단말 검색부(120), 전송데이터 할당부(130), 데이터 전송부(140), 피어단말 제어부(150) 및 제어부(160)를 포함한다. Hereinafter, a content providing server 100 according to an embodiment of the present invention will be described in detail with reference to FIG. 3, a content providing server 100 according to the present invention includes a content request receiving unit 110, a peer terminal searching unit 120, a transmission data allocating unit 130, a data transmitting unit 140, a peer terminal controlling unit 150 And a control unit 160. [0033]

우선, 컨텐츠요청 수신부(110)는 사용자 단말(300)로부터 특정 컨텐츠에 대한 다운로드 요청을 수신한다. 이 때, 사용자 단말(300)이 전송하는 컨텐츠 다운로드 요청은 일련의 데이터로 된 메시지 형태의 것일 수 있으며, 다양한 형식의 네트워크망을 통하여 전달될 수 있다. 또한, 상기 요청에는 사용자가 다운로드 받고자 하는 컨텐츠 파일정보, 당해 사용자 단말(300) 식별정보 또는 사용자 단말(300)의 단말기 사양 정보 중 적어도 어느 하나가 포함될 수 있다. First, the content request receiving unit 110 receives a download request for specific content from the user terminal 300. At this time, the content download request transmitted by the user terminal 300 may be a message in the form of a series of data, and may be transmitted through various network networks. In addition, the request may include at least one of content file information that the user wants to download, identification information of the user terminal 300, or terminal specification information of the user terminal 300.

한편, 피어단말 검색부(120)는 상기 컨텐츠 다운로드 요청을 전송한 사용자 단말(300) 측으로 해당 컨텐츠 전송이 가능한 피어단말(200)을 검색한다. Meanwhile, the peer terminal searching unit 120 searches for the peer terminal 200 capable of transmitting the content to the user terminal 300 that has transmitted the content download request.

피어단말 검색부(120)가 사용자 단말(300)로의 컨텐츠 전송이 가능한 피어단말(200)을 찾는 과정을 구체적으로 살펴보면, 상기 피어단말 검색부(120)는 복수 개의 피어단말(200)을 대상으로 응답요청신호를 전송하고, 상기 응답요청신호에 응답한 피어단말(200)로부터 단말정보를 수신하며, 상기 수신한 단말정보를 바탕으로 특정 사용자 단말(300)로의 컨텐츠 전송이 가능한 피어단말(200)을 검색할 수 있다. 이 때, 상기 피어단말 검색부(120)가 생성하여 전송하는 응답요청신호에는 상기 사용자 단말(300)이 요청한 컨텐츠 파일정보, 사용자 단말(300) 식별정보 또는 사용자 단말(300)의 단말기 사양 정보 중 적어도 어느 하나가 포함될 수 있다. 또한, 피어단말(200)이 제공하는 단말정보에는 지정된 사용자 단말(300)로의 컨텐츠 데이터 전송 가능여부, 당해 피어단말(200)이 저장하고 있는 컨텐츠 정보, 당해 피어단말(200)과 사용자 단말(300) 사이의 네트워크 대역폭 또는 피어단말(200)의 단말기 사양정보 중 적어도 어느 하나가 포함될 수 있다. 한편, 피어단말(200)과 사용자 단말(300) 사이의 네트워크 대역폭을 구하는 내용에 대해서는 다수의 선행문헌에 개시되어 있는 바, 해당 내용에 대한 구체적인 설명은 생략하기로 한다. The peer terminal searching unit 120 searches a plurality of peer terminals 200 for searching for a peer terminal 200 capable of transmitting content to the user terminal 300. [ The peer terminal 200 transmits a response request signal, receives the terminal information from the peer terminal 200 in response to the response request signal, and transmits the content to the specific user terminal 300 based on the received terminal information. Can be searched. At this time, the response request signal generated and transmitted by the peer terminal searching unit 120 includes the content file information requested by the user terminal 300, the user terminal 300 identification information, or the terminal specification information of the user terminal 300 At least one of them may be included. The terminal information provided by the peer terminal 200 includes information indicating whether content data can be transmitted to the designated user terminal 300, content information stored in the peer terminal 200, Or the terminal specification information of the peer terminal 200 may be included. The content of obtaining the network bandwidth between the peer terminal 200 and the user terminal 300 is disclosed in a number of prior art documents, and a detailed description thereof will be omitted.

피어단말 검색과정의 일 예시를 살펴보면, 甲 사용자 단말(300) 로부터 A라는 컨텐츠에 대한 다운로드 요청이 수신된 경우, 피어단말 검색부(120)는 (컨텐츠:A||타겟단말:甲||甲사양정보)와 같은 정보가 포함된 응답요청신호를 생성하여 다수의 피어단말(200)로 전송할 수 있으며, 상기 응답요청신호에 응답하고자 하는 乙 피어단말(200) 은 (전송가능여부:可||甲乙 간 네트워크 대역폭||乙사양정보)와 같은 단말정보를 생성하여 상기 컨텐츠 제공 서버(100)측으로 회신할 수 있다.When a download request for the content A is received from the upper user terminal 300, the peer terminal search unit 120 searches for the content (A: | target terminal: Specification information) can be generated and transmitted to a plurality of peer terminals 200, and the user terminal 200 to respond to the response request signal can transmit the response request signal to the plurality of peer terminals 200. The network bandwidth of the mobile terminal, and the network bandwidth || B specification information) between the mobile terminal and the mobile terminal, and return the generated terminal information to the content providing server 100.

한편, 피어단말 검색부(120)가 사용자 단말(300)로의 컨텐츠 전송이 가능한 피어단말(200)을 찾는 또 다른 실시예로서, 상기 피어단말 검색부(120)는 컨텐츠 제공 서버(100)에 별도로 구비된 피어단말 데이터베이스로부터 상기 사용자 단말(300)로 컨텐츠 전송이 가능한 피어단말(200)을 검색할 수 있다. 이 때, 피어단말 데이터베이스란, 복수의 피어단말(200)에 대한 상세정보가 저장되어 있는 일종의 데이터 저장수단으로서, 여기에는 피어단말(200)로서 기능을 할 수 있는 복수 개의 단말정보, 각각의 단말이 저장하고 있는 컨텐츠 파일정보 등이 저장될 수 있다. The peer terminal searching unit 120 may search the peer terminal searching unit 120 for the peer terminal 200 capable of transmitting the content to the user terminal 300, It is possible to search for the peer terminal 200 capable of transmitting content from the provided peer terminal database to the user terminal 300. In this case, the peer terminal database is a kind of data storage means in which detailed information about a plurality of peer terminals 200 is stored. The terminal information includes a plurality of terminal information capable of functioning as the peer terminal 200, And the stored contents file information and the like can be stored.

예를 들어, 상기 피어단말 데이터베이스에는 (단말1|컨텐츠 파일정보|단말1 사양정보), (단말2|컨텐츠 파일정보|단말2 사양정보)와 같이 복수 개의 단말이 각각 저장하고 있는 또는 특정 사용자 단말(300)로 전송 가능한 컨텐츠 파일정보가 저장될 수 있으며, 피어단말 검색부(120)는 이와 같은 정보가 저장되어 있는 피어단말 데이터베이스로부터 특정 사용자 단말(300)로의 컨텐츠 파일 전송이 가능한 피어단말(200)을 검색해 낼 수 있다. For example, the peer terminal database may store a plurality of terminals such as (terminal 1 | content file information | terminal 1 specification information), (terminal 2 | content file information | terminal 2 specification information) The peer terminal searching unit 120 may store the content file information that can be transmitted to the peer terminal 200 that can transmit the content file from the peer terminal database in which the information is stored to the specific user terminal 300 ) Can be searched.

한편, 전송데이터 할당부(130)는 컨텐츠 제공 서버(100) 및 피어단말(200)이 상기 사용자 단말(300)로 전송할 데이터 패킷을 할당하는 기능을 수행한다. The transmission data allocation unit 130 allocates a data packet to be transmitted to the user terminal 300 by the content providing server 100 and the peer terminal 200.

즉, 상기 전송데이터 할당부(130)는 하나의 컨텐츠 파일을 도 2에서와 같이 여러 개의 데이터 패킷으로 분할하며, 분할된 패킷을 당해 컨텐츠 전송 서버 및 검색된 피어단말(200)에 각각 할당하는 기능을 수행한다. That is, the transmission data allocation unit 130 divides one content file into a plurality of data packets as shown in FIG. 2, and allocates the divided packets to the content transmission server and the searched peer terminal 200, respectively .

한편, 상기 전송데이터 할당부(130)는 사용자 단말(300)이 요청한 컨텐츠의 용량, 검색된 피어단말(200)의 개수, 피어단말(200)의 단말기 사양 또는 데이터 처리능력, 각 피어단말(200)과 사용자 단말(300) 사이의 네트워크 대역폭 등과 같이 데이터 패킷 전송에 영향을 미칠 수 있는 사항들을 고려하여 전송데이터의 패킷을 할당할 수 있다. The transmission data allocation unit 130 allocates the transmission data to the peer terminal 200 in accordance with the capacity of the content requested by the user terminal 300, the number of the retrieved peer terminals 200, the terminal specification or data processing capability of the peer terminal 200, Such as the network bandwidth between the user terminal 300 and the user terminal 300, may be considered.

일 예시로서, 용량이 100MB인 A컨텐츠를 1번부터 10번가지의 데이터 패킷으로 분할하였다고 가정하는 경우, 상기 전송데이터 할당부(130)는 컨텐츠 제공 서버(100), 피어단말(200) 1, 2, 3와 사용자 단말(300)과의 네트워크 대역폭을 고려하여 각 데이터 패킷을 할당할 수 있다. 예를 들어, 컨텐츠 제공 서버(100)와 사용자 단말(300) 간의 네트워크 대역폭을 확인한 결과 타 피어단말(200)들에 비해 넓은 대역폭, 즉 일정 시간 동안 더 많은 양의 데이터 패킷을 전송할 수 있는 네트워크 대역폭을 확보하고 있음이 확인된 경우, 상기 전송데이터 할당부(130)는 컨텐츠 제공 서버(100)에 대해서는 4번부터 10번까지의 데이터 패킷을, 나머지 피어단말(200) 1, 2, 3 에는 각각 1번, 2번, 3번 데이터 패킷을 할당할 수 있다. As an example, when it is assumed that A content having a capacity of 100 MB is divided into data packets from 1 to 10, the transmission data allocator 130 allocates the content data to the content providing server 100, the peer terminal 200, 2, and 3 and the user terminal 300. In this case, For example, as a result of checking the network bandwidth between the content providing server 100 and the user terminal 300, it is possible to obtain a wide bandwidth, that is, a network bandwidth capable of transmitting a larger amount of data packets over a certain period of time The transmission data allocation unit 130 allocates data packets 4 to 10 for the content providing server 100 and data packets 4 to 10 for the remaining peer terminals 200, 1, 2, and 3 data packets can be allocated.

또 다른 한편, 상기 전송데이터 할당부(130)는 당해 컨텐츠 제공 서버(100)에 할당된 전송데이터 패킷에 보안 패킷을 부가적으로 삽입할 수도 있다. 상기 보안 패킷은 컨텐츠의 DRM 또는 암호화 정보를 포함할 수 있으며, 삽입되는 위치는 컨텐츠 파일의 헤더영역 또는 컨텐츠 제공 서버(100)가 할당받은 데이터 패킷에 포함된 별도영역일 수 있다. On the other hand, the transmission data allocator 130 may additionally insert a security packet into the transmission data packet allocated to the content providing server 100. [ The security packet may include DRM or encryption information of the content, and the inserted location may be a header area of the content file or a separate area included in the data packet allocated by the content providing server 100.

이처럼 컨텐츠 제공 서버(100)는 자신이 할당받은 데이터 패킷에 보안 패킷을 부가적으로 삽입하여 컨텐츠의 보안을 직접 관리할 수 있다. 이와 같은 보안 패킷의 활용은 해당 컨텐츠가 네트워크 상에서 안전하게 거래될 수 있도록 보장해주고, 나아가 저작권자의 권리를 보호하는 데에도 활용될 수 있다. In this way, the content providing server 100 can directly manage the security of the content by additionally inserting a security packet into the data packet allocated thereto. The use of such a security packet ensures that the content can be traded securely on the network and can be used to protect the rights of the copyright owner.

한편, 데이터 전송부(140)는 앞서 전송데이터 할당부(130)에 의해 할당된 데이터 패킷을 사용자 단말(300)로 전송한다. 즉, 데이터 전송부(140)는 당해 컨텐츠 제공 서버(100)가 할당받은 전송데이터 패킷만을 사용자 단말(300)로 전송하게 된다. Meanwhile, the data transmission unit 140 transmits the data packet allocated by the transmission data allocation unit 130 to the user terminal 300. That is, the data transmission unit 140 transmits only the transmission data packet allocated by the content providing server 100 to the user terminal 300.

한편, 컨텐츠 제공 서버(100)의 또 다른 구성요소인 피어단말 제어부(150)는, 상기 피어단말 검색부(120)에 의해 검색된 피어단말(200) 측으로 데이터 패킷 전송 제어를 위한 제어신호를 전송한다. 즉, 상기 제어신호는 피어단말(200)로 하여금 각각 할당받은 데이터 패킷을 사용자 단말(300)로 전송시키도록 제어하기 위한 것으로서, 상기 제어신호에는 각 피어단말(200)에 할당된 데이터 패킷정보, 타겟단말정보 등이 포함될 수 있다. Meanwhile, the peer terminal controller 150, which is another component of the content providing server 100, transmits a control signal for data packet transmission control to the peer terminal 200 searched by the peer terminal searching unit 120 . That is, the control signal is for controlling the peer terminal 200 to transmit the allocated data packet to the user terminal 300. The control signal includes data packet information allocated to each peer terminal 200, Target terminal information, and the like.

또 다른 한편, 상기 피어단말 제어부(150)는 멀티소스 다운로드 시스템 내에서 각 피어단말(200)의 다운로드 기여도를 산출할 수 있으며, 산출된 기여도를 기반으로 해당 피어단말(200)에 대해 별도의 보상을 지급할 수도 있다. 이 때, 다운로드 기여도 산출은 다양한 방법을 이용하여 구할 수 있으며, 바람직하게는 컨텐츠 제공 서버(100)의 응답요청신호에 대한 응답횟수, 사용자 단말(300)로 전송한 데이터 패킷 크기 등을 고려하여 구할 수 있다. 한편, 피어단말(200)은 보상으로 향후 해당 피어단말(200)이 사용자 단말(300)의 입장에서 멀티소스 다운로드 서비스를 이용하는 경우 활용할 수 있는 사이버머니, 서비스 이용 쿠폰 등을 지급받을 수 있다. On the other hand, the peer terminal controller 150 may calculate the download contribution of each peer terminal 200 in the multi-source download system, and may calculate the download contribution of the peer terminal 200 based on the calculated contribution, . At this time, the download contribution calculation can be obtained by using various methods. It is preferably determined by considering the number of responses to the response request signal of the contents providing server 100, the size of the data packet transmitted to the user terminal 300, and the like . On the other hand, the peer terminal 200 can receive a cyber money, a service use coupon, and the like that can be utilized when the peer terminal 200 uses the multi-source download service from the user terminal 300 in the future.

마지막으로, 컨텐츠 제공 서버(100)는 앞서 설명한 각 세부구성, 즉, 컨텐츠요청 수신부(110), 피어단말 검색부(120), 전송데이터 할당부(130), 데이터 전송부(140), 피어단말 제어부(150)를 제어하는 제어부(160)를 포함한다.The content providing server 100 includes the content request receiving unit 110, the peer terminal searching unit 120, the transmission data allocating unit 130, the data transmitting unit 140, And a control unit 160 for controlling the control unit 150.

이하 도 4를 참조하여 본 발명의 일 실시예에 따른 피어단말(200)에 대해 살펴본다. 도 4에 의하면 본 발명에 따른 피어단말(200)은 제어신호 수신부(210), 데이터 전송부(230), 단말정보 제공부(220) 및 제어부를 포함한다.A peer terminal 200 according to an embodiment of the present invention will be described below with reference to FIG. 4, the peer terminal 200 according to the present invention includes a control signal receiving unit 210, a data transmitting unit 230, a terminal information providing unit 220, and a control unit.

우선, 상기 제어신호 수신부(210)는 컨텐츠 제공 서버(100)로부터 전송되는 제어신호를 수신한다. 제어신호에 대한 설명은 앞서 컨텐츠 제공 서버(100)의 피어단말 제어부(150) 부분에서 상술하였는바, 본 단락에서는 생략하기로 한다.First, the control signal receiving unit 210 receives a control signal transmitted from the content providing server 100. The control signal has been described above in the peer terminal control unit 150 of the content providing server 100, and will not be described in this paragraph.

데이터 전송부(230)는 컨텐츠 제공 서버(100)로부터 수신한 제어신호에 따라 지정된 사용자 단말(300)로 할당된 데이터 패킷을 전송한다. 즉, 상기 데이터 전송부(230)는 피어단말(200)의 별도 저장수단에 저장된 특정 컨텐츠 파일 중 할당된 데이터 패킷만을 상기 사용자 단말(300)로 전송하게 된다. The data transmission unit 230 transmits the data packet allocated to the designated user terminal 300 according to the control signal received from the content providing server 100. [ That is, the data transmission unit 230 transmits only the allocated data packets of the specific content files stored in the separate storage unit of the peer terminal 200 to the user terminal 300.

한편, 피어단말(200)의 단말정보 제공부(220)는, 컨텐츠 제공 서버(100) 측으로 당해 피어단말(200)에 대한 단말정보를 생성하여 전송한다. 즉, 상기 단말정보 제공부(220)는 컨텐츠 제공 서버(100)측으로 다양한 정보를 제공함으로써 적절한 피어단말(200)을 용이하게 검색할 수 있도록 도움을 주는 역할을 한다. 한편, 상기 단말정보는 피어단말(200)이 저장하고 있는 컨텐츠 정보, 지정된 사용자 단말(300)로의 데이터 전송 가능여부 또는 피어단말(200)의 사양정보 중 적어도 어느 하나를 포함할 수 있다. Meanwhile, the terminal information providing unit 220 of the peer terminal 200 generates and transmits the terminal information for the peer terminal 200 to the content providing server 100. That is, the terminal information providing unit 220 provides a variety of information to the content providing server 100, thereby helping the user to search the appropriate peer terminal 200 easily. The terminal information may include at least one of content information stored in the peer terminal 200, availability of data transmission to the designated user terminal 300, or specification information of the peer terminal 200.

마지막으로, 피어단말(200)은 상기 제어신호 수신부(210), 데이터 전송부(230) 및 단말정보 제공부(220)를 제어하는 제어부(240)를 더 포함한다.Finally, the peer terminal 200 further includes a control unit 240 for controlling the control signal receiving unit 210, the data transmitting unit 230, and the terminal information providing unit 220.

이하 도 5를 참조하여 본 발명의 또 다른 일실시예에 따른 사용자 단말(300)에 대해 살펴본다. 도 5에 의하면 본 발명에 따른 사용자 단말(300)은 컨텐츠 요청부(310), 데이터 수신부(320), 데이터 합성부(330), 데이터 확인부(340) 및 제어부(350)를 포함한다.Hereinafter, a user terminal 300 according to another embodiment of the present invention will be described with reference to FIG. 5, the user terminal 300 according to the present invention includes a content request unit 310, a data receiving unit 320, a data combining unit 330, a data checking unit 340, and a control unit 350.

컨텐츠 요청부(310)는 컨텐츠 제공 서버(100)에 대하여 특정 컨텐츠에 대한 다운로드를 요청한다. 이 때, 상기 컨텐츠 다운로드 요청은 일련의 데이터로 된 메시지 형태일 수 있으며, 다양한 형식의 네트워크망을 통하여 전달될 수 있다. 또한, 상기 요청에 사용자가 다운로드 받고자 하는 컨텐츠 파일정보, 당해 사용자 단말(300) 식별정보 또는 사용자 단말(300)의 단말기 사양 정보 중 적어도 어느 하나가 포함될 수 있음은 앞서 설명한 것과 같다.The content requesting unit 310 requests the content providing server 100 to download a specific content. At this time, the content download request may be in the form of a message composed of a series of data, and may be transmitted through various network networks. In addition, the content file information, the identification information of the user terminal 300, or the terminal specification information of the user terminal 300 may be included in the request, as described above.

데이터 수신부(320)는 상기 컨텐츠 제공 서버(100) 및 하나 이상의 피어단말(200)로부터 특정 컨텐츠 파일의 데이터 패킷을 수신한다. The data receiving unit 320 receives a data packet of a specific content file from the content providing server 100 and one or more peer terminals 200.

한편, 데이터 합성부(330)는 상기 데이터 수신부(320)를 통해 수신된 데이터 패킷을 조합하여 하나의 완성된 컨텐츠로 복원하는 기능을 수행한다. 앞서에서도 설명했듯이, 패킷은 하나의 데이터 파일을 여러 개로 분할한 일종의 데이터 집합체를 의미하는 것이며, 다수개의 조각으로 나뉘어진 패킷은 수신측에서는 원래의 데이터 파일로 재조합될 수 있는 특징을 가진다. 데이터 합성부(330)는 패킷의 이와 같은 속성을 이용하여 상기 데이터 수신부(320)에 의해 수신된 여러 조각의 데이터 패킷을 조합하고 결과적으로 하나의 컨텐츠 파일을 복원하게 된다. 특히, 상기 데이터 합성부(330)는 수신된 각 패킷에 저장된 순번을 이용하여 용이하게 복원작업을 수행할 수 있다. The data combining unit 330 combines the data packets received through the data receiving unit 320 and reconstructs the combined data into one complete content. As described above, a packet means a kind of data aggregate in which one data file is divided into several pieces, and a packet divided into a plurality of pieces can be recombined into an original data file on the receiving side. The data combining unit 330 combines the pieces of data packets received by the data receiving unit 320 using the attributes of the packet and reconstructs one content file as a result. In particular, the data combining unit 330 can easily perform a restoration operation using the order stored in each packet received.

한편, 사용자 단말(300)의 또 다른 구성요소인 데이터 확인부(340)는 컨텐츠 제공 서버(100) 및 하나 이상의 피어단말(200)로부터 데이터 패킷을 수신한 이후 누락된 데이터 패킷이 존재하는지 여부를 확인하는 기능을 수행한다. 즉, 상기 데이터 확인부(340)는 수신된 데이터 패킷들을 합성하기 이전, 하나의 컨텐츠 파일을 온전하게 복원시킬 수 있는 모든 데이터 패킷이 수신되었는지를 확인할 수 있으며, 확인 결과 누락된 패킷이 존재하는 경우, 해당 패킷정보를 컨텐츠 제공 서버(100) 측으로 전달할 수 있다. 이 때, 누락된 패킷의 확인은 패킷에 저장된 순번을 확인하여 모든 번호의 패킷이 수신되었는지를 파악하는 방식으로 이루어질 수 있다. The data checking unit 340 which is another component of the user terminal 300 determines whether there is a missing data packet after receiving the data packet from the content providing server 100 and the one or more peer terminals 200 It performs the function to confirm. That is, the data checking unit 340 can check whether all the data packets that can completely restore one content file are received before combining the received data packets, and if there is a missing packet , And can transmit the packet information to the content providing server 100 side. At this time, the confirmation of the missing packet can be performed by checking the order stored in the packet and determining whether all the packets of the number are received.

한편, 사용자 단말(300)은 상기 컨텐츠 요청부(310), 데이터 수신부(320), 데이터 합성부(330) 및 데이터 확인부(340)를 제어하는 제어부(350)를 포함한다. The user terminal 300 includes a control unit 350 for controlling the content request unit 310, the data receiving unit 320, the data combining unit 330, and the data checking unit 340.

이하 도 6을 참조하여 본 발명의 일 실시예에 따른 멀티소스 다운로드 방법에 대해 보다 구체적으로 살펴본다. 도 6에 의하면, 본 발명의 일 실시예에 다른 멀티소스 다운로드 방법은 우선적으로 사용자 단말(300)이 컨텐츠 제공 서버(100)에 대하여 컨텐츠 다운로드 요청하는 단계(S10)를 포함한다. 한편, 컨텐츠 제공 서버(100)는 상기 사용자 단말(300)로부터 특정 컨텐츠에 대한 다운로드 요청이 수신된 경우, 해당 사용자 단말(300)기로 상기 컨텐츠 전송이 가능한 피어단말(200)을 검색(S11)한다. 즉, 상기 컨텐츠 제공 서버(100)는 i) 상기 사용자 단말(300)이 요청한 특정 컨텐츠를 저장하고 있고, ii) 상기 사용자 단말(300) 측으로 데이터 패킷 전송이 가능한 피어단말(200)을 검색하게 된다. 한편, 상기 컨텐츠 제공 서버(100)는 복수개의 피어단말(200)에 대한 정보를 저장할 수 있는 피어단말(200) 데이터베이스를 더 구비할 수 있으며, 상기 피어단말(200)에 대한 정보에는 각 피어단말(200)들이 저장하고 있는 컨텐츠 파일정보, 피어단말(200)의 단말사양, 과거 컨텐츠 제공이력 등의 정보가 포함될 수 있다. 또한 바람직하게는, 상기 피어단말(200) 데이터베이스는 기설정된 주기마다 복수개의 피어단말(200)로부터 단말정보를 제공받아 저장되어 있는 정보를 갱신할 수 있다. Hereinafter, a method for downloading a multi-source according to an embodiment of the present invention will be described in detail with reference to FIG. Referring to FIG. 6, a method for downloading a multi-source according to an exemplary embodiment of the present invention includes a step S10 of requesting a content download server 100 to download a content from the user terminal 300 first. Meanwhile, when receiving a download request for a specific content from the user terminal 300, the content providing server 100 searches for the peer terminal 200 capable of transmitting the content to the corresponding user terminal 300 (S11) . That is, the content providing server 100 searches for a peer terminal 200 capable of transmitting data packets to the user terminal 300, i) storing specific content requested by the user terminal 300, and ii) . The content providing server 100 may further include a database of a peer terminal 200 capable of storing information on a plurality of peer terminals 200. The information on the peer terminal 200 may include, The content file information stored in the terminal 200, the terminal specification of the peer terminal 200, past history of providing content, and the like. Also, preferably, the database of the peer terminal 200 may receive the terminal information from a plurality of peer terminals 200 at predetermined intervals, and may update the stored information.

한편, 사용자 단말(300)로 특정 컨텐츠 전송이 가능한 피어단말(200)이 검색된 이후 컨텐츠 제공 서버(100)는 위 검색결과를 바탕으로 당해 컨텐츠 제공 서버(100) 및 하나 이상의 상기 피어단말(200)이 전송할 데이터 패킷을 할당(S12)하게 된다. 즉, 컨텐츠 제공 서버(100)는 검색된 피어단말(200)의 개수, 각 피어단말(200)의 데이터 전송능력, 당해 컨텐츠 제공 서버(100)의 데이터 전송능력 등의 사항을 고려하여 하나의 컨텐츠 파일을 복수개의 데이터 패킷으로 분할하고, 각각의 데이터 패킷을 컨텐츠 제공 서버(100) 및 하나 이상의 피어단말(200)로 할당하는 역할을 수행한다. After the peer terminal 200 capable of transmitting a specific content is searched for in the user terminal 300, the content providing server 100 searches the content providing server 100 and one or more peer terminals 200, The data packet to be transmitted is allocated (S12). In other words, the content providing server 100 determines the number of the peer terminals 200, the data transmission capability of each peer terminal 200, and the data transmission capability of the content providing server 100, And allocates each data packet to the content providing server 100 and the one or more peer terminals 200. [0050]

한편, 데이터 패킷이 각 컨텐츠 제공 서버(100) 및 피어단말(200)로 할당된 이후, 컨텐츠 제공 서버(100)는 피어단말(200) 측으로 데이터 패킷 전송 제어를 위한 제어신호를 전송(S13)한다. 이 때 상기 제어신호에는 피어단말(200)로 하여금 사용자 단말(300)로 할당된 데이터 패킷을 전송하도록 제어하기 위한 제어정보, 예를 들어 피어단말(200) 인증정보, 전송하고자 하는 사용자 단말(300)의 식별정보, 컨텐츠 파일 식별정보, 할당된 데이터 패킷정보 등이 포함될 수 있다. Meanwhile, after the data packet is allocated to each of the content providing server 100 and the peer terminal 200, the content providing server 100 transmits a control signal for controlling the data packet transmission to the peer terminal 200 (S13) . In this case, the control signal includes control information for controlling the peer terminal 200 to transmit a data packet allocated to the user terminal 300, for example, authentication information of the peer terminal 200, ), Content file identification information, allocated data packet information, and the like.

데이터 패킷의 할당단계(S12) 및 피어단말(200)로의 제어신호 전송단계(S13) 이후, 컨텐츠 제공 서버(100) 및 하나 이상의 피어단말(200)은 각각 할당된 데이터 패킷, 즉 컨텐츠 파일이 분할된 일부 데이터 패킷을 사용자 단말(300)로 전송하게 된다.(S14, S15) After the data packet allocation step S12 and the control signal transmission step S13 to the peer terminal 200, the content providing server 100 and the one or more peer terminals 200 transmit the allocated data packets, To the user terminal 300. (S14, S15)

한편, 모든 데이터 패킷이 사용자 단말(300)로 전송된 이후, 상기 사용자 단말(300)은 여러 개로 분할되어 수신된 데이터 패킷을 하나의 완성된 컨텐츠 파일로 복원시키는 작업을 수행(S16)하게 된다. 이 때 상기 사용자 단말(300)은 수신된 데이터 패킷에 저장된 순번 또는 일련번호를 참조할 수 있다.Meanwhile, after all the data packets are transmitted to the user terminal 300, the user terminal 300 divides the received data packets into a plurality of pieces of the received data packets to restore a complete content file (S16). At this time, the user terminal 300 may refer to an order number or a serial number stored in the received data packet.

또 다른 한편, 본 발명에 의한 멀티소스 다운로드 방법은 부가적으로 피어단말(200)의 다운로드 기여도를 산출하는 단계를 더 포함할 수 있다. 즉, 컨텐츠 제공 서버(100)는 특정 컨텐츠 파일에 대한 다운로드가 종료된 이후 각 피어단말(200)의 다운로드 기여도, 예를 들어 각 피어단말(200)이 실제 전송한 데이터 패킷량 등을 기준으로 기여도를 산출(S17)할 수 있으며, 상기 산출된 기여도를 근거로 소정의 보상을 지급(S18)할 수 있다.On the other hand, the multi-source download method according to the present invention may further include a step of calculating a download contribution of the peer terminal 200. That is, after the download of the specific content file is finished, the content providing server 100 determines the contribution degree of each peer terminal 200 based on, for example, the amount of data packets actually transmitted by each peer terminal 200 (S17), and a predetermined compensation can be paid based on the calculated contribution (S18).

이하 도 7을 참조하여 본 발명의 또 다른 일 실시예에 따른 멀티소스 다운로드 방법에 대해 살펴본다. 도 7을 참조하면, 우선적으로 사용자 단말(300)은 앞선 도 6에서의 실시예에서와 마찬가지로 컨텐츠 제공 서버(100)에 대해 특정 컨텐츠에 대한 다운로드 요청(S20)을 한다. 한편, 상기 컨텐츠 제공 서버(100)는 사용자 단말(300)로부터 컨텐츠 다운로드 요청이 있는 경우 상기 사용자 단말(300)로 해당 컨텐츠 전송이 가능한 피어단말(200)을 검색하게 되는바, 이 때 상기 컨텐츠 제공 서버(100)는 복수의 피어단말(200)들에 대해 응답요청신호를 전송(S21)하고, 상기 응답요청신호에 응답한 피어단말(200)로부터 단말정보를 수신(S22)함으로써 적절한 피어단말(200)을 검색할 수 있다. 한편, 상기 피어단말 검색부(120)가 생성하여 전송하는 응답요청신호에는 상기 사용자 단말(300)이 요청한 컨텐츠 파일정보, 사용자 단말(300) 식별정보 또는 사용자 단말(300)의 단말기 사양 정보 중 적어도 어느 하나가 포함될 수 있으며, 피어단말(200)이 제공하는 상기 단말정보에는 지정된 사용자 단말(300)로의 컨텐츠 데이터 전송 가능여부, 당해 피어단말(200)이 저장하고 있는 컨텐츠 정보, 당해 피어단말(200)과 사용자 단말(300) 사이의 네트워크 대역폭 또는 피어단말(200)의 단말기 사양정보와 같은 정보들이 포함될 수 있다. Hereinafter, a method for downloading a multi-source according to another embodiment of the present invention will be described with reference to FIG. Referring to FIG. 7, the user terminal 300 preferentially requests downloading (S20) of a specific content to the content providing server 100 as in the embodiment of FIG. The content providing server 100 searches for a peer terminal 200 capable of transmitting a corresponding content to the user terminal 300 when a content download request is received from the user terminal 300. At this time, The server 100 transmits a response request signal to the plurality of peer terminals 200 in step S21 and receives the terminal information from the peer terminal 200 in response to the response request signal in step S22, 200). Meanwhile, the response request signal generated and transmitted by the peer terminal searching unit 120 includes at least one of the content file information requested by the user terminal 300, the user terminal 300 identification information or the terminal specification information of the user terminal 300 The terminal information provided by the peer terminal 200 may include information indicating whether or not content data can be transmitted to the designated user terminal 300, content information stored in the peer terminal 200, The network bandwidth between the user terminal 300 and the terminal 300 or the terminal specification information of the peer terminal 200 may be included.

한편, 멀티소스로서 기능할 수 있는 피어단말(200)이 검색된 이후, 상기 컨텐츠 제공 서버(100)가 전송데이터를 할당(S23)하는 단계, 피어단말(200)로 제어신호를 전송하는 단계(S24), 상기 사용자 단말(300)로 데이터 패킷 전송하는 단계(S25, S26)는 앞선 도 6에서의 실시예와 동일하게 진행되는바 중복되는 설명은 생략하기로 한다. After the peer terminal 200 capable of functioning as a multi-source is searched, the content providing server 100 allocates transmission data (S23), transmitting a control signal to the peer terminal 200 (S24 , The steps S25 and S26 of transmitting the data packet to the user terminal 300 proceed in the same manner as in the embodiment of FIG. 6, but will not be repeated.

한편, 사용자 단말(300)은 모든 데이터 패킷의 수신이 종료된 이후 누락된 데이터 패킷이 존재하는지 확인하는 단계(S27)를 더 실시할 수 있다. 누락된 데이터 패킷을 확인하는 단계는 다양한 방식으로 구현될 수 있으며, 바람직하게는 데이터 패킷에 저장된 일련번호를 확인함으로써 모든 데이터 패킷이 수신되었는지를 체크할 수 있다. Meanwhile, the user terminal 300 may further check whether there is a missing data packet after the reception of all the data packets is completed (S27). The step of identifying missing data packets may be implemented in various ways, preferably by checking the serial number stored in the data packet to check if all data packets have been received.

한편, 확인 결과 누락된 데이터 패킷이 존재하는 경우, 사용자 단말(300)은 컨텐츠 제공 서버(100) 측으로 누락된 해당 데이터 패킷에 대한 정보, 즉 누락된 패킷의 일련번호를 전송(S28)하며, 컨텐츠 제공 서버(100)는 누락된 데이터 패킷을 사용자 단말(300)로 전송(S29)하게 된다.Meanwhile, if there is a missing data packet, the user terminal 300 transmits information on the missing data packet to the content providing server 100, that is, the serial number of the missing packet (S28) The providing server 100 transmits the missing data packet to the user terminal 300 (S29).

이상 본 발명의 바람직한 실시예 및 응용예에 대하여 도시하고 설명하였으나, 본 발명은 상술한 특정의 실시예 및 응용예에 한정되지 아니하며, 청구범위에서 청구하는 본 발명의 요지를 벗어남이 없이 당해 발명이 속하는 기술분야에서 통상의 지식을 가진 자에 의해 다양한 변형실시가 가능한 것은 물론이고, 이러한 변형실시들은 본 발명의 기술적 사상이나 전망으로부터 구별되어 이해되어서는 안 될 것이다.
While the present invention has been particularly shown and described with reference to exemplary embodiments thereof, it is to be understood that the invention is not limited to the disclosed exemplary embodiments, It will be understood by those skilled in the art that various changes and modifications may be made without departing from the spirit and scope of the present invention.

본 발명은 컨텐츠 데이터 전송 분야에 적용될 수 있으며, 특히 멀티소스 다운로드 서비스를 제공할 수 있는 시스템, 컨텐츠 제공 서버, 사용자 단말, 피어단말 및 멀티소스 다운로드 방법을 제공한다. 본 발명에 따르면 사용자 단말로서는 복수개의 다운로드 소스로부터 데이터 패킷을 전송받을 수 있는바, 하나의 컨텐츠 파일을 여러 개로 분할된 패킷의 형태로 수신할 수 있어 다운로드 시간을 줄일 수 있으며, 데이터 전송을 위한 네트워크 대역폭을 보다 효율적으로 활용할 수 있는 이점이 있다. 이와 같은 점에 비추어 볼 때 본 발명은 산업상 이용가능성이 있는 유용한 발명이라 할 수 있다.
The present invention can be applied to a content data transmission field, and in particular, provides a system capable of providing a multi-source download service, a content providing server, a user terminal, a peer terminal, and a multi-source downloading method. According to the present invention, since a data packet can be received from a plurality of download sources as a user terminal, it is possible to receive one content file in the form of a plurality of divided packets, thereby reducing download time, There is an advantage that bandwidth can be utilized more efficiently. In view of the above, the present invention is a useful invention having industrial applicability.

100: 컨텐츠 제공 서버
110: 컨텐츠요청 수신부 120: 피어단말 검색부
130: 전송데이터 할당부 140: 데이터 전송부
150: 피어단말 제어부 160: 제어부
200: 피어단말
210: 제어신호 수신부 220: 단말정보 제공부
230: 데이터 전송부 240: 제어부
300: 사용자 단말
310: 컨텐츠 요청부 320: 데이터 수신부
330: 데이터 합성부 340: 데이터 확인부
350: 제어부
100: Content providing server
110: Content request receiving unit 120: Peer terminal searching unit
130: transmission data allocation unit 140: data transmission unit
150: Peer terminal control unit 160:
200: Peer terminal
210: control signal receiving unit 220: terminal information providing unit
230: Data transferring unit 240: Controlling unit
300: user terminal
310: Content requesting unit 320: Data receiving unit
330: Data combining unit 340: Data checking unit
350:

Claims (15)

사용자 단말로부터 컨텐츠 다운로드 요청을 수신하는 컨텐츠요청 수신부;
상기 사용자 단말로의 컨텐츠 전송이 가능한 피어단말을 검색하는 피어단말 검색부;
컨텐츠 제공 서버 및 피어단말이 상기 사용자 단말로 전송할 데이터 패킷을 할당하는 전송데이터 할당부;
상기 전송데이터 할당부에 의해 할당된 데이터 패킷을 상기 사용자 단말로 전송하는 데이터 전송부;
상기 피어단말로 데이터 패킷 전송 제어를 위한 제어신호를 전송하는 피어단말 제어부; 및
상기 컨텐츠요청 수신부, 피어단말 검색부, 전송데이터 할당부, 데이터 전송부 및 피어단말 제어부를 제어하는 제어부;
를 포함하는 컨텐츠 제공 서버.
A content request receiving unit for receiving a content download request from a user terminal;
A peer terminal searching unit searching for a peer terminal capable of transmitting content to the user terminal;
A transmission data allocation unit for allocating a data packet to be transmitted to the user terminal by the content providing server and the peer terminal;
A data transmission unit for transmitting a data packet allocated by the transmission data allocation unit to the user terminal;
A peer terminal controller for transmitting a control signal for data packet transmission control to the peer terminal; And
A control unit for controlling the content request receiving unit, the peer terminal searching unit, the transmission data allocating unit, the data transmitting unit and the peer terminal controlling unit;
And a content providing server.
제1항에 있어서,
상기 전송데이터 할당부는, 사용자 단말과 피어 단말 사이의 네트워크 대역폭에 따라 전송데이터 패킷을 할당하는 것을 특징으로 하는 컨텐츠 제공 서버.
The method according to claim 1,
Wherein the transmission data allocation unit allocates a transmission data packet according to a network bandwidth between the user terminal and the peer terminal.
제1항에 있어서,
상기 피어단말 검색부는 복수 개의 피어단말로 응답요청신호를 전송하고, 상기 응답요청신호에 응답한 피어단말로부터 수신한 단말정보를 바탕으로 상기 사용자 단말로의 컨텐츠 전송이 가능한 피어단말을 검색하는 것을 특징으로 하는 컨텐츠 제공 서버.
The method according to claim 1,
The peer terminal searching unit transmits a response request signal to a plurality of peer terminals and searches for a peer terminal capable of transmitting contents to the user terminal based on the terminal information received from the peer terminal in response to the response request signal The content providing server.
제1항에 있어서,
상기 전송데이터 할당부는, 상기 데이터 전송부가 사용자 단말 측으로 전송하는 데이터 패킷에 보안 패킷을 부가적으로 삽입하는 것을 특징으로 하는 컨텐츠 제공 서버.
The method according to claim 1,
Wherein the transmission data allocation unit further inserts a security packet into a data packet transmitted by the data transmission unit to the user terminal.
제1항에 있어서,
상기 피어단말 제어부는, 피어단말의 다운로드 기여도를 산출하고, 상기 기여도에 따라 보상을 지급하는 것을 특징으로 하는 컨텐츠 제공 서버.
The method according to claim 1,
Wherein the peer terminal control unit calculates a download contribution of the peer terminal and pays compensation according to the contribution.
컨텐츠 제공 서버로부터 전송되는 제어신호를 수신하는 제어신호 수신부;
컨텐츠 제공 서버측으로 당해 피어단말에 대한 단말정보를 생성하여 전송하는 단말정보 제공부;
컨텐츠 제공 서버로부터 수신한 제어신호에 따라 지정된 사용자 단말로 할당된 데이터 패킷을 전송하는 데이터 전송부; 및
상기 제어신호 수신부, 단말정보 제공부 및 데이터 전송부를 제어하는 제어부;
를 포함하는 피어 단말.
A control signal receiving unit for receiving a control signal transmitted from a content providing server;
A terminal information provider for generating and transmitting terminal information for the peer terminal to the content providing server;
A data transmission unit for transmitting a data packet allocated to a designated user terminal according to a control signal received from a content providing server; And
A control unit for controlling the control signal receiving unit, the terminal information providing unit and the data transmitting unit;
.
제 6항에 있어서,
상기 단말정보는 피어단말이 저장하고 있는 컨텐츠 정보, 지정된 사용자 단말로의 데이터 전송 가능여부 또는 피어단말의 사양정보 중 적어도 어느 하나를 포함하는 것을 특징으로 하는 피어 단말.
The method according to claim 6,
Wherein the terminal information includes at least one of content information stored in a peer terminal, whether data can be transmitted to a designated user terminal, or specification information of a peer terminal.
컨텐츠 제공 서버에 대하여 특정 컨텐츠에 대한 다운로드를 요청하는 컨텐츠 요청부;
컨텐츠 제공 서버 및 하나 이상의 피어단말로부터 데이터 패킷을 수신하는 데이터 수신부;
수신한 데이터 패킷을 조합하여 하나의 완성된 컨텐츠로 복원하는 데이터 합성부; 및
상기 컨텐츠 요청부, 데이터 수신부 및 데이터 합성부를 제어하는 제어부;
를 포함하는 사용자 단말
A content request unit for requesting a content providing server to download a specific content;
A data receiving unit for receiving a data packet from a content providing server and one or more peer terminals;
A data synthesizer for combining the received data packets and restoring them into one complete content; And
A control unit for controlling the content requesting unit, the data receiving unit, and the data synthesizing unit;
Lt; / RTI >
제8항에 있어서,
컨텐츠 제공 서버 및 하나 이상의 피어단말로부터 데이터 패킷을 수신한 이후 누락된 데이터 패킷이 존재하는지 여부를 확인하는 데이터 확인부;
를 더 포함하는 사용자 단말.
9. The method of claim 8,
A data checking unit for checking whether a missing data packet exists after receiving the data packet from the content providing server and one or more peer terminals;
Lt; / RTI >
컨텐츠 제공 서버에 대해 컨텐츠 다운로드 요청을 하고, 상기 컨텐츠 제공 서버 및 하나 이상의 피어단말로부터 데이터 패킷을 수신하여 하나의 완성된 컨텐츠로 복원하는 사용자 단말;
사용자 단말로부터 특정 컨텐츠에 대한 다운로드 요청이 수신되면 상기 사용자 단말로의 해당 컨텐츠 전송이 가능한 피어단말을 검색하고, 당해 컨텐츠 제공 서버 및 피어단말이 전송할 데이터 패킷을 할당하며, 할당된 데이터 패킷을 사용자 단말로 전송하고, 상기 피어단말로 데이터 패킷 전송 제어를 위한 제어신호를 전송하는 컨텐츠 제공 서버; 및
컨텐츠 제공 서버의 제어신호에 따라 할당받은 데이터 패킷을 상기 사용자 단말로 전송하는 하나 이상의 피어단말;
을 포함하는 멀티소스(multi-source) 다운로드 시스템.
A user terminal for making a content download request to a content providing server, receiving a data packet from the content providing server and one or more peer terminals and restoring the received content to one completed content;
A download request for a specific content is received from the user terminal, a search is made for a peer terminal capable of transmitting the corresponding content to the user terminal, a data packet to be transmitted by the content providing server and the peer terminal is allocated, And transmits a control signal for control of data packet transmission to the peer terminal; And
At least one peer terminal for transmitting the allocated data packet to the user terminal according to a control signal of the content providing server;
A multi-source download system.
컨텐츠 제공 서버가
(a) 사용자 단말로부터 컨텐츠 다운로드 요청을 수신하는 단계;
(b) 상기 사용자 단말로의 컨텐츠 전송이 가능한 피어단말을 검색하는 단계;
(c) 상기 (b)단계에서의 검색결과를 바탕으로 당해 컨텐츠 제공 서버 및 하나 이상의 피어단말이 전송할 데이터 패킷을 할당하는 단계;
(d) 상기 피어단말로 제어신호를 전송하는 단계;
(e) 상기 (c)단계에서 할당된 데이터 패킷을 상기 사용자 단말로 전송하는 단계;
를 포함하는 컨텐츠 제공 서버의 멀티소스 다운로드 서비스 제공 방법.
If the content providing server
(a) receiving a content download request from a user terminal;
(b) searching for a peer terminal capable of transmitting content to the user terminal;
(c) allocating a data packet to be transmitted by the content providing server and the one or more peer terminals based on the search result in the step (b);
(d) transmitting a control signal to the peer terminal;
(e) transmitting the data packet allocated in the step (c) to the user terminal;
And downloading the multi-source download service.
(a) 사용자 단말이 컨텐츠 제공 서버에 대해 컨텐츠 다운로드 요청을 하는 단계;
(b) 컨텐츠 제공 서버가 사용자 단말로부터 컨텐츠 다운로드 요청을 수신한 이후 상기 사용자 단말로의 해당 컨텐츠 전송이 가능한 피어단말을 검색하는 단계;
(c) 컨텐츠 제공 서버가 상기 (b)단계에서의 검색결과를 바탕으로 당해 컨텐츠 제공 서버 및 하나 이상의 피어단말이 전송할 데이터 패킷을 할당하는 단계;
(d) 컨텐츠 제공 서버가 상기 피어단말로 데이터 패킷 전송 제어를 위한 제어신호를 전송하는 단계;
(e) 컨텐츠 제공 서버 및 하나 이상의 피어 단말이 상기 사용자 단말로 각 할당된 데이터 패킷을 전송하는 단계;
를 포함하는 멀티소스 다운로드 방법.
(a) the user terminal making a content download request to the content providing server;
(b) searching the peer terminal capable of transmitting the content to the user terminal after the content providing server receives the content download request from the user terminal;
(c) allocating a data packet to be transmitted by the content providing server and the one or more peer terminals based on the search result in the step (b);
(d) transmitting, by the content providing server, a control signal for controlling data packet transmission to the peer terminal;
(e) transmitting each allocated data packet to the user terminal by the content providing server and the one or more peer terminals;
/ RTI >
제12항에 있어서,
(e)단계 이후,
사용자 단말이 수신한 데이터 패킷을 조합하여 하나의 완성된 컨텐츠로 복원하는 단계;
를 더 포함하는 멀티소스 다운로드 방법.
13. The method of claim 12,
After step (e)
Combining the data packets received by the user terminal to restore one complete content;
The method further comprising:
제12항에 있어서,
(e)단계 이후,
사용자 단말이 누락된 데이터 패킷의 존재여부를 확인하는 단계;
사용자 단말의 확인결과 누락된 데이터 패킷이 존재하면 컨텐츠 제공 서버 측으로 누락된 데이터 패킷정보를 전송하는 단계; 및
컨텐츠 제공 서버가 사용자 단말로 누락된 데이터 패킷을 전송하는 단계;
를 더 포함하는 멀티소스 다운로드 방법.
13. The method of claim 12,
After step (e)
Checking whether a user terminal has a missing data packet;
Transmitting missing data packet information to a content providing server if a missing data packet exists as a result of the confirmation of the user terminal; And
The contents providing server transmitting the missing data packet to the user terminal;
The method further comprising:
제12항에 있어서,
컨텐츠 제공 서버가 피어단말의 다운로드 기여도를 산출하고 상기 기여도에 따라 보상을 지급하는 단계;
를 더 포함하는 멀티소스 다운로드 방법.
13. The method of claim 12,
The content providing server calculating a download contribution of the peer terminal and paying the reward according to the contribution;
The method further comprising:
KR1020130129918A 2013-10-30 2013-10-30 Apparatus and Method for Multi-source downloading KR20150050669A (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020130129918A KR20150050669A (en) 2013-10-30 2013-10-30 Apparatus and Method for Multi-source downloading

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020130129918A KR20150050669A (en) 2013-10-30 2013-10-30 Apparatus and Method for Multi-source downloading

Publications (1)

Publication Number Publication Date
KR20150050669A true KR20150050669A (en) 2015-05-11

Family

ID=53388352

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020130129918A KR20150050669A (en) 2013-10-30 2013-10-30 Apparatus and Method for Multi-source downloading

Country Status (1)

Country Link
KR (1) KR20150050669A (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20200091648A (en) * 2019-01-23 2020-07-31 넷마블 주식회사 Computer program, contents download management server and method for downloading contents

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20200091648A (en) * 2019-01-23 2020-07-31 넷마블 주식회사 Computer program, contents download management server and method for downloading contents

Similar Documents

Publication Publication Date Title
US9118638B2 (en) Content delivery using multiple sources over heterogeneous interfaces
US8280986B2 (en) Mobile terminal and associated storage devices having web servers, and method for controlling the same
CN102263828B (en) Load balanced sharing method and equipment
JP4823602B2 (en) Method for providing access to encrypted content to one of a plurality of consumer systems, apparatus for providing access to encrypted content, and method for generating a secure content package
CN104137587B (en) A kind of method and terminal device for sending, receiving user data
JP4980592B2 (en) How to provide a rights data object
EP2628125B1 (en) Method and apparatus for downloading drm module
US20170295467A1 (en) Kiosk System for Downloading Media Content
KR101465966B1 (en) Data encryption processing apparatus and method in a cloud environment
US8761727B2 (en) Method and apparatus for pre-caching in a telecommunication system
US8903972B2 (en) Method and apparatus for sharing contents using information of group change in content oriented network environment
US20140344901A1 (en) Method And System For Sharing A File
KR102147026B1 (en) Application download method and device
CN109982152A (en) P2P CDN method for processing business, intelligent gateway and CDN platform
KR100823730B1 (en) Method and apparatus for providing streaming service based on P2P, and streaming service system using the same
CN103685426A (en) An information processing method and an information processing apparatus used for an electronic device
CN102571963B (en) Content delivery method, device and access network equipment
CN103973747A (en) Method and device for acquiring content
EP3449614B1 (en) Handling cached content resources
KR20150050669A (en) Apparatus and Method for Multi-source downloading
JP2017500642A (en) System and method for policy control function management mechanism
CN109754251B (en) Data processing method and device, medium and terminal thereof
US20080170589A1 (en) Server and simultaneous access control method thereof
CN106060155A (en) P2P (Peer to Peer) resource sharing method and device
US9264886B1 (en) Scaling storage capability for subscriber data across multiple devices and device types in a mobile data network

Legal Events

Date Code Title Description
N231 Notification of change of applicant
E902 Notification of reason for refusal
E601 Decision to refuse application