US20090070843A1 - Video server for video distribution system - Google Patents

Video server for video distribution system Download PDF

Info

Publication number
US20090070843A1
US20090070843A1 US12/263,559 US26355908A US2009070843A1 US 20090070843 A1 US20090070843 A1 US 20090070843A1 US 26355908 A US26355908 A US 26355908A US 2009070843 A1 US2009070843 A1 US 2009070843A1
Authority
US
United States
Prior art keywords
video
video information
http
terminal
server
Prior art date
Legal status (The legal status 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 status listed.)
Abandoned
Application number
US12/263,559
Inventor
Koichi Shibata
Masaru Igawa
Koichi Morita
Shuichi Sakamoto
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Individual
Original Assignee
Individual
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 Individual filed Critical Individual
Priority to US12/263,559 priority Critical patent/US20090070843A1/en
Publication of US20090070843A1 publication Critical patent/US20090070843A1/en
Abandoned legal-status Critical Current

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/21Server components or server architectures
    • 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

Definitions

  • the present invention relates to a video server for transmitting a video signal in parallel to a plurality of locations using the Internet protocol, and more particularly, to a video server for a video distribution system which enables transmission of a video signal through a transmission path, which cannot use IP multicast, through protocol conversion.
  • multicast Simultaneous transmission of a signal such as a video signal to multiple locations, utilizing a protocol such as the Internet protocol, is referred to as “multicast,” and a number of methods for realizing the multicast have already been proposed, with some of such methods already brought into practical use.
  • a representative one of these methods is the Internet multicast technology which has been published as a standard designated “RFC1112” of Internet Engineering Task Force (IETF).
  • a critical component of the multicast technology is a host group model.
  • Multicast information is transmitted to a host group indicated by some multicast address, such that each of terminals attempting to share the multicast information receives the information addressed to the host group.
  • multicast information is accompanied by a “multicast address,” used as a destination address, which indicates that the information is multicast.
  • a device for controlling an information transmission path i.e., a “router” reads its multicast address, and transmits the multicast information to a path to which a terminal belonging to an associated host group is connected.
  • the router copies the information intended for transmission, and transmits the copies to the respective paths.
  • firewalls are installed everywhere as required for the security, preventing the Internet protocol information from freely passing therethrough.
  • the firewall refers to a device for examining information which is going to pass therethrough to block information other than that regarded as safe. Multicast information is generally blocked by the firewall. Therefore, a special setting is required for multicast information to pass through the firewall. However, it is quite difficult to pass multicast information through in the current Internet in which firewalls are installed everywhere and managed independently by different organizations.
  • the video is conventionally transmitted individually from the video server to each of the terminals.
  • the amount of information transmitted from the video server to the terminals is increased in proportion to the number of receiving terminals, resulting in a problem of a higher transmission cost.
  • the present invention provides a video server for distributing a digitized video content, which includes a unit for determining whether or not a video content requested from a terminal is stored in the video server, a unit for transmitting a transmission request to another video server for transmitting the video content thereto in accordance with the HTTP (Hyper-Text Transfer Protocol) protocol when the video content requested by the terminal is not stored in the video server, and a unit for receiving the video content transmitted from the other video server in accordance with the HTTP protocol and transmitting the video content to the terminal in accordance with the IP multicast or the HTTP protocol.
  • HTTP Hyper-Text Transfer Protocol
  • the transmission unit further includes a plurality of buffers, a buffer selector, and a reference time generator.
  • the transmission unit detects a random access point in image information, and stores the image information up to the next random access point in one of the plurality of buffers.
  • the buffer selector selects, from among the plurality of buffers, image information which has not been transmitted and has a time stamp equal to or smaller than a reference time generated by the reference time generator, and indicates the selected image information to the transmission unit.
  • FIG. 1 is a block diagram illustrating an example of a video distribution system in which two video servers according to the present invention are connected through a transmission path which does not allow IP multicast to pass therethrough;
  • FIG. 2 is a flow diagram for explaining the operational flow of the video distribution system utilizing the video servers described in FIG. 1 ;
  • FIG. 3 is a flow chart for explaining the operation of the video server system illustrated in FIG. 2 ;
  • FIG. 4 is a diagram illustrating an example of management information stored in video management tables 204 , 214 ;
  • FIG. 6 is a block diagram illustrating an exemplary configuration of a video delivery unit
  • FIG. 6 is a diagram illustrating an exemplary format for image information
  • FIG. 7 is a diagram for explaining an example of extended functions for the video delivery unit.
  • FIG. 8 is a diagram for explaining an exemplary video transmission method according to the HTTP protocol.
  • FIG. 1 illustrates an example of a video distribution system in which two video servers according to the present invention are connected through a transmission path which does not allow IP multicast to pass therethrough.
  • a video content stored in a video storage 102 A of a video server 101 A can be transmitted simultaneously to client terminals 103 A through an IP network 12 A using an IP multicast transmission scheme.
  • IP multicast based transmission cannot be realized from the video server 101 A to the client terminal 103 B, though connected to the network 12 B, because a network connecting the IP network 12 A and the IP network 12 B has a firewall 104 interposed therebetween and serves as a network dedicated to HTTP.
  • the present invention transmits image information using the HTTP protocol only when the image information is passed through an HTTP network. For example, when an client terminal 103 B requests to view a video content stored in the video storage 102 A and multicast to the client terminals 103 A, the video server 101 A transmits image information to the client terminals 103 A using the IP multicast, and simultaneously transmits the image information to the video server 101 B through the HTTP network 11 using the HTTP protocol.
  • the video server 101 B receives the image information transmitted from the video server 101 A, and multicasts the image information to the client terminals 103 B using the IP multicast.
  • a logical transmission path in accordance with the HTTP protocol between the video servers 101 A and 101 B is different from a logical transmission path in accordance with the IP multicast between the video server 101 B and the client terminals 103 B.
  • the video server 101 B manages the correspondence for both logical transmission paths and controls transmission/reception of image information.
  • FIG. 2 is a diagram for explaining the operational flow of the video distribution system utilizing the video servers described in connection with FIG. 1 .
  • explanation will be given of how a video content stored in a video storage 216 of a video server 101 A is viewed on an client terminal 103 B.
  • a video server 101 B comprises a video management unit 203 and a video delivery unit 205 .
  • Image information is stored in a video storage 206 , while identification information, attributes and so on for identifying the name and file of particular image information are managed by a video management table 204 which is referenced by the video management unit 203 .
  • the video server 101 A comprises a video management unit 213 and a video delivery unit 215 .
  • Image information is stored in a video storage 216 , while identification information, attributes and so on for identifying the name and file of particular image information are managed by a video management table 214 which is referenced by the video management unit 213 .
  • the video servers 101 A, 101 B comprise computers equipped with communication functions, and the video management units and the video delivery units are implemented by software programs.
  • FIG. 3 is a flow chart for explaining the operation of the video distribution system illustrated in FIG. 2 .
  • the video management unit 203 references the video management table 204 to determine whether or not the requested video content is stored in the video storage 206 (step S 2 ), and sends a transmission command 23 to the video delivery unit 205 (step S 3 ) when determining that the video content is stored in the video storage 206 (step S 2 : Y).
  • the video delivery unit 205 retrieves the requested video content 24 from the video storage 206 for delivery to the client terminal 103 B (step S 4 ).
  • the video delivery unit 205 may also transmit the video content 24 simultaneously to a plurality of other terminals using the IP multicast as is the case with the client terminal 103 B.
  • the video management unit 203 sends an audience request 25 to the video management unit 213 in the other video server 101 A (step S 5 ).
  • the video server 101 B has a list of other video servers which can be connected thereto.
  • the video management unit 213 upon receipt of the audience request 25 , references the video management table 214 to determine whether or not the requested video content is stored in the video storage 216 .
  • the video management unit 213 When stored, the video management unit 213 sends a transmission command 27 to the video delivery unit 215 , and sends to the video management unit 203 in the video server 101 B reception parameters 26 required for receiving the video content from the video delivery unit 215 , for example, attribute information such as a video format, compression method, rate, and so on (step S 6 ). Transmission/reception of the audience request and parameters between the video servers are performed in accordance with the HTTP protocol (and may be performed in accordance with any other protocol).
  • the video server 101 B When the requested video content is not stored in the video storage 216 , the video server 101 B further sends an audience request to another video server within the list. The video server 101 B repeats this operation, and returns an error or the like when the requested video content is not stored in any video server.
  • the video delivery unit 215 upon receipt of the transmission command 27 , uses the HTTP protocol to retrieve image information of interest from the video storage 216 and transmit the retrieved image information to the video delivery unit 205 in the video server 101 B in accordance with the transmission command 27 (step S 7 ).
  • the video management unit 203 Upon receipt of the reception parameters 26 , the video management unit 203 sends the transmission command 23 adapted for the parameters 26 to the video delivery unit 205 , and transmits to the client terminal 103 B reception parameters 22 which are attribute information of the video content required to receive the video content (step S 8 ).
  • the video delivery unit 205 receives a HTTP-based video content 28 from the video delivery unit 215 in the video server 101 A in accordance with the received transmission command 23 , and again transmits the video content 28 to the client terminal 103 B as image information 24 .
  • the image information received by the video delivery unit 205 is also stored in the video storage 206 for registering its title and so on in the video management table 204 as a cache which is temporary information (step S 9 ).
  • the video management unit 203 when an audience request for the same video content is again transmitted from an client terminal, the video management unit 203 , at this time, can find the requested video storage registered in the video management table 204 as a cache, sends a transmission command 23 to the video delivery unit 205 , retrieves the image information 24 stored in the video storage 206 , and transmits the image information 24 to the client terminal 103 B (steps S 3 , S 4 ). In this event, since the image information need not be retrieved and transmitted from the video storage 216 in the video server 101 A, a large reduction in the transmission cost can be accomplished.
  • FIG. 4 is a diagram illustrating an example of management information stored in the video management tables 204 , 214 .
  • a server 1 is a video server which holds the video management table
  • servers 2 , 3 , . . . are other video servers.
  • the video management table describes perfect information on video contents stored in the server 1 .
  • information on video contents once transmitted in the past is described in a cache directory.
  • An audience request for a video content which is not described in the cache directory is queried sequentially to the other servers as mentioned above.
  • Each video content is managed by a video title (for example, “move 1”), attribute information thereof (the type of the video content, initialization parameters for decoding the video content, dimensions of the vertical side 720 and the horizontal side 480 , and so on), the location of the file (for example, a file name such as “video A.movie”), and so on.
  • a video title for example, “move 1”
  • attribute information thereof the type of the video content, initialization parameters for decoding the video content, dimensions of the vertical side 720 and the horizontal side 480 , and so on
  • the location of the file for example, a file name such as “video A.movie”
  • FIG. 4 shows that video contents 3 , 4 are recorded in a directory 1 of the server 1 ; video contents 5 , 6 in a directory 2 ; a directory 4 and a video content 7 in a directory 3 ; video contents 8 , 9 , 10 in the directory 4 ; and video contents 1 , 2 directly in the server 1 .
  • FIG. 4 shows in the cache directory that video contents 11 , 12 , 13 , 14 have been once transmitted from the servers 2 , 3 , 4 , respectively, and stored in the server 1 as caches.
  • FIG. 6 is a diagram illustrating an exemplary format for the image information in this embodiment.
  • FIG. 6 illustrates image information which is compressed using MPEG (Moving Picture Experts Group).
  • a video content can be regarded as a sequence of a plurality of still images.
  • a plurality of information pieces for still images forming part of a video content are designated 501 A, 502 A, 502 B, 502 C, 501 B.
  • differential information between one image and the following image is used for encoding a majority of still images 502 A, 502 B, 502 C within this sequence of still images, so that it is difficult to retrieve and decode only such still images.
  • These still images are referred to as “P frames.”
  • still images such as 501 A, 501 B are encoded independently of previous and following still images such that the video content can be started from these images.
  • These still images are referred to as “I frames.” If the video content is decoded from the beginning of a header added to the beginning of codes in an I frame, the video content can be correctly decoded. For this reason, this point is referred to as a “random access point.”
  • the video content is further divided into smaller fragments (packets) 503 A, 503 B, 503 C, 503 D, 503 E, . . . , 503 F, 503 G, 503 H when it is transmitted.
  • the head packet 503 A ( 503 G as well) of the packets comprising an I frame image stores a time stamp 505 which describes a relative time at which the information is reproduced in a packet header 504 .
  • Packets included between the head packets of two consecutive I frames for example, packets 503 A- 503 F in FIG. 6 define a minimum unit for reproducing the video content.
  • N is a natural number and variable).
  • FIG. 5 is a block diagram illustrating an exemplary configuration of the video delivery unit.
  • the video delivery unit illustrated in FIG. 5 corresponds to the video delivery unit 205 in the video server 101 B previously described with reference to FIG. 2 , and shows a specific configuration for delivering HTTP-based image information transmitted from the other video server 101 A to the client terminal 103 B.
  • the video delivery unit comprises an HTTP reception buffer 401 ; an HTTP receiver 402 ; a file writer 403 ; a video storage 404 ; a file reader 405 ; speed adjusting buffers 406 A- 406 C; a buffer controller 407 ; a transmission controller 408 ; and a transmission reference time generator 409 for generating a reference time for transmission.
  • image information 28 incoming from another video server (corresponding to the video server 101 A in FIG. 2 ) is temporarily stored in the HTTP reception buffer 401 .
  • the HTTP receiver 402 sequentially reads the image information 28 from the HTTP reception buffer 401 , examines a packet header to detect a random access point, and stores the image information 28 in the aforementioned minimum units, which allow correct decoding of the video contents, in the speed adjusting buffers 406 A, 406 B, 406 C. While the video delivery unit of this example is provided with three speed adjusting buffers, the same operation principles can be applied if two or more buffers are provided.
  • the buffer controller 407 that manages which image information from the HTTP reception buffer 401 should be stored in which speed adjusting buffer.
  • the buffer controller 407 instructs the HTTP receiver 402 to select the buffer which is not currently used for transmission and into which the preceding image information was written least recently, and to perform a write into the selected buffer.
  • the three speed adjusting buffers are equally used in order except for that actually in use for transmission.
  • the transmission controller 408 reads a video content from one of the speed adjusting buffers 406 A, 406 B, 406 C and transmits it to the client terminal as image information 24 . In this event, it is again the buffer controller 407 that determines from which speed adjusting buffer the image information is read. The buffer controller 407 selects in order such buffers that are not currently being written and from which the contents have not been read.
  • the transmission controller 408 reads a time stamp of the image information read from the selected speed adjusting buffer, and compares the time stamp with the reference time 42 received from the transmission reference time generator 409 . When the time stamp value is equal to or smaller than the reference time 42 , the image information 24 is sent to the terminal through the IP multicast. Once the transmission is completed, the transmission controller 408 dequeues the image information in the buffer. On the other hand, when the time stamp value is larger than the reference time, the transmission controller 408 discards the image information rather than transmitting it to the terminal, and also dequeues the image information from the buffer. In other words, the video controller 408 discards image information exceeding the transmission capability in order to prevent a delay from occurring in course of transmission/reception.
  • the image information received by the HTTP receiver 402 is sent not only to the speed adjusting buffers but also to the file writer 403 for storage in the video storage 206 . Also, when an audience request is sent for image information which has been stored in the video storage 206 , the file reader 405 , instead of the HTTP receiver 402 , reads the requested image information from the video storage 206 and stores it in the speed adjusting buffers 405 A, 406 B, 406 C.
  • FIG. 7 is a diagram for explaining an example of extended functions for the video delivery unit of the present invention.
  • an HTTP reception buffer 401 an HTTP receiver 402 , a file writer 403 , a video storage 206 , a file reader 405 , speed adjusting buffers 406 A, 406 B, 406 C, a buffer controller 407 operate in the same manner as their respective counterparts in FIG. 5 .
  • a multicast transmitter 408 operates in the same manner as the transmission controller 408 in FIG. 5 .
  • the embodiment of FIG. 7 includes a transmission function, added to the embodiment of FIG. 5 , for transmitting image information to a plurality of client terminals in accordance with the HTTP protocol. Since the HTTP protocol is essentially intended for point-to-point communications, it is not suitable for transmitting the same information simultaneously to a plurality of terminals.
  • this embodiment separately provides HTTP transmission controllers corresponding to a terminal A 603 A and a terminal B 603 B, respectively.
  • An HTTP transmission controller 601 A is responsible for transmission to the terminal A 603 A, and has a buffer 602 A for temporarily storing information to be transmitted.
  • an HTTP transmission controller 601 B is responsible for transmission to the terminal B 603 B, and has a buffer 602 B for temporarily storing information to be transmitted.
  • a similar configuration may be applied for transmitting image information to three or more terminals.
  • the terminal A 603 A first transmits a video transmission request 64 A in sequence to the HTTP transmission controller 601 A.
  • the HTTP transmission controller 601 A upon receipt of the video transmission request 64 A, reads information from the buffer 602 A for transmission to the terminal A 603 A as image information 63 A.
  • the HTTP transmission controller 601 A reads image information to be next transmitted from one of the speed adjusting buffers 406 A, 406 B, 406 C, and stores the read image information in the buffer 602 A.
  • the buffer controller 407 selects a speed adjusting buffer which stores the most recent image information that has not been transmitted to the terminal A 603 A, and into which image information is not being written.
  • the buffer controller 407 selects a like speed adjusting buffer for the terminal B 603 B. Subsequently, at the time the multicast transmission controller 408 has read and transmitted the contents (image information) of the buffer, the contents of the buffer are deleted.
  • the HTTP transmission controllers 601 A, 601 B have the same transmission reference time generator as that designated by 409 in FIG. 5 , and transmits image information in the buffers 602 A, 602 B to a terminal such that no delay occurs.
  • FIG. 8 is a diagram for explaining an exemplary video transmission method between a video server and a terminal according to the HTTP protocol.
  • N N>2 logical transmission paths are established between a video server and a terminal for use in sending a video content.
  • the HTTP protocol involves a procedure in which the transmission side responds to a transmission request from the reception side, so that a transmission path is left unused until a response is returned from the transmission side after the transmission request has been sent from the reception side, thereby causing a lower efficiency.
  • this embodiment enables a plurality of transmission requests to be issued to a server even for a period from the time the first request has been issued to the time a response is returned.
  • a video content from a image information source 701 is stored in the speed adjusting buffers 702 A, 702 B, 702 C, in a manner similar to the embodiment of FIG. 5 .
  • the video content stored in the speed adjusting buffers 702 A, 702 B, 702 C is overwritten or erased from the oldest one irrespective of whether it has been transmitted or not.
  • a selector 703 selects, in response to a request from a transmitter associated with each terminal, selects a speed adjusting buffer which stores the most recent video content and into which a write is not being executed, from among the speed adjusting buffers 702 A, 702 B, 702 C, and sends the contents of the selected speed adjusting buffer to the transmitter.
  • a transmitter is provided in correspondence to each reception side for responding to requests from a plurality of transmission sides.
  • a transmitter 704 A is provided for a receiver 708 A of a terminal A
  • a transmitter 704 B is provided for a receiver 708 B of a terminal B.
  • the transmitter 704 A for the terminal A and the receiver 708 A of the terminal A are connected over a transmission path 707 through a plurality of independent logical transmission paths in accordance with the HTTP protocol. In this example, three HTTP protocol connections are used.
  • the transmitter 704 B for the terminal B and the receiver 708 B of the terminal B are also connected in a similar manner.
  • An HTTP reception controller 709 A provided in the receiver 708 A of the terminal A transmits a transmission request 71 to the transmitter 705 A for the terminal A.
  • a video content 72 is transmitted from the HTTP transmitter 705 A to the HTTP reception controller 709 A.
  • an HTTP reception controller 709 B receives a video content from an HTTP transmission controller 705 B
  • an HTTP reception controller 709 C receives a video content from the HTTP transmission controller 705 C.
  • Each of the HTTP reception controllers 709 A, 709 B, 709 C in the terminal A transmits the next transmission request 71 to the HTTP transmission controller 705 A, 705 B, 705 C associated therewith immediately after it has received the video content.
  • the HTTP transmission controllers 705 A, 705 B, 705 C upon receipt of the transmission request 71 from the HTTP reception controllers 709 A, 709 B, 709 C associated therewith, each refers to the contents of a transmitted time stamp memory 706 to compare a time stamp of image information of the most recent video fragment transmitted to the terminal A with time stamps of image information stored in the speed adjusting buffers 702 A, 702 B, 702 C.
  • a selector 703 selects the most recent video fragment stored in the speed adjusting buffer 702 A, 702 B or 702 C for transmission.
  • the time stamp of the transmitted image information is stored in the transmitted time stamp memory 706 .
  • the speed adjusting buffers 702 A, 702 B, 702 C do not store image information having a time stamp more recent than the stored time stamp, the transmission is delayed until recent image information is written into the speed adjusting buffers 702 A, 702 B, 702 C.
  • the respective HTTP reception controllers 709 A, 709 B, 709 C transmit, independently of one another, transmission requests 71 to the HTTP transmission controllers 705 A, 705 B, 705 C associated therewith. Each time the HTTP transmission controllers 705 A, 705 B, 705 C receive the transmission request 71 , they merely transmit back the most recent image information at that time as image information 72 . Therefore, the image information transmitted back to the HTTP reception controllers 709 A, 709 B, 709 C does not always reach in order. Further, the HTTP reception controllers 709 A, 709 B, 709 C may fail to receive image information due to communication failures or the like.
  • the image information received at the HTTP reception controllers 709 A, 709 B, 709 C must be sent to a decoder 712 A after it is rearranged in correct order.
  • a selector 711 compares a time stamp stored in a decoded time stamp memory 710 with time stamps of the image information which has reached the HTTP reception controllers 709 A, 709 B, 709 C to select the HTTP reception controller which stores the least recent image information except for already decoded image information, and sends the image information stored therein to the decoder 712 A.
  • the associated HTTP reception controller After the image information is sent to the decoder 712 A, the associated HTTP reception controller again sends a transmission request 71 to the HTTP transmission controller.
  • a time stamp of the image information sent to the decoder 712 A is stored in the decoded time stamp memory 710 . If image information previous to the decoded time stamp reaches any of the HTTP reception controllers 709 A, 709 B, 709 C, the HTTP reception controller stops receiving the image information at that time, discards the image information which has been received, and immediately sends the next transmission request 71 .
  • the operations in the transmitter 704 B for the terminal B, the receiver 708 B for the terminal B, and a decoder 712 B are similar to the foregoing.
  • the HTTP protocol based video transmission method using a plurality of logical transmission paths can be applied to video transmission/reception between video servers.

Abstract

A video server for distributing a digitized video content includes a unit for determining whether or not a video content requested from a terminal is stored in the video server, a unit for issuing a transmission request to another server for transmitting the video thereto in accordance with the HTTP protocol when the video content requested from the terminal is not stored in the video server, and a unit for receiving the video content transmitted from the other video server in accordance with the HTTP protocol, and transmitting the video content to the terminal in accordance with IP multicast or HTTP protocol.

Description

    CROSS-REFERENCE TO RELATED APPLICATION
  • The present application is a continuation of application Ser. No. 11/406,394, filed Apr. 19, 2006; which is a divisional application of application Ser. No. 09/739,691, filed Dec. 20, 2000, now U.S. Pat. No. 7,069,332; which relates to U.S. application Ser. No. 09/764,377, filed Jan. 19, 2001 and based on Japanese Application 2000-021977, the entire contents of which are incorporated herein by reference.
  • BACKGROUND OF THE INVENTION
  • The present invention relates to a video server for transmitting a video signal in parallel to a plurality of locations using the Internet protocol, and more particularly, to a video server for a video distribution system which enables transmission of a video signal through a transmission path, which cannot use IP multicast, through protocol conversion.
  • Simultaneous transmission of a signal such as a video signal to multiple locations, utilizing a protocol such as the Internet protocol, is referred to as “multicast,” and a number of methods for realizing the multicast have already been proposed, with some of such methods already brought into practical use. A representative one of these methods is the Internet multicast technology which has been published as a standard designated “RFC1112” of Internet Engineering Task Force (IETF).
  • A critical component of the multicast technology is a host group model. Multicast information is transmitted to a host group indicated by some multicast address, such that each of terminals attempting to share the multicast information receives the information addressed to the host group. In a network based on the Internet protocol, multicast information is accompanied by a “multicast address,” used as a destination address, which indicates that the information is multicast.
  • Upon receiving multicast information, a device for controlling an information transmission path, i.e., a “router” reads its multicast address, and transmits the multicast information to a path to which a terminal belonging to an associated host group is connected. In this event, when a plurality of terminals belong to the associated host group and they are located on different paths, the router copies the information intended for transmission, and transmits the copies to the respective paths. This scheme allows for a large reduction in the amount of transmitted information, as compared with independent transmission of information from an origination to all terminals is belonging to a host group.
  • However, the effectiveness of the multicast-based transmission is limited only to those paths which support the multicast from an origination to all terminals belonging to a host group. Additionally, in the current Internet environment, firewalls are installed everywhere as required for the security, preventing the Internet protocol information from freely passing therethrough.
  • The firewall refers to a device for examining information which is going to pass therethrough to block information other than that regarded as safe. Multicast information is generally blocked by the firewall. Therefore, a special setting is required for multicast information to pass through the firewall. However, it is quite difficult to pass multicast information through in the current Internet in which firewalls are installed everywhere and managed independently by different organizations.
  • Therefore, for transmitting the same video simultaneously to a plurality of terminals when firewalls are interposed between a video server and the terminals, the video is conventionally transmitted individually from the video server to each of the terminals. In this event, the amount of information transmitted from the video server to the terminals is increased in proportion to the number of receiving terminals, resulting in a problem of a higher transmission cost.
  • On the other hand, many of protocols for passing information through a firewall are inherently intended for file transfer, so that although they can transmit information without errors, they do not guarantee when the information will arrive at a particular terminal. Applications which require the multicast often involve real-time transmission such as transmission of video and audio contents. Therefore, a mechanism for matching the transmission rate between reception and transmission of video and audio contents is required for protocols which pass the information through firewalls.
  • SUMMARY OF THE INVENTION
  • It is an object of the present invention to provide a video server for a video distribution system which is capable of solving the above-mentioned problems, and transmitting the same video from a video server to a plurality of terminals utilizing the multicast to reduce the transmission cost even when firewalls are interposed between the video server and the terminals.
  • It is another object of the present invention to provide a mechanism for matching the transmission rate between reception and transmission in an asynchronous transmission network.
  • To achieve the above object, the present invention provides a video server for distributing a digitized video content, which includes a unit for determining whether or not a video content requested from a terminal is stored in the video server, a unit for transmitting a transmission request to another video server for transmitting the video content thereto in accordance with the HTTP (Hyper-Text Transfer Protocol) protocol when the video content requested by the terminal is not stored in the video server, and a unit for receiving the video content transmitted from the other video server in accordance with the HTTP protocol and transmitting the video content to the terminal in accordance with the IP multicast or the HTTP protocol.
  • The transmission unit further includes a plurality of buffers, a buffer selector, and a reference time generator. The transmission unit detects a random access point in image information, and stores the image information up to the next random access point in one of the plurality of buffers. The buffer selector selects, from among the plurality of buffers, image information which has not been transmitted and has a time stamp equal to or smaller than a reference time generated by the reference time generator, and indicates the selected image information to the transmission unit.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a block diagram illustrating an example of a video distribution system in which two video servers according to the present invention are connected through a transmission path which does not allow IP multicast to pass therethrough;
  • FIG. 2 is a flow diagram for explaining the operational flow of the video distribution system utilizing the video servers described in FIG. 1;
  • FIG. 3 is a flow chart for explaining the operation of the video server system illustrated in FIG. 2;
  • FIG. 4 is a diagram illustrating an example of management information stored in video management tables 204, 214;
  • FIG. 6 is a block diagram illustrating an exemplary configuration of a video delivery unit;
  • FIG. 6 is a diagram illustrating an exemplary format for image information;
  • FIG. 7 is a diagram for explaining an example of extended functions for the video delivery unit; and
  • FIG. 8 is a diagram for explaining an exemplary video transmission method according to the HTTP protocol.
  • DESCRIPTION OF THE EMBODIMENTS (1) System Configuration
  • FIG. 1 illustrates an example of a video distribution system in which two video servers according to the present invention are connected through a transmission path which does not allow IP multicast to pass therethrough.
  • A video content stored in a video storage 102A of a video server 101A can be transmitted simultaneously to client terminals 103A through an IP network 12A using an IP multicast transmission scheme.
  • However, as to client terminals 103B connected to an IP network 12B, IP multicast based transmission cannot be realized from the video server 101A to the client terminal 103B, though connected to the network 12B, because a network connecting the IP network 12A and the IP network 12B has a firewall 104 interposed therebetween and serves as a network dedicated to HTTP.
  • To eliminate this inconvenience, the present invention transmits image information using the HTTP protocol only when the image information is passed through an HTTP network. For example, when an client terminal 103B requests to view a video content stored in the video storage 102A and multicast to the client terminals 103A, the video server 101A transmits image information to the client terminals 103A using the IP multicast, and simultaneously transmits the image information to the video server 101B through the HTTP network 11 using the HTTP protocol.
  • The video server 101B receives the image information transmitted from the video server 101A, and multicasts the image information to the client terminals 103B using the IP multicast.
  • A logical transmission path in accordance with the HTTP protocol between the video servers 101A and 101B is different from a logical transmission path in accordance with the IP multicast between the video server 101B and the client terminals 103B. The video server 101B manages the correspondence for both logical transmission paths and controls transmission/reception of image information.
  • FIG. 2 is a diagram for explaining the operational flow of the video distribution system utilizing the video servers described in connection with FIG. 1. Here, explanation will be given of how a video content stored in a video storage 216 of a video server 101A is viewed on an client terminal 103B.
  • A video server 101B comprises a video management unit 203 and a video delivery unit 205. Image information is stored in a video storage 206, while identification information, attributes and so on for identifying the name and file of particular image information are managed by a video management table 204 which is referenced by the video management unit 203.
  • Similarly, the video server 101A comprises a video management unit 213 and a video delivery unit 215. Image information is stored in a video storage 216, while identification information, attributes and so on for identifying the name and file of particular image information are managed by a video management table 214 which is referenced by the video management unit 213.
  • The video servers 101A, 101B comprise computers equipped with communication functions, and the video management units and the video delivery units are implemented by software programs.
  • (2) Distribution of Video
  • FIG. 3 is a flow chart for explaining the operation of the video distribution system illustrated in FIG. 2.
  • In the following, the operational flow in the video distribution system illustrated in FIG. 2 will be explained along the flow chart of FIG. 3.
  • Assume that the client terminal 103B issues a video audience request 21 to the video management unit 203 in the video server 101B (step S1). In this event, the video management unit 203 references the video management table 204 to determine whether or not the requested video content is stored in the video storage 206 (step S2), and sends a transmission command 23 to the video delivery unit 205 (step S3) when determining that the video content is stored in the video storage 206 (step S2: Y). In this way, the video delivery unit 205 retrieves the requested video content 24 from the video storage 206 for delivery to the client terminal 103B (step S4). In this event, the video delivery unit 205 may also transmit the video content 24 simultaneously to a plurality of other terminals using the IP multicast as is the case with the client terminal 103B.
  • On the other hand, when the requested video content is not stored in the video storage 206 (step S2: N), the video management unit 203 sends an audience request 25 to the video management unit 213 in the other video server 101A (step S5). The video server 101B has a list of other video servers which can be connected thereto. The video management unit 213, upon receipt of the audience request 25, references the video management table 214 to determine whether or not the requested video content is stored in the video storage 216. When stored, the video management unit 213 sends a transmission command 27 to the video delivery unit 215, and sends to the video management unit 203 in the video server 101 B reception parameters 26 required for receiving the video content from the video delivery unit 215, for example, attribute information such as a video format, compression method, rate, and so on (step S6). Transmission/reception of the audience request and parameters between the video servers are performed in accordance with the HTTP protocol (and may be performed in accordance with any other protocol).
  • When the requested video content is not stored in the video storage 216, the video server 101B further sends an audience request to another video server within the list. The video server 101B repeats this operation, and returns an error or the like when the requested video content is not stored in any video server.
  • Turning back to the explanation of the operational flow, the video delivery unit 215, upon receipt of the transmission command 27, uses the HTTP protocol to retrieve image information of interest from the video storage 216 and transmit the retrieved image information to the video delivery unit 205 in the video server 101B in accordance with the transmission command 27 (step S7). Upon receipt of the reception parameters 26, the video management unit 203 sends the transmission command 23 adapted for the parameters 26 to the video delivery unit 205, and transmits to the client terminal 103 B reception parameters 22 which are attribute information of the video content required to receive the video content (step S8).
  • The video delivery unit 205 receives a HTTP-based video content 28 from the video delivery unit 215 in the video server 101A in accordance with the received transmission command 23, and again transmits the video content 28 to the client terminal 103B as image information 24. In this event, the image information received by the video delivery unit 205 is also stored in the video storage 206 for registering its title and so on in the video management table 204 as a cache which is temporary information (step S9).
  • Subsequently, when an audience request for the same video content is again transmitted from an client terminal, the video management unit 203, at this time, can find the requested video storage registered in the video management table 204 as a cache, sends a transmission command 23 to the video delivery unit 205, retrieves the image information 24 stored in the video storage 206, and transmits the image information 24 to the client terminal 103B (steps S3, S4). In this event, since the image information need not be retrieved and transmitted from the video storage 216 in the video server 101A, a large reduction in the transmission cost can be accomplished.
  • FIG. 4 is a diagram illustrating an example of management information stored in the video management tables 204, 214.
  • In FIG. 4, assume that a server 1 is a video server which holds the video management table, and servers 2, 3, . . . are other video servers. The video management table describes perfect information on video contents stored in the server 1. For video contents stored in the other servers 2, 3, . . . , information on video contents once transmitted in the past is described in a cache directory. An audience request for a video content which is not described in the cache directory is queried sequentially to the other servers as mentioned above. Each video content is managed by a video title (for example, “move 1”), attribute information thereof (the type of the video content, initialization parameters for decoding the video content, dimensions of the vertical side 720 and the horizontal side 480, and so on), the location of the file (for example, a file name such as “video A.movie”), and so on.
  • The example of FIG. 4 shows that video contents 3, 4 are recorded in a directory 1 of the server 1; video contents 5, 6 in a directory 2; a directory 4 and a video content 7 in a directory 3; video contents 8, 9, 10 in the directory 4; and video contents 1, 2 directly in the server 1. Also, FIG. 4 shows in the cache directory that video contents 11, 12, 13, 14 have been once transmitted from the servers 2, 3, 4, respectively, and stored in the server 1 as caches.
  • FIG. 6 is a diagram illustrating an exemplary format for the image information in this embodiment.
  • Since image information is often compression encoded using differential information, it is not always the case that a video content can be restored whichever location the information is decoded from. More frequently, the reproduction of a video content can be started only from a particular point. As an example, FIG. 6 illustrates image information which is compressed using MPEG (Moving Picture Experts Group). A video content can be regarded as a sequence of a plurality of still images.
  • A plurality of information pieces for still images forming part of a video content are designated 501A, 502A, 502B, 502C, 501B. When the video content is encoded, differential information between one image and the following image is used for encoding a majority of still images 502A, 502B, 502C within this sequence of still images, so that it is difficult to retrieve and decode only such still images. These still images are referred to as “P frames.”
  • On the other hand, some of the still images such as 501A, 501B are encoded independently of previous and following still images such that the video content can be started from these images. These still images are referred to as “I frames.” If the video content is decoded from the beginning of a header added to the beginning of codes in an I frame, the video content can be correctly decoded. For this reason, this point is referred to as a “random access point.”
  • The video content is further divided into smaller fragments (packets) 503A, 503B, 503C, 503D, 503E, . . . , 503F, 503G, 503H when it is transmitted. Within these packets, the head packet 503A (503G as well) of the packets comprising an I frame image stores a time stamp 505 which describes a relative time at which the information is reproduced in a packet header 504. Packets included between the head packets of two consecutive I frames, for example, packets 503A-503F in FIG. 6 define a minimum unit for reproducing the video content. When packets are stored in a buffer or the like, they are stored in minimum units N (N is a natural number and variable).
  • (3) Transmission of Video Content from Video Server to Terminal
  • FIG. 5 is a block diagram illustrating an exemplary configuration of the video delivery unit.
  • The video delivery unit illustrated in FIG. 5 corresponds to the video delivery unit 205 in the video server 101B previously described with reference to FIG. 2, and shows a specific configuration for delivering HTTP-based image information transmitted from the other video server 101A to the client terminal 103B.
  • As illustrated, the video delivery unit comprises an HTTP reception buffer 401; an HTTP receiver 402; a file writer 403; a video storage 404; a file reader 405; speed adjusting buffers 406A-406C; a buffer controller 407; a transmission controller 408; and a transmission reference time generator 409 for generating a reference time for transmission.
  • In this configuration, image information 28 incoming from another video server (corresponding to the video server 101A in FIG. 2) is temporarily stored in the HTTP reception buffer 401. The HTTP receiver 402 sequentially reads the image information 28 from the HTTP reception buffer 401, examines a packet header to detect a random access point, and stores the image information 28 in the aforementioned minimum units, which allow correct decoding of the video contents, in the speed adjusting buffers 406A, 406B, 406C. While the video delivery unit of this example is provided with three speed adjusting buffers, the same operation principles can be applied if two or more buffers are provided.
  • It is the buffer controller 407 that manages which image information from the HTTP reception buffer 401 should be stored in which speed adjusting buffer. The buffer controller 407 instructs the HTTP receiver 402 to select the buffer which is not currently used for transmission and into which the preceding image information was written least recently, and to perform a write into the selected buffer. In other words, the three speed adjusting buffers are equally used in order except for that actually in use for transmission.
  • The transmission controller 408 reads a video content from one of the speed adjusting buffers 406A, 406B, 406C and transmits it to the client terminal as image information 24. In this event, it is again the buffer controller 407 that determines from which speed adjusting buffer the image information is read. The buffer controller 407 selects in order such buffers that are not currently being written and from which the contents have not been read.
  • The transmission controller 408 reads a time stamp of the image information read from the selected speed adjusting buffer, and compares the time stamp with the reference time 42 received from the transmission reference time generator 409. When the time stamp value is equal to or smaller than the reference time 42, the image information 24 is sent to the terminal through the IP multicast. Once the transmission is completed, the transmission controller 408 dequeues the image information in the buffer. On the other hand, when the time stamp value is larger than the reference time, the transmission controller 408 discards the image information rather than transmitting it to the terminal, and also dequeues the image information from the buffer. In other words, the video controller 408 discards image information exceeding the transmission capability in order to prevent a delay from occurring in course of transmission/reception.
  • The image information received by the HTTP receiver 402 is sent not only to the speed adjusting buffers but also to the file writer 403 for storage in the video storage 206. Also, when an audience request is sent for image information which has been stored in the video storage 206, the file reader 405, instead of the HTTP receiver 402, reads the requested image information from the video storage 206 and stores it in the speed adjusting buffers 405A, 406B, 406C.
  • FIG. 7 is a diagram for explaining an example of extended functions for the video delivery unit of the present invention.
  • In FIG. 7, an HTTP reception buffer 401, an HTTP receiver 402, a file writer 403, a video storage 206, a file reader 405, speed adjusting buffers 406A, 406B, 406C, a buffer controller 407 operate in the same manner as their respective counterparts in FIG. 5. A multicast transmitter 408 operates in the same manner as the transmission controller 408 in FIG. 5.
  • The embodiment of FIG. 7 includes a transmission function, added to the embodiment of FIG. 5, for transmitting image information to a plurality of client terminals in accordance with the HTTP protocol. Since the HTTP protocol is essentially intended for point-to-point communications, it is not suitable for transmitting the same information simultaneously to a plurality of terminals.
  • Therefore, this embodiment separately provides HTTP transmission controllers corresponding to a terminal A 603A and a terminal B 603B, respectively. An HTTP transmission controller 601A is responsible for transmission to the terminal A 603A, and has a buffer 602A for temporarily storing information to be transmitted. Similarly, an HTTP transmission controller 601B is responsible for transmission to the terminal B 603B, and has a buffer 602B for temporarily storing information to be transmitted. A similar configuration may be applied for transmitting image information to three or more terminals.
  • In FIG. 7, the terminal A 603A first transmits a video transmission request 64A in sequence to the HTTP transmission controller 601A. The HTTP transmission controller 601A, upon receipt of the video transmission request 64A, reads information from the buffer 602A for transmission to the terminal A 603A as image information 63A. As the buffer 602A has a free space, the HTTP transmission controller 601A reads image information to be next transmitted from one of the speed adjusting buffers 406A, 406B, 406C, and stores the read image information in the buffer 602A. In this event, it is the buffer controller 407 that determines from which speed adjusting buffer image information is read, as is the case of FIG. 5.
  • The buffer controller 407 selects a speed adjusting buffer which stores the most recent image information that has not been transmitted to the terminal A 603A, and into which image information is not being written. The buffer controller 407 selects a like speed adjusting buffer for the terminal B 603B. Subsequently, at the time the multicast transmission controller 408 has read and transmitted the contents (image information) of the buffer, the contents of the buffer are deleted.
  • The HTTP transmission controllers 601A, 601B have the same transmission reference time generator as that designated by 409 in FIG. 5, and transmits image information in the buffers 602A, 602B to a terminal such that no delay occurs.
  • FIG. 8 is a diagram for explaining an exemplary video transmission method between a video server and a terminal according to the HTTP protocol.
  • In this example, one or more HTTP communications are simultaneously performed for improving the utilization efficiency of transmission paths. Specifically, N (N>2) logical transmission paths are established between a video server and a terminal for use in sending a video content.
  • Generally, the HTTP protocol involves a procedure in which the transmission side responds to a transmission request from the reception side, so that a transmission path is left unused until a response is returned from the transmission side after the transmission request has been sent from the reception side, thereby causing a lower efficiency. To solve this problem, this embodiment enables a plurality of transmission requests to be issued to a server even for a period from the time the first request has been issued to the time a response is returned.
  • A video content from a image information source 701 is stored in the speed adjusting buffers 702A, 702B, 702C, in a manner similar to the embodiment of FIG. 5. The video content stored in the speed adjusting buffers 702A, 702B, 702C is overwritten or erased from the oldest one irrespective of whether it has been transmitted or not. A selector 703 selects, in response to a request from a transmitter associated with each terminal, selects a speed adjusting buffer which stores the most recent video content and into which a write is not being executed, from among the speed adjusting buffers 702A, 702B, 702C, and sends the contents of the selected speed adjusting buffer to the transmitter.
  • A transmitter is provided in correspondence to each reception side for responding to requests from a plurality of transmission sides. For example, a transmitter 704A is provided for a receiver 708A of a terminal A, and a transmitter 704B is provided for a receiver 708B of a terminal B. The transmitter 704A for the terminal A and the receiver 708A of the terminal A are connected over a transmission path 707 through a plurality of independent logical transmission paths in accordance with the HTTP protocol. In this example, three HTTP protocol connections are used. The transmitter 704B for the terminal B and the receiver 708B of the terminal B are also connected in a similar manner.
  • An HTTP reception controller 709A provided in the receiver 708A of the terminal A transmits a transmission request 71 to the transmitter 705A for the terminal A. As a response to the request, a video content 72 is transmitted from the HTTP transmitter 705A to the HTTP reception controller 709A. Similarly, an HTTP reception controller 709B receives a video content from an HTTP transmission controller 705B, and an HTTP reception controller 709C receives a video content from the HTTP transmission controller 705C.
  • Each of the HTTP reception controllers 709A, 709B, 709C in the terminal A transmits the next transmission request 71 to the HTTP transmission controller 705A, 705B, 705C associated therewith immediately after it has received the video content. The HTTP transmission controllers 705A, 705B, 705C, upon receipt of the transmission request 71 from the HTTP reception controllers 709A, 709B, 709C associated therewith, each refers to the contents of a transmitted time stamp memory 706 to compare a time stamp of image information of the most recent video fragment transmitted to the terminal A with time stamps of image information stored in the speed adjusting buffers 702A, 702B, 702C. Only when the speed adjusting buffers 702A, 702B or 702C store image information having more recent time stamps than the time stamp of the transmitted video content, a selector 703 selects the most recent video fragment stored in the speed adjusting buffer 702A, 702B or 702C for transmission.
  • The time stamp of the transmitted image information is stored in the transmitted time stamp memory 706. When the speed adjusting buffers 702A, 702B, 702C do not store image information having a time stamp more recent than the stored time stamp, the transmission is delayed until recent image information is written into the speed adjusting buffers 702A, 702B, 702C.
  • The respective HTTP reception controllers 709A, 709B, 709C transmit, independently of one another, transmission requests 71 to the HTTP transmission controllers 705A, 705B, 705C associated therewith. Each time the HTTP transmission controllers 705A, 705B, 705C receive the transmission request 71, they merely transmit back the most recent image information at that time as image information 72. Therefore, the image information transmitted back to the HTTP reception controllers 709A, 709B, 709C does not always reach in order. Further, the HTTP reception controllers 709A, 709B, 709C may fail to receive image information due to communication failures or the like.
  • For the reason set forth above, the image information received at the HTTP reception controllers 709A, 709B, 709C must be sent to a decoder 712A after it is rearranged in correct order. A selector 711 compares a time stamp stored in a decoded time stamp memory 710 with time stamps of the image information which has reached the HTTP reception controllers 709A, 709B, 709C to select the HTTP reception controller which stores the least recent image information except for already decoded image information, and sends the image information stored therein to the decoder 712A.
  • After the image information is sent to the decoder 712A, the associated HTTP reception controller again sends a transmission request 71 to the HTTP transmission controller. A time stamp of the image information sent to the decoder 712A is stored in the decoded time stamp memory 710. If image information previous to the decoded time stamp reaches any of the HTTP reception controllers 709A, 709B, 709C, the HTTP reception controller stops receiving the image information at that time, discards the image information which has been received, and immediately sends the next transmission request 71.
  • The operations in the transmitter 704B for the terminal B, the receiver 708B for the terminal B, and a decoder 712B are similar to the foregoing.
  • As described above, the HTTP protocol based video transmission method using a plurality of logical transmission paths can be applied to video transmission/reception between video servers.

Claims (6)

1. A video server which converts digitized video information into a form according to Hyper-Text Transfer Protocol (HTTP) before the digitized image information is transmitted via a transmission path which does not allow multicast using Internet Protocol to pass therethrough and converts the digitized video information into a form according to multicast to send the video information to a plurality of terminals in parallel using Internet Protocol, comprising:
detecting means for detecting whether video information requested by the terminal is stored in the video server or not;
requesting means for requesting another video server to transmit the video information requested by the terminal to the video server according to HTTP when the requested video information is not stored in the video server; and
transmitting means for receiving the video information from the another video server according to HTTP and transmitting the received video information to the plurality of terminals in parallel using multicast or HTTP,
wherein the transmitting means stores fragments of the video information in form of packets, receives a transmission request from each of the terminals according to HTTP, and transmits the recent packet which has not been transmitted yet to each of the terminals in response to the received transmission request.
2. The video server according to claim 1, wherein the transmitting means includes a plurality of memory devices and selecting means,
wherein the transmitting means detects random access points in the video information to be transmitted and extracts the video information pieces between two successive random access points to store the extracted video information pieces into the plurality of memory devices, the random access point being a point from which the video information can be correctly decoded,
wherein the selecting means selects one of the plurality of memory devices which stores the recent video information piece which has not transmitted yet in response to the transmission request issued by a receiving side according to HTTP, and
wherein the video information piece in the selected memory device is transmitted to the receiving side according to HTTP.
3. The video server in accordance with claim 1, wherein the transmitting means includes cache means for storing the video information received from the another video server according to HTTP, and
wherein the transmitting means transmits the video information stored in the cache means when the video information requested by the terminal is stored in the cache means.
4. A method of transmitting video information to terminals by a video server which is connected to another video server via a transmission path which does not allow Internet Protocol (IP) multicast to pass therethrough, comprising the steps of:
detecting whether video information requested by a terminal is stored in the video server or not;
requesting the another video server to transmit the video information requested by the terminal to the video server according to HTTP when the requested video information is not stored in the video server;
receiving the video information from the another video server according to HTTP to store fragments of the received video information in form of packets; and
transmitting the received video information to one or more terminals in parallel using IP multicast or HTTP,
wherein the recent packet which has not been transmitted yet is transmitted to each of the terminals in response to a transmission request from each of the terminals according to HTTP.
5. The video information transmitting method according to claim 4, further comprising the steps of:
detecting random access points in the video information to be transmitted and extracting the video information pieces between two successive random access points to store the extracted video information pieces into a plurality of buffers, the random access point being a point from which the video information can be correctly decoded;
selecting one of the plurality of buffers which stores the recent video information piece which has not transmitted yet in response to the transmission request issued by the terminal according to HTTP, and
transmitting the video information piece in the selected buffer to the terminal according to HTTP.
6. The video information transmitting method according to claim 4, further comprising the steps of:
storing the video information received from the another video server according to HTTP in a cache, and
transmitting the video information stored in the cache when the video information requested by the terminal is stored in the cache.
US12/263,559 2000-02-24 2008-11-03 Video server for video distribution system Abandoned US20090070843A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US12/263,559 US20090070843A1 (en) 2000-02-24 2008-11-03 Video server for video distribution system

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
JP2000046997A JP3793941B2 (en) 2000-02-24 2000-02-24 Video server device and video delivery method thereof in video delivery system
JP2000-046997 2000-02-24
US09/739,691 US7069332B2 (en) 2000-02-24 2000-12-20 Video server for video distribution system
US11/406,394 US7467221B2 (en) 2000-02-24 2006-04-19 Video server for video distribution system
US12/263,559 US20090070843A1 (en) 2000-02-24 2008-11-03 Video server for video distribution system

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US11/406,394 Continuation US7467221B2 (en) 2000-02-24 2006-04-19 Video server for video distribution system

Publications (1)

Publication Number Publication Date
US20090070843A1 true US20090070843A1 (en) 2009-03-12

Family

ID=18569321

Family Applications (3)

Application Number Title Priority Date Filing Date
US09/739,691 Expired - Fee Related US7069332B2 (en) 2000-02-24 2000-12-20 Video server for video distribution system
US11/406,394 Expired - Fee Related US7467221B2 (en) 2000-02-24 2006-04-19 Video server for video distribution system
US12/263,559 Abandoned US20090070843A1 (en) 2000-02-24 2008-11-03 Video server for video distribution system

Family Applications Before (2)

Application Number Title Priority Date Filing Date
US09/739,691 Expired - Fee Related US7069332B2 (en) 2000-02-24 2000-12-20 Video server for video distribution system
US11/406,394 Expired - Fee Related US7467221B2 (en) 2000-02-24 2006-04-19 Video server for video distribution system

Country Status (2)

Country Link
US (3) US7069332B2 (en)
JP (1) JP3793941B2 (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100306401A1 (en) * 2009-05-29 2010-12-02 Comcast Cable Communications, Llc Switched Multicast Video Streaming
US8355450B1 (en) * 2007-10-09 2013-01-15 Arris Solutions, Inc. Buffer delay reduction

Families Citing this family (64)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8151306B2 (en) * 2000-01-14 2012-04-03 Terayon Communication Systems, Inc. Remote control for wireless control of system including home gateway and headend, either or both of which have digital video recording functionality
JP4035806B2 (en) * 2000-01-31 2008-01-23 株式会社日立製作所 Video distribution system
JP3793941B2 (en) * 2000-02-24 2006-07-05 株式会社日立製作所 Video server device and video delivery method thereof in video delivery system
US6629193B1 (en) * 2000-10-24 2003-09-30 Hewlett-Packard Development Company, L.P. Solid-state information storage device
US7257639B1 (en) * 2001-01-19 2007-08-14 Microsoft Corporation Enhanced email—distributed attachment storage
FI115744B (en) * 2001-02-08 2005-06-30 Nokia Corp communication Service
US8117313B2 (en) * 2001-03-19 2012-02-14 International Business Machines Corporation System and method for adaptive formatting of image information for efficient delivery and presentation
MXPA04001463A (en) * 2001-08-16 2005-04-29 Trans World New York Llc User-personalized media sampling, recommendation and purchasing system using real-time inventory database.
FI115684B (en) * 2001-10-19 2005-06-15 Swelcom Oy System and method for combining a video stream with digital information
US20030079016A1 (en) * 2001-10-23 2003-04-24 Sheng (Ted) Tai Tsao Using NAS appliance to build a non-conventional distributed video server
SE524989C2 (en) * 2002-05-08 2004-11-09 Marratech Ab Device and method for distributing flowing real-time information between clients
TWI265697B (en) * 2002-06-06 2006-11-01 Ibm Digital contents distribution system, digital contents distribution method, computer readable recording medium storing the program therein, and server and client therefor
KR101052826B1 (en) * 2002-09-05 2011-07-29 톰슨 라이센싱 System and method for providing programming in a multi-dwelling unit or multi-tenant unit network
DE602004003025T2 (en) * 2003-01-16 2007-05-24 Sony United Kingdom Ltd., Brooklands VIDEO / AUDIO NETWORK
US20050010961A1 (en) * 2003-06-02 2005-01-13 Hagen David A. System for providing live and pre-recorded audio-video content to a plurality of portals over the Internet
US20050030892A1 (en) * 2003-06-23 2005-02-10 Hagen David A. System for providing network load distribution
CA2475808A1 (en) * 2003-07-29 2005-01-29 Thomas M. Thorsteinson Pcr timing control in variable bit rate (vbr) transport streams
US20050044333A1 (en) * 2003-08-19 2005-02-24 Browning James V. Solid-state information storage device
US8214256B2 (en) * 2003-09-15 2012-07-03 Time Warner Cable Inc. System and method for advertisement delivery within a video time shifting architecture
US20050070277A1 (en) * 2003-09-30 2005-03-31 Teck Hu Method of initiating multimedia broadcast multicast services
JP4439880B2 (en) * 2003-11-13 2010-03-24 パナソニック株式会社 Content distribution system, content server, content receiving device, content distribution method, recording medium, and program
US8104065B2 (en) * 2003-11-13 2012-01-24 Arris Group, Inc. System to provide markers to affect rendering and navigation of content on demand
KR100470398B1 (en) * 2004-02-07 2005-02-05 가온미디어 주식회사 Digital Convergent Recorder Device
US7836472B2 (en) * 2004-05-27 2010-11-16 Thales Avionics, Inc. System and method for loading content in an in-flight entertainment system
US8230096B2 (en) 2005-01-14 2012-07-24 Citrix Systems, Inc. Methods and systems for generating playback instructions for playback of a recorded computer session
US7996549B2 (en) * 2005-01-14 2011-08-09 Citrix Systems, Inc. Methods and systems for recording and real-time playback of presentation layer protocol data
US7831728B2 (en) * 2005-01-14 2010-11-09 Citrix Systems, Inc. Methods and systems for real-time seeking during real-time playback of a presentation layer protocol data stream
US8935316B2 (en) * 2005-01-14 2015-01-13 Citrix Systems, Inc. Methods and systems for in-session playback on a local machine of remotely-stored and real time presentation layer protocol data
US8340130B2 (en) 2005-01-14 2012-12-25 Citrix Systems, Inc. Methods and systems for generating playback instructions for rendering of a recorded computer session
US8200828B2 (en) 2005-01-14 2012-06-12 Citrix Systems, Inc. Systems and methods for single stack shadowing
US8296441B2 (en) 2005-01-14 2012-10-23 Citrix Systems, Inc. Methods and systems for joining a real-time session of presentation layer protocol data
US20060159432A1 (en) 2005-01-14 2006-07-20 Citrix Systems, Inc. System and methods for automatic time-warped playback in rendering a recorded computer session
US20060161671A1 (en) * 2005-01-14 2006-07-20 Citrix Systems, Inc. Method and systems for capture and replay of remote presentation protocol data
US8145777B2 (en) 2005-01-14 2012-03-27 Citrix Systems, Inc. Method and system for real-time seeking during playback of remote presentation protocols
US8364792B2 (en) * 2005-03-09 2013-01-29 Vudu, Inc. Method and system for distributing restricted media to consumers
US8191008B2 (en) 2005-10-03 2012-05-29 Citrix Systems, Inc. Simulating multi-monitor functionality in a single monitor environment
US8179891B2 (en) * 2006-01-25 2012-05-15 Vectormax Corporation Method and apparatus for interdomain multicast routing
US7900060B2 (en) * 2006-02-17 2011-03-01 Vudu, Inc. Method and system for securing a disk key
US8239686B1 (en) 2006-04-27 2012-08-07 Vudu, Inc. Method and system for protecting against the execution of unauthorized software
US7904575B2 (en) * 2006-08-25 2011-03-08 Samsung Electronics Co., Ltd. Apparatus and method for matching protocols of embedded audio/video contents
US8179872B2 (en) * 2007-05-09 2012-05-15 Research In Motion Limited Wireless router system and method
US8285818B2 (en) * 2007-06-08 2012-10-09 At&T Intellectual Property I, L.P. System and method of recording and accessing multimedia data
GB2454001A (en) * 2007-10-25 2009-04-29 Vantage Diagnostics Ltd Digital image selection according to predefined policy
KR101591706B1 (en) * 2008-06-04 2016-02-18 삼성전자주식회사 Method and apparatus for transmittingreceiving filtered content based on age limit
US8589992B2 (en) * 2010-05-27 2013-11-19 Istreamplanet Co. Video workflow automation platform for publishing a video feed in multiple formats
US8918820B2 (en) * 2010-05-27 2014-12-23 Istreamplanet Co. Video workflow automation platform
JP6039915B2 (en) * 2011-07-08 2016-12-07 株式会社ドワンゴ Stage presentation system, presentation control subsystem, operation method of stage presentation system, operation method of presentation control subsystem, and program
US8615159B2 (en) 2011-09-20 2013-12-24 Citrix Systems, Inc. Methods and systems for cataloging text in a recorded session
US8904447B1 (en) 2011-09-23 2014-12-02 Google Inc. Video campaign automatic configuration
US9467369B2 (en) 2013-08-02 2016-10-11 Time Warner Cable Enterprises Llc Packetized content delivery apparatus and methods
CN103686447B (en) * 2013-12-20 2017-12-08 广东威创视讯科技股份有限公司 Video transmission method and system
US9912707B2 (en) 2014-07-31 2018-03-06 Istreamplanet Co. Method and system for ensuring reliability of unicast video streaming at a video streaming platform
US9826011B2 (en) 2014-07-31 2017-11-21 Istreamplanet Co. Method and system for coordinating stream processing at a video streaming platform
US9417921B2 (en) 2014-07-31 2016-08-16 Istreamplanet Co. Method and system for a graph based video streaming platform
US9407944B1 (en) 2015-05-08 2016-08-02 Istreamplanet Co. Resource allocation optimization for cloud-based video processing
US9344751B1 (en) 2015-05-08 2016-05-17 Istreamplanet Co. Coordination of fault-tolerant video stream processing in cloud-based video streaming system
US9686576B2 (en) 2015-05-08 2017-06-20 Istreamplanet Co. Coordination of video stream timing in cloud-based video streaming system
US10164853B2 (en) 2015-05-29 2018-12-25 Istreamplanet Co., Llc Real-time anomaly mitigation in a cloud-based video streaming system
US9743151B2 (en) * 2015-06-24 2017-08-22 Time Warner Cable Enterprises Llc Multicast video program switching architecture
JP7021842B2 (en) * 2015-11-13 2022-02-17 パナソニック ネットソリューションズ株式会社 Video distribution system and video distribution method
US10341379B2 (en) 2016-02-12 2019-07-02 Time Warner Cable Enterprises Llc Apparatus and methods for mitigation of network attacks via dynamic re-routing
DE102017130980A1 (en) * 2017-12-21 2019-06-27 Schölly Fiberoptic GmbH Image transfer arrangement and method for image transfer
US11070603B2 (en) 2018-02-26 2021-07-20 Charter Communicatons Operating, LLC Apparatus and methods for packetized content routing and delivery
US10887647B2 (en) 2019-04-24 2021-01-05 Charter Communications Operating, Llc Apparatus and methods for personalized content synchronization and delivery in a content distribution network

Citations (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US25378A (en) * 1859-09-13 Andrew f
US49977A (en) * 1865-09-19 Improved washing compound
US195602A (en) * 1877-09-25 Improvement in show-stands for exhibiting garments
US5550807A (en) * 1994-03-04 1996-08-27 Fujitsu Limited Method of measuring distance between equipments on lan and distance measuring apparatus
US5583995A (en) * 1995-01-30 1996-12-10 Mrj, Inc. Apparatus and method for data storage and retrieval using bandwidth allocation
US6014694A (en) * 1997-06-26 2000-01-11 Citrix Systems, Inc. System for adaptive video/audio transport over a network
US6088721A (en) * 1998-10-20 2000-07-11 Lucent Technologies, Inc. Efficient unified replication and caching protocol
US6304904B1 (en) * 1997-03-27 2001-10-16 Intel Corporation Method and apparatus for collecting page-level performance statistics from a network device
US6356947B1 (en) * 1998-02-20 2002-03-12 Alcatel Data delivery system
US6658476B1 (en) * 1999-11-29 2003-12-02 Microsoft Corporation Client-server protocol support list for standard request-response protocols
US6714549B1 (en) * 1998-12-23 2004-03-30 Worldcom, Inc. High resiliency network infrastructure
US6760749B1 (en) * 2000-05-10 2004-07-06 Polycom, Inc. Interactive conference content distribution device and methods of use thereof
US7069332B2 (en) * 2000-02-24 2006-06-27 Hitachi, Ltd. Video server for video distribution system
US7159233B2 (en) * 2000-01-28 2007-01-02 Sedna Patent Services, Llc Method and apparatus for preprocessing and postprocessing content in an interactive information distribution system
US7343618B2 (en) * 2000-01-31 2008-03-11 Hitachi, Ltd. Video content transmitting system and method

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH09282247A (en) 1996-04-10 1997-10-31 Hitachi Ltd Method for distributing multimedia data
TW400487B (en) 1996-10-24 2000-08-01 Tumbleweed Software Corp Electronic document delivery system
US6978306B2 (en) * 2000-08-10 2005-12-20 Pts Corporation Multi-tier video delivery network

Patent Citations (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US49977A (en) * 1865-09-19 Improved washing compound
US195602A (en) * 1877-09-25 Improvement in show-stands for exhibiting garments
US25378A (en) * 1859-09-13 Andrew f
US5550807A (en) * 1994-03-04 1996-08-27 Fujitsu Limited Method of measuring distance between equipments on lan and distance measuring apparatus
US5583995A (en) * 1995-01-30 1996-12-10 Mrj, Inc. Apparatus and method for data storage and retrieval using bandwidth allocation
US6304904B1 (en) * 1997-03-27 2001-10-16 Intel Corporation Method and apparatus for collecting page-level performance statistics from a network device
US6014694A (en) * 1997-06-26 2000-01-11 Citrix Systems, Inc. System for adaptive video/audio transport over a network
US6356947B1 (en) * 1998-02-20 2002-03-12 Alcatel Data delivery system
US6088721A (en) * 1998-10-20 2000-07-11 Lucent Technologies, Inc. Efficient unified replication and caching protocol
US6714549B1 (en) * 1998-12-23 2004-03-30 Worldcom, Inc. High resiliency network infrastructure
US6658476B1 (en) * 1999-11-29 2003-12-02 Microsoft Corporation Client-server protocol support list for standard request-response protocols
US7159233B2 (en) * 2000-01-28 2007-01-02 Sedna Patent Services, Llc Method and apparatus for preprocessing and postprocessing content in an interactive information distribution system
US7343618B2 (en) * 2000-01-31 2008-03-11 Hitachi, Ltd. Video content transmitting system and method
US7069332B2 (en) * 2000-02-24 2006-06-27 Hitachi, Ltd. Video server for video distribution system
US6760749B1 (en) * 2000-05-10 2004-07-06 Polycom, Inc. Interactive conference content distribution device and methods of use thereof

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8355450B1 (en) * 2007-10-09 2013-01-15 Arris Solutions, Inc. Buffer delay reduction
US20100306401A1 (en) * 2009-05-29 2010-12-02 Comcast Cable Communications, Llc Switched Multicast Video Streaming

Also Published As

Publication number Publication date
US20010018772A1 (en) 2001-08-30
US7069332B2 (en) 2006-06-27
US7467221B2 (en) 2008-12-16
JP3793941B2 (en) 2006-07-05
US20060195602A1 (en) 2006-08-31
JP2001237829A (en) 2001-08-31

Similar Documents

Publication Publication Date Title
US7467221B2 (en) Video server for video distribution system
US7124195B2 (en) Broadband network system configured to transport audio or video at the transport layer, and associated method
US7301944B1 (en) Media file distribution with adaptive transmission protocols
US7171485B2 (en) Broadband network system configured to transport audio or video at the transport layer, and associated method
CN109525460B (en) Method and device for monitoring number resources of video network
US20020040404A1 (en) System and method for performing broadcast-enabled disk drive replication in a distributed data delivery network
JP2009512279A (en) Media data processing using different elements for streaming and control processing
US20010034788A1 (en) System and method for receiving packet data multicast in sequential looping fashion
US20030074554A1 (en) Broadband interface unit and associated method
CN110198345B (en) Data request method, system and device and storage medium
CN109788247B (en) Method and device for identifying monitoring instruction
CN110049273B (en) Video networking-based conference recording method and transfer server
KR100240645B1 (en) Packet error controller of multicast communication and method thereof
CN110224988B (en) Image data processing method, system and device and storage medium
CN109905627B (en) Method and device for recording audio and video stream data
CN109698859B (en) Data storage method and device based on video network
JP2008193500A (en) Data transmitter and data repeater
KR100773778B1 (en) Method for controlling server with multicast transmitting and System thereof
Ge et al. Experimental evaluation of error control for video multicast over wireless LANs
CN110620936B (en) Video network video backup method and device, electronic equipment and storage medium
CN111245592B (en) Signaling transmission method and device and computer readable storage medium
CN111147795B (en) Resource scheduling method, server, terminal, electronic device, and storage medium
CN110460811B (en) Multimedia data processing method and system based on video network
CN109327730B (en) Method and device for downloading data packet
CN110691214B (en) Data processing method and device for business object

Legal Events

Date Code Title Description
STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION