|
Claims  |
|
|
We claim:
1. A method for operating a network system having a content provider which
provides content over a network through local service providers to
multiple content rendering units, the method comprising the following
steps:
identifing a peak time when a plurality of the content rendering units are
likely to request the content supplied by the content provider;
sending at least some of the content from the content provider to the local
service provider prior to the peak time; and
storing the content received from the content provider at the local service
provider for use during the peak time.
2. A method as recited in claim 1, wherein the sending step is performed
without being requested by the content rendering units.
3. A method as recited in claim 1, wherein the content comprises streaming
audio or video data.
4. A method as recited in claim 1, further comprising the step of
requesting, by the local service provider, the content based on the
results of the identifying step.
5. A method as recited in claim 1, and further comprising:
monitoring usage patterns of the content;
scheduling early sending of the content at a time prior to the peak time
based on the usage patterns.
6. A method as recited in claim 1, and further comprising the step of
serving the content from the local service provider to requesting content
rendering units during the peak time.
7. A method as recited in claim 1, wherein:
the identifying step comprises designating a peak time in terms of discrete
time slots as covering an ending portion of at least one time slot and a
beginning portion of at least one subsequent time slot; and
the sending step comprises sending the content that is likely to be
requested in the subsequent time slot prior to the peak time.
8. A method as recited in claim 1, and further comprising the following
steps:
customizing a set of prioritized content according to requests made by the
content rendering units; and
selectively sending the set of prioritized content to the local service
provider prior to the peak time.
9. A method as recited in claim 1, and further comprising the step of
assigning a time-to-live tag to the content to indicate when the content
is expected to be updated.
10. A method as recited in claim 1, and Fuhrer comprising the step of
estimating, at the local service provider, a time-to-live tag for the
content received from the content provider to indicate when the content is
expected to be updated.
11. A method as recited in claim 10, wherein the estimating step comprises
deriving the time-to-live tag based upon a time since the content was last
updated.
12. In a network system having a content provider which provides content
over a network through a local service provider to multiple content
rendering units, a method for operating a local service provider
comprising the following steps:
monitoring usage patterns to detect highly requested content;
identifying from the usage patterns a peak time when a plurality of the
content rendering units are likely to request the content;
scheduling delivery of the highly requested content at a scheduled time
prior to the peak time;
receiving the highly requested content from the content provider at the
scheduled time prior to the peak time; and
storing the highly requested content received from the content provider for
use during the peak time.
13. A method as recited in claim 12, wherein the content comprises
streaming audio or video data.
14. A method as recited in claim 12, and further comprising the step of
modifying target specifications, which are used by the local service
provider to reference the content stored at the content provider, to
instead reference the content stored at the local service provider.
15. A method as recited in claim 12, and further comprising the step of
serving the stored content to requesting content rendering units during
the peak time.
16. A method as recited in claim 12, and further comprising the step of
estimating, at the local service provider, a time-to-live tag for the
content received from the content provider to indicate when the content is
expected to be updated.
17. A method as recited in claim 16, wherein the estimating step comprises
deriving the time-to-live tag based upon a time since the content was last
updated.
18. A computer programmed to perform the steps in the method as recited in
claim 16.
19. A method for operating a network system having a content provider which
provides content through a local service provider to multiple content
rendering units, the content being provided from the content provider to
the local service provider over a first network, the method comprising the
following steps:
distributing supplemental content from the content provider to the local
service provider over a second network;
choosing selected portions of the supplemental content to be stored at the
local service provider based upon usage patterns exhibited by the content
rendering units; and
storing the selected portions of the supplemental content received from the
content provider in a cache at the local service provider for use in
serving the content rendering units.
20. A method as recited in claim 19, wherein the supplemental content
comprises streaming audio or video data.
21. A method as recited in claim 19 wherein the second network comprises a
satellite network and the distributing step comprises the step of
broadcasting the supplemental content.
22. A method as recited in claim 19, and further comprising the step of
serving the distributed content from the local service provider to
requesting content rendering units.
23. A method for operating a network system having a content provider which
provides content through a local service provider to multiple content
rendering units, the content being provided from the content provider to
the local service provider over a first network, the method comprising the
following steps:
identifying a peak time when a plurality of the content rendering units are
likely to request the content stored at the content provider;
distributing supplemental content from the content provider to the local
service provider over a second network prior to the peak time; and
storing selected portions of the supplemental content received from the
content provider in a cache at the local service provider for use in
serving the content rendering units.
24. A method for operating a network system having a content provider which
provides content through a local service provider to multiple content
rendering units, the content being provided from the content provider to
the local service provider over a first network, the method comprising the
following steps:
distributing supplemental content from the content provider to the local
service provider over a second network;
storing selected portions of the supplemental content received from the
content provider in a cache at the local service provider for use in
serving the content rendering units; and
assigning a time-to-live tag to the supplemental content to indicate when
the content is expected to be updated.
25. A method for operating a network system having a content provider which
provides content through a local service provider to multiple content
rendering units, the content being provided from the content provider to
the local service provider over a first network, the method comprising the
following steps:
distributing supplemental content from the content provider to the local
service provider over a second network;
storing selected portions of the supplemental content received from the
content provider in a cache at the local service provider for use in
serving the content rendering units; and
estimating, at the local service provider, a time-to-live tag for the
supplemental content received from the content provider to indicate when
the supplemental content is expected to be updated.
26. A method as recited in claim 25, wherein the estimating step comprises
deriving the time-to-live tag based upon a time since the supplemental
content was last updated.
27. A system for providing content to user content rendering units,
comprising:
a content provider having storage for storing the content;
at least one local service provider to facilitate access to the content
stored at the content provider on behalf of the content rendering units;
a distribution network interconnecting the program provider and the local
service provider; and
the local service provider being configured to request certain content from
the content provider prior to a peak time when multiple content rendering
units are likely to request the content and to cache the content received
from the content provider for serving to requesting content rendering
units during the ensuing peak time.
28. A system as recited in claim 27, wherein the local service provider
using target specifications to request the content stored at the content
provider for serving to the content rendering units, the local service
provider modifying the target specifications to reference the content
cached at the local service provider instead of referencing that same
content at the content provider.
29. A system as recited in claim 27, wherein the content provider assigns a
time-to-live tag to the content to indicate when the content is expected
to be updated.
30. A system as recited in claim 27, wherein the local service provider is
configured to estimate a time-to-live tag for the content to indicate when
the content is expected to be updated.
31. A system as recited in claim 27, and further comprising at least one
content rendering unit connected to the local service provider to
facilitate access to the content served by the content provider, the local
service provider serving the content cached locally to the content
rendering unit during the peak time.
32. A system for providing content to user content rendering units,
comprising:
a content provider having storage for storing the content;
at least one local service provider to facilitate access to the content
stored at the content provider on behalf of the content rendering units,
the local service provider using target specifications to request the
content stored at the content provider;
an interactive network interconnecting the content provider and the local
service provider;
a broadcast network;
the content provider being configured to broadcast at least some of the
content over a broadcast network to the local service provider;
the local service provider being configured to cache the broadcasted
content for serving to requesting content rendering units; and
the local service provider being further configured to modify the target
specifications to reference the broadcasted content cached at the local
service provider instead of referencing that same content at the content
provider.
33. A system as recited in claim 32, wherein the broadcast network
comprises a satellite network.
34. A system for providing content to user content rendering units,
comprising:
a content provider having storage for storing the content;
at least one local service provider to facilitate access to the content
stored at the content provider on behalf of the content rendering units;
an interactive network interconnecting the content provider and the local
service provider;
a broadcast network;
the content provider being configured to broadcast at least some of the
content over the broadcast network to the local service provider, the
content provider assigning a time-to-live tag to the broadcasted content
to indicate when the content is expected to be update; and
the local service provider being configured to cache the broadcasted
content for serving to requesting content rendering units.
35. A system for providing content to user content rendering units,
comprising:
a content provider having storage for storing the content;
at least one local service provider to facilitate access to the content
stored at the content provider on behalf of the content rendering units;
an interactive network interconnecting the content provider and the local
service provider;
a broadcast network;
the content provider being configured to broadcast at least some of the
content over the broadcast network to the local service provider; and
the local service provider being configured to cache the broadcasted
content for serving to requesting content rendering units, the local
service provider estimating a time-to-live tag for the broadcasted content
to indicate when the broadcasted content is expected to be updated.
36. A system for providing content to user content rendering units,
comprising:
a content provider having storage for storing the content;
at least one local service provider to facilitate access to the content
stored at the content provider on behalf of the content rendering units;
and
the local service provider being configured to request certain content from
the content provider prior to a peak time when multiple content rendering
units are likely to request the content and to cache the content received
from the content provider for serving to requesting content rendering
units during the ensuing peak time.
37. A system for providing content to user content rendering units,
comprising:
a content provider having storage for storing the content;
at least one local service provider to facilitate access to the content
stored at the content provider on behalf of the content rendering units,
the local service provider using target specifications to request the
content stored at the content provider;
the content provider being configured to broadcast at least some of the
content to the local service provider;
the local service provider being configured to cache the broadcasted
content for serving to requesting content rendering units; and
the local service provider being further configured to modify the target
specifications to reference the broadcasted content cached at the local
service provider instead of referencing that same content at the content
provider.
38. A system for providing content to user content rendering units,
comprising:
a content provider having storage for storing the content;
at least one local service provider to facilitate access to the content
stored at the content provider on behalf of the content rendering units;
the content provider being configured to broadcast at least some of the
content to the local service provider, the content provider assigning a
time-to-live tag to the broadcasted content to indicate when the content
is expected to be updated; and
the local service provider being configured to cache the broadcasted
content for serving to requesting content rendering units.
39. A system for providing content to user content rendering units,
comprising:
a content provider having storage for storing the content;
at least one local service provider to facilitate access to the content
stored at the content provider on behalf of the content rendering units;
the content provider being configured to broadcast at least some of the
content to the local service provider; and
the local service provider being configured to cache the broadcasted
content for serving to requesting content rendering units, the local
service provider estimating a time-to-live tag for the broadcasted content
to indicate when the broadcasted content is expected to be updated. |
|
|
|
|
Claims  |
|
|
Description  |
|
|
TECHNICAL FIELD
This invention relates to network systems, and particularly public network
systems, such as the Internet. More particularly, this invention relates
to methods which improve distribution of streaming continuous data (e.g.,
audio and video data) from a content provider over a network to a
subscriber's computer or other content rendering unit.
BACKGROUND OF THE INVENTION
Public networks, and most notably the Internet, are emerging as a primary
conduit for communications, entertainment, and business services. The
Internet is a network formed by the cooperative interconnection of
computing networks, including local and wide area networks. It
interconnects computers from around the world with existing and even
incompatible technologies by employing common protocols that smoothly
integrate the individual and diverse components.
The Internet has recently been popularized by the overwhelming and rapid
success of the World Wide Web (WWW or Web). The Web is a graphical user
interface to the Internet that facilitates interaction between users and
the Internet. The Web links together various topics in a complex,
non-sequential web of associations which permit a user to browse from one
topic to another, regardless of the presented order of topics. A "Web
browser" is an application which executes on the user's computer to
navigate the Web. The Web browser allows a user to retrieve and render
hypermedia content from the WWW, including text, sound, images, video, and
other data.
One problem facing the continued growth and acceptance of the Internet
concerns dissemination of streaming continuous data, such as video and
audio content. Data is delivered and rendered to users in essentially two
formats. The first format, referred to as "block data," entails
downloading the entire data set to local storage and then rendering the
data from the locally stored copy. A second delivery format, known as
"streaming data," entails sending bits of data continuously over the
network for just-in-time rendering.
Computer network users have been conditioned through their experiences with
television and CD-ROM multimedia applications to expect instantaneous
streaming data on demand. For technical reasons, however, the Internet is
often unable to deliver streaming data. This inability is most pronounced
for video data. In the Internet context there is often long delays between
the time video content is requested and the time when the video content
actually begins playing. It is not uncommon to wait several minutes for a
video file to begin playing. In essence, for factors discussed below,
video data is traditionally delivered as "block data" over the Internet
and thus requires that the entire file be downloaded prior to rendering.
The inability to provide streaming data is a result of too little bandwidth
in the distribution network. "Bandwidth" is the amount of data that can be
moved through a particular network segment at any one time. The Internet
is a conglomerate of different technologies with different associated
bandwidths. Distribution over the Internet is usually constrained by the
segment with the lowest available bandwidth.
FIG. 1 shows a model of a public network system 20, such as the Internet.
The network system 20 includes a content server 22 (e.g., a Web server)
which stores and serves multimedia data over a distribution network 24.
The network system 20 also has regional independent service providers
(ISPs) or point of presence (POP) operators, as represented by ISP 26,
which provide the connectivity to the primary distribution network 24.
Many users, as represented by subcriber computers 28, 30, and 32, are
connected to the ISP 26 to gain access to the Internet.
The ISP 26 is connected to the distribution network 24 with a network
connection 34. In this example illustration, the network connection 34 is
a "T1" connection. "T1" is a unit of bandwidth having a base throughput
speed of approximately 1.5 Mbps (Megabits per second). Another common high
bandwidth connection is a T3 connection, which has a base throughput speed
of approximately 44.7 Mbps. For purposes of explaining the state of the
technology and the practical problems with providing real-time streaming
data over the Internet, it is sufficient to understand that there is also
a limited bandwidth connection between the content server 22 and the
distribution network 24.
The subscriber computers 28, 30, and 32 are connected to their host ISP 26
via a home entry lines, such as telephone or cable lines, and compatible
modems. As examples of commercially available technology, subscriber
computer 28 is connected to ISP 26 over a 14.4K connection 36 which
consists of a standard telephone line and a V.32bis modem to enable a
maximum data rate of 14.4 Kbps (Kilobits per second). Subscriber computer
30 is connected to the ISP 26 with a 28.8K connection 38 (telephone line
and V.34 modem) which supports a data rate of 28.8 Kbps. Subscriber
computer 32 is connected to the ISP 26 with an ISDN connection 40 which is
a special type of telephone line that facilitates data flow in the range
of 128-132 Kbps. Table 1 summarizes connection technologies that are
available today.
TABLE 1
______________________________________
Connection Technologies and Throughput
Connection Type Base Speed (Kbps)
______________________________________
V.32bis modem 14.4
V.34 modem 28.8
56K Leased Line 56
ISDN BRI (1 channel)
56-64
ISDN BRI (2 channels)
128-132
Frame Relay 56-1,544
Fractional T1 256-1,280
ISDN PRI 1,544
Full T1 (24 channels)
1,544
ADSL 2,000-6,000
Cable Modem 27,000
T3 44,736
______________________________________
With a T1 connection to the primary distribution network 24, the ISP 26 can
facilitate a maximum data flow of approximately 1.5 Mbps. This bandwidth
is available to serve all of the subscribers of the ISP. When subscriber
computer 28 is connected and downloading data files, it requires a 14.4
Kbps slice of the 1.5 Mbps bandwidth. Subscriber computers 30 and 32
consume 28.8 Kbps and 128 Kbps slices, respectively, of the available
bandwidth.
The ISP can accommodate simultaneous requests from a number of subscribers.
As more subscribers utilize the ISP services, however, there is less
available bandwidth to satisfy the subscribers requests. If too many
requests are received, the ISP becomes overburdened and may not be able to
adequately service the requests in a timely manner, causing frustration to
the subscribers. If latency problems persist, the ISP can purchase more
bandwidth by adding additional capacity (e.g., upgrading to a T3
connection or adding more T1 connections). Unfortunately, adding more
bandwidth may not be economically wise for the ISP. The load placed on the
ISP typically fluctuates throughout different times of the day. Adding
expensive bandwidth to more readily service short duration high-demand
times may not be profitable if the present capacity adequately services
the subscriber traffic during most of the day.
The latency problems are perhaps the most pronounced when working with
video. There are few things more frustrating to a user than trying to
download video over the Internet. The problem is that video requires large
bandwidth in comparison to text files, graphics, and pictures.
Additionally, unlike still images or text files, video is presented as
moving images which are played continuously without interruption. Video
typically requires a 1.2 Mbps for real-time streaming data. This 1.2 Mbps
throughput requirement consumes nearly all of a T1 bandwidth (1.5 Mbps).
Accordingly, when multiple subscribers are coupled to the ISP and one
subscriber requests a video file, there is generally not enough capacity
to stream the video in real-time from the content server 22 over the
Internet to the requesting subscriber. Instead, the video file is
typically delivered in its entirety and only then played on the subscriber
computer. Unfortunately, even downloading video files in the block data
format is often inconvenient and usually requires an excessive amount of
time.
Consider the following example. Suppose a subscriber wishes to access the
CNN Web site on the Internet for an account of recent news. As part of the
news materials, CNN provides a twenty second video clip of an airplane
hijacking incident. At 1.2 Mbps, the 20 second video clip involves
downloading a 24 Mbyte file over the Internet. If the user has a modest
14.4 Kbps connection, it would take approximately 28 minutes to download
the entire file.
Now, assume that the subscriber/ISP connection is sufficiently large to
handle real-time video streaming of the video file, meaning that the
subscriber computer can render the video data as it is received from the
ISP. Despite the bandwidth of the subscriber/ISP connection, real-time
video streaming may still be unachievable if the T1 connection 34 between
the ISP 26 and the distribution network 24 is unable, or unwilling due to
policy reasons, to dedicate 1.2 Mbps of its bandwidth to the video file.
Requests for the CNN video clip made during peak traffic times at the ISP
most certainly could not be accommodated by the ISP/network connection.
Since adding more bandwidth may be a poor investment for the ISP, the ISP
may have no economic incentive to remedy the latency problem. The result
is that some users might be inconvenienced by the lack of ability to
receive streaming video despite their own connection to the ISP being
capable of accommodating streaming video.
The latency problem is further aggravated if the connection between the
content server 22 and the distribution network 24 is equally taxed. The
lack of sufficient bandwidth at the content server/network link could also
prevent real-time video streaming over the Internet, regardless of the
bandwidths of the network/ISP link or the ISP/subscriber link. If all
links lack sufficient bandwidth, the latency problem can be compounded.
One solution to this problem is to provide local cache storage at the ISP.
As subscribers request files from the Internet, the ISP caches the files
locally so that subsequent requests are handled in a more expeditious
manner. This process is known as "on-demand caching." Local on-demand
caching methods improve the ability to deliver video content over the
Internet. When the first subscriber requests the CNN video clip of the
airplane hijacking incident, the ISP requests the video clip from the CNN
server, and facilitates delivery of the video clip to the requesting
subscriber. The ISP also caches the video clip in its own memory. When any
subsequent subscriber requests the same CNN video clip, the ISP serves the
local version of the video clip from its own cache, rather than requesting
the clip from the CNN server. If the subscriber computer has a high
bandwidth connection with the ISP, the locally stored video clip can be
served as continuous streaming video data for instantaneous rendering on
the subscriber computer.
A drawback of the on-demand caching method is that the first requesting
subscriber is faced with the same latency problems described above. All
subsequent subscribers have the benefit of the cached version. However, if
the initial delay is too long, there may not be any subscriber who is
willing to assume the responsibility of ordering the video file and then
waiting for it to download.
Accordingly, there remains a need to develop improved techniques for
facilitating distribution of streaming video over public networks, such as
the Internet.
SUMMARY OF THE INVENTION
This invention provides improved methods for delivering large amounts of
data, such as streaming audio and video data, over a network, such as the
Internet. According to one aspect, the method involves an intelligent,
pre-caching and pre-loading of frequently requested content to the local
service provider (e.g., ISP or LAN network server) prior to peak demand
times when the content is likely to be requested by the subscribers. In
this maimer, the frequently requested content is already downloaded and
ready to be served to the subscribers before they actually request it.
Where content is finally requested, the data is streamed continuously in
real-time for just-in-time rendering at the subscriber. This eliminates
the latency problems of prior art systems because the subscribers do not
have to wait for the downloading of video and audio files over the.
Internet. Moreover, intelligently pre-caching content before peak demand
times is more effective than traditional on-demand caching because the
content is available to the first subscriber who requests it.
In one implementation, the network system includes a content provider
connected to local service providers via a distribution network. The local
service providers facilitate delivery of the content from the content
provider to multiple subscribers. The local service providers are
configured to request certain content from the content provider prior to a
peak time when the subscribers are likely to request the content. The
content is downloaded from the content provider during non-peak hours and
cached at the local service providers for serving to the subscribers
during the ensuing peak time.
The local service provider includes a processing control unit, a cache
memory, and a continuous media server. A hit recording module executes on
the processing control unit to record requests for particular content from
the subscribers. In the Internet context these requests are submitted in
the form of URLs (universal resource locators) for target resources
located on the Web. A pattern recognizer detects behavior patterns based
on subscriber requests to determine which content the subscribers are most
likely to request and when. A scheduler then schedules requests for the
frequently requested content from the content provider at a selected time
prior to the peak demand time for that content. These requests are posted
to the content provider at their scheduled times, and the content provider
downloads the content during the off-hours prior to the peak time.
When the content is received from the content provider, the local service
provider stores the content in the cache memory. For instance, the content
might be a Web page from a frequently visited Web site. Web pages are
typically designed as hypermedia documents to provide rich multimedia
presentations which blend text, images, sound, and video. If the Web page
references or includes continuous data files, such as audio or video
files, these files are stored in a continuous media server. The target
specifications embedded in the Web page to reference the continuous data
files are modified to reference the local copy of the continuous data
files, as opposed to the original location of the files at the Web site.
During the ensuing peak time, the processing control unit serves the target
resources maintained in the cache memory to the subscribers. If any
subscriber clicks on or otherwise activates a link to an audio or video
file, the requested file is served as a continuous stream of data from the
continuous media server at the ISP. In this manner, the continuous video
or audio data stream can be rendered just-in-time by the subscriber.
Another aspect of this invention involves supplementing the primary
Internet connection owned by the ISP with a delivery of content over a
secondary network. This supplemental delivery effectively increases
bandwidth between the content provider and the local service provider. In
the described implementation, the content provider broadcasts additional
content over a broadcast satellite network to the local service provider.
The broadcast communication link offers additional bandwidth at a fraction
of the cost that would be incurred if the local service provider installed
additional Internet connections, such as T1 or T3 connections. The
broadcasted content is stored at the local service provider and served
during peak times to afford continuous audio streaming to the subscribers.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a diagrammatic illustration of a network system which is used to
explain the present state of Internet technology.
FIG. 2 is a diagrammatic illustration of a network system constructed
according to one implementation of this invention.
FIG. 3 is a diagrammatic illustration of a network system constructed
according to another implementation of this invention.
FIG. 4 is a block diagram of the functional components in a local service
provider in the network system.
FIG. 5 is a flow diagram of a method for operating the local service
provider.
FIG. 6 is a diagrammatic illustration of a network system according to
still another implementation of this invention.
The same reference numbers are used throughout the figures to reference
like components and features.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT
FIG. 2 shows a public network system 50. It includes multiple content
servers, as represented by content server 52, which store and serve
content over a network 54. The content server 52 serves content in the
form of text audio, video, graphic images, and other multimedia data. In
the Internet context, the content servers might represent Web sites which
serve or multicast content in the form of hypermedia documents (e.g., Web
page) which link text, images, sounds, and actions in a web of
associations that permit a user to browse through related topics,
regardless of the presented order of the topics. The content server 52
might alternatively represent headend servers for a cable company which
transmit video content over a cable network, or an audio server for a
radio station that sends audio data over the network. The content server
52 might further represent servers for educational institutions, public
agencies, libraries, merchants, or any other public or private
organizations which serve or multicast information over the network.
The network 54 is a high-speed, high-bandwidth interactive distribution
network, and can be representative of the Internet. Traffic over the
network 54 is organized according to protocols which define how and when
data is moved. One example protocol is the transmission control
protocol/Internet protocol (TCP/IP) which forms the backbone of the
Internet. The network 54 might be implemented using various physical
mediums, including wirebased technologies (e.g., cable, telephone lines,
etc.) and wireless technologies (e.g., satellite, cellular, infrared,
etc.). The network is operated according to high-speed switching services,
including connection-oriented network services (e.g., frame relay,
asynchronous transfer mode (ATM), etc.) and connectionless services (e.g.,
switched multimegabit data service, etc.). These switching services
support connection speeds of several Megabits per second (Mbps), up to
Gigabits per second (Gbps). At these speeds, the network 54 is capable of
supporting streaming video data which requires 1.2 Mbps.
Many independent service providers (ISPs), as represented by ISP 56,
function as terminal connections or "on-ramps" to the high-speed network
54. The ISP 56 acts as an intermediary between the subscribers 58 and 60
and the network 54. The ISP 56 has a network port 62 which provides a
high-speed, high-bandwidth connection 64 to the network 54. The ISPs
segment and rent portions of the bandwidth to the multiple subscribers 58
and 60 so that the subscribers do not individually need to purchase and
maintain their own network connections. The ISPs 56 may also be referred
to as point of presence (POP) servers, and the names "ISP" and "POP" are
used interchangeably in this disclosure.
The subscriber personal computers (PCs) 58 and 60 are individually
connected to the ISP 56 by permanent or sessional dial-up connections.
Conventional telephone or cable lines and compatible modems are used to
form the connections 66, 68. Examples of suitable technologies include
HFC, ISDN, POTS, and ADSL. The ISP 56 has network terminal switching
equipment 70 to accommodate the connections to the subscriber PCs 58, 60.
The ISP 56 also has a cache server 72 and a continuous media server (CMS)
74. The cache server 72 is configured as a conventional database server
having processing capabilities, including a CPU (not shown), and storage
78. As one example, the cache server 72 is implemented as a SQL (Structure
Query Language) database. The cache server 72 caches Internet resources,
such as those requested by subscriber computers 58, 60, that have been
downloaded from the content provider 52 to allow localized serving of
those resources.
The CMS 74 is a server designed particularly for serving continuous data
streams, such as video data and audio data, in an ordered and
uninterrupted manner. As one example implementation, the continuous media
server is configured as a disk array data storage system consisting of
many large capacity storage disks with video and audio data streams stored
digitally thereon. The locations of the video and audio data streams are
kept in a memory map and each video and audio data stream is accessed
through pointers to the particular memory location. To serve the audio or
video data, the processor grabs the pointer to the video stream and begins
retrieving the video from the storage disk 82 and streaming it over the
communication line 66, 68 to the requesting subscriber computing unit.
FIG. 3 shows a network system 90 which is implemented in a local area
network (LAN) configuration. This implementation is exemplary of how a
company or multi-user organization might be connected to the Internet. The
network system 90 differs from the system of FIG. 2 in that the local
service provider which facilitates the on-ramp connection to the
high-speed, high-bandwidth network 54 is itself a local server 92 on a LAN
94. The LAN 94 can be constructed using conventional network topologies,
such as Ethernet. The LAN network server 92 has a network port 96 which
enables a high-speed, high-bandwidth connection 98 to the network 54. The
cache server 72 and CMS 74 are connected to the LAN 94. Workstations or
other computing units 100, 102 are connected to the LAN 94 and are served
by the LAN network server 92 in regards to Internet access. In this
configuration, the LAN users of workstations 100, 102 have access to the
Internet through their enterprise LAN 94 and the LAN network server 92.
It is noted that both implementations of FIGS. 2 and 3 are shown and
described as suitable examples for implementing various aspects of the
invention. However, the network system might be implemented in a variety
of arrangements. In addition, the illustrations show the subscriber units
as being personal computers or work stations. However, the subscriber
units can be implemented in other forms which are capable of rendering
content received over the network. As examples, the subscriber computing
units might include televisions, computers, game devices, handheld
devices, and the like.
As explained in the Background section, conventional techniques for
delivering video and audio content over the Internet is plagued with
latency problems. An aspect of this invention is to provide an improved
method for delivering streaming audio and video content over a network
system. The technique involves an intelligent, pre-caching and preloading
of certain content at the local service provider (e.g., ISP, POP, LAN
network server) prior to optimal or peak demand times when the content is
likely to be requested by the subscribers. In this manner, the frequently
requested content is already downloaded and ready for access from the
subscribers before they actually request it. When it is finally requested,
the data can be streamed continuously in real-time for just-in-time
rendering from the local service provider to the subscriber. This
eliminates the latency problems of prior art systems. Moreover,
intelligently pre-caching content before peak demand times is more
effective than traditional on-demand caching because the content is
available to the first subscriber who requests it.
FIG. 4 shows a functional block diagram of a local service provider 110
according to one implementation which enables intelligent pre-caching and
pre-loading. At its most fundamental level the local service provider 110
provides an on-ramp connection to the Internet for its subscribers. The
subscribers send requests to the local service provider 110 for content
available on the Internet. The local service provider acts as an
intermediary facilitator which communicates the requests to the
appropriate content server and then returns the requested content to the
appropriate subscribers.
The local service provider 110 has a request handler 111 which manages
requests received from the subscribers. In the Web context, the subscriber
computers run Web browser applications which generate requests in the form
of universal resource locators (URLs). A URL describes everything about a
particular resource that a Web browser needs to know to request and render
it. The URL describes the protocol a browser should use to retrieve the
resource, the name of the computer it is on, and the path and file name of
the resource. The following is an example of a URL:
http:/ /www.microsoft.com/upgrades
The "http://" portion of the URL describes the protocol. The letters "http"
stand for HyperText Transfer Protocol, the set of rules that a browser
will follow to request a document and the remote server will follow to
supply the document. The "www.microsoft.com" portion of the URL is the
name of the remote host computer which maintains the document. The last
portion "/upgrades" is the path and file name of the document on the
remote host computer.
When the request handler 111 receives a request, the local service provider
110 first looks to its own cache memory 124 to determine if a proxy copy
of the target resource referenced by the URL is stored locally. The cache
memory 124 serves as a quasi-temporary local storage for holding proxy
copies of often used and requested target resources. The cache memory 124
can be implemented using different types of memory, including RAM storage
disks (optical magnetic, etc.), and the like. If a proxy copy is stored in
the cache memory 124, the target resource is served locally from the cache
memory 124. If there is no proxy copy, the local service provider 110 uses
the URL request to locate the target resource from a content provider and
to request delivery of the target resource over the Internet. The local
service provider 110 passes the target resources on to the requesting
subscriber and may also cache the target resource in the cache 124 if the
policy rules governing the cache are met.
The local service provider 110 has a hit recorder 112 which is coupled to
receive the URLs submitted by the subscribers. For each URL, the hit
recorder 112 records hit information in a URL hit database 114. The hit
information includes the date/time of the request, the subscriber who made
the request, and other information. The hit recorder 112 also triggers a
pattern recognizer 116 which draws on information in the URL hit database
114 to detect repetitive access behavior patterns based on subscriber
requests. The pattern recognizer 116 performs statistical analyses using
hit data from the URL hit database to determine usage patterns that help
the local service provider be more responsive to the needs of its
clientele. For instance, in the preferred implementation, the pattern
recognizer 116 determines which URLs, and hence which Internet resources,
are being requested most often and least often, and the time of day when
the most requests are received. The pattern recognizer 116 is also
responsive to operator input to allow adjustment or tuning by the operator
for specialized analysis.
A scheduler 118 uses the pattern results generated by the pattern
recognizer 116 to schedule requests for specific URLs of target resources
on the Internet. The requests are scheduled to be filled at pre-selected
times prior to the peak times when the highest number of users are most
likely to request the content found at the URLs. Administrative tools 120
permit the operator to configure various operating parameters.
The pattern recognizer 116 and scheduler 118 cooperate to enable
intelligent pre-caching of frequently requested content. The operation of
the local service provider 110 to perform this intelligent pre-caching
according to an aspect of this invention is described in conjunction with
reference to the flow diagram of FIG. 5. The local service provider is
programmed to perform the computer-implemented steps of FIG. 5 to
alleviate the problems of providing streaming video and audio data over
the Internet. The steps are presented in the illustrated order for
discussion purposes, but are not restricted to this sequence.
The pattern recognizer 116 monitors the patterns of the subscriber requests
to determine which content is most frequently requested and when (step 150
in FIG. 5). From these patterns, the pattern recognizer 116 can identify
peak times in subscriber traffic and the relation of the peak times to
specific requested content (step 152). For instance, suppose that a high
number of subscribers frequently request the CNN Web page during the
morning hours of 6:30 AM to 8:00 AM. These requests translate into a high
number of URL hits for the CNN Web page which are recorded by hit recorder
112 in the URL hit database 114. The pattern recognizer 116 recognizes
this recurring pattern of requests for the CNN Web page and identifies the
peak time for this Web page to be between 6:30 AM | | |