METERED CONTENT DELIVERY
TECHNICAL FIELD
The present invention is directed to the field of computer networks, and more particularly, to the field of delivering data using a computer network.
BACKGROUND OF THE INVENTION
The term "multimedia" refers to various different presentation formats that have been developed for presenting data to users of computer systems. These include graphics, audio, and video. Because audio and video are played, or "rendered," over a period of time, instances of these forms of multimedia are called "multimedia sequences." In order to support rendering over a period of time, multimedia sequences are often time-indexed.
While multimedia sequences may be physically delivered on removable media such as CD ROMs and DVDs, they may also be delivered via a network such as the Internet. Where delivered via a network, the data making up a multimedia sequence is transmitted over the network from a server computer system to a client computer system. The data received in the client computer system is used by the client computer system to render the sequence for the benefit of one or more users. Initially, multimedia sequences were delivered to the client computer system in their entirety before being rendered. This approach to delivering multimedia sequences, called "pre-rendering delivery," has been largely superseded by an approach called "streaming delivery." In streaming delivery, the data of the multimedia sequence is transmitted to the client in a form that permits the client to begin rendering the sequence almost
immediately. While rendering proceeds, data for additional portions of the sequence, which are to be rendered after the portion of the sequence presently being rendered, is transmitted to the client.
Streaming delivery has several advantages over pre-rendering delivery. First, for dense media such as video, pre-rendering delivery of even a sequence of moderate length can impose a wait time of many minutes before rendering can begin, while rendering can often begin within seconds using streaming delivery. Also, streaming delivery is much better suited to live sequences, which typically do not have a fixed length, and whose data is often not all available when downloading commences. In a related vein, streaming delivery is also much better suited to live sequences in that it permits live sequences to be rendered in near real time, thus reinforcing their "up to the minute" nature. Further, since streaming delivery permits users to in essence preview a sequence, it enables users to quickly cancel the delivery of unwanted sequences.
Streaming delivery has rigorous bandwidth requirements. While streaming delivery can be configured to use a larger data rate for clients having high-speed connections to their servers, modern streaming delivery systems for audio sequences generally rely on transmitting data at a rate of about 10-15 kilobits/second (kbps) to the client computer system. Because streaming delivery schemes commonly utilize protocols that provide delivery verification such as TCP, streaming may consume an even greater data rate where packets containing streaming data are lost during their initial delivery and must be retransmitted. In order to effectively render a streaming multimedia sequence at the client computer system, it is necessary for adequate bandwidth to be consistently available from the server computer system to the client computer system to transmit the data representing the sequence at the required data rate. Unfortunately, because many client computer systems are connected to server computer systems via the Internet, and connected to the Internet via a 28.8 kbps
modem, this leaves only about 10-15 kbps of additional bandwidth for other
Internet applications. When other Internet applications, such as web browsing, file downloading, or email retrieval, consume more than this 10-15 kbps bandwidth "remainder" during streaming delivery, the required bandwidth for streaming delivery is no longer available, and the quality of the rendered multimedia sequence can suffer substantially. Indeed, rendering of the multimedia sequence may even be interrupted or terminated. While modern stre-irning delivery systems typically buffer an amount of data corresponding to a few seconds of the sequence, this buffering usually only enables rendering to continue uninterrupted during brief periods when significant portions of the bandwidth to the client computer system is consumed by other Internet applications.
In view of the rigorous bandwidth requirements of streaming delivery discussed above, and in view of the limited bandwidth available to many client computer systems on the Internet, a system for controlling the bandwidth used to transmit other types of data to the client computer system to reserve adequate bandwidth for the transmission of streaming media data would have sigmficant utility.
BRIEF DESCRIPTION OF THE DRAWINGS
Figure 1 is a network diagram showing a typical network in which the facility is implemented.
Figure 2 is a high-level block diagram of a typical general- purpose computer system in the network in which portions of the facility operate. Figure 3 is a high-level block diagram showing typical components of a client computer system in which portions of the facility operate, such as client computer systems 101-105 shown in Figure 1.
Figure 4 is a conceptual diagram showing, at a high level, the processing performed by the bandwidth manager.
Figure 5 is a flow diagram showing the steps preferably performed in a bandwidth manager by the facility in order to receive, packetize, and queue messages.
Figure 6 is a flow diagram showing the conceptual steps that are performed by the facility and the bandwidth manager to transmit messages to clients.
Figure 7 is a flow diagram showing the steps that are preferably actually performed by the facility in order to transmit packets to client computer systems. Figure 8 shows the queue data structure at a time before the transmission of the packet.
Figure 9 is a data structure diagram showing the state of the queue data structure after a packet has been sent.
Figure 10 is a conceptual diagram showing, at a high level, the processing performed by the client computer system.
Figure 11 is a flow diagram showing the steps preferably performed by the portion of the facility that is in the client computer system in order to process received packets.
Figure 12 is a flow diagram showing the steps preferably performed by the facility to process an uncached message.
Figure 13 is a display diagram showing a user interface preferably displayed by the facility.
Figure 14 is a display diagram showing the user interface after the receipt of an uncached chat message. Figure 15 is a flow diagram showing the steps preferably performed in the client computer system by the facility to process a message of the cache class.
Figure 16 is a flow diagram showing the steps preferably performed in the client computer system by the facility in order to process a trigger message.
Figure 17 is a display diagram showing a display of contents of the cached message in response to receiving a trigger message.
Figure 18 is a display diagram showing the display of a progress meter in accordance with step 1604 of Figure 16. Figure 19 is a flow diagram showing the steps preferably performed by the facility in order to process a message deletion message.
Figure 20 is a flow diagram showing the steps preferably performed by the facility in order to process a message retention cache clearing message. Figure 21 is a flow diagram showing the steps preferably performed by the facility in order to retrieve chat messages.
Figure 22 is a flow diagram showing the steps preferably performed in the HTTP server in response to an HTTP request from the client for packets for a particular component. Figure 23 is a flow diagram showing the steps preferably performed by the facility in the second implementation of the client in components other than the chat component.
DETAILED DESCRIPTION
The present invention provides a facility for controlling the bandwidth used to transmit data to a recipient computer system ("the facility").
In a preferred embodiment, the facility is implemented in a bandwidth manager computer system ("the bandwidth manager"), which sends data to the recipient computer system at a data rate generally not exceeding a maximum data rate.
The maximum data rate is preferably chosen for the recipient computer system based on both the total data rate at which the recipient computer system can typically receive data, as well as the sorts and sources of data that the recipient computer system is expected to receive. For example, where a recipient computer system is connected to the Internet via a "28.8K" modem, the recipient computer system can generally receive data at a total rate
of about 20 kilobits per second ("kbps"), allowing for error correction and connections at speeds lower than the modem maximum speed. (Recipient computer systems connected to the Internet with higher-speed connections, such as "56.6K" modems, ISDN, xDSL, cable modems, or Tl connections, have higher total data rates.) If the recipient computer system is expected to receive data only from the bandwidth manager, then a maximum data rate of 20 kbps may be set for this recipient computer system. If, on the other hand, the recipient computer system is also expected to receive streaming audio from a streaming multimedia server at the rate of 10 kbps, then a maximum data rate of 10 kbps, or about 100 bytes every 100 ms, may be set for data transmitted from the bandwidth manager to the recipient computer system.
By limiting the rate at which the bandwidth manager transmits data to the recipient computer system to the maximum data rate established for the recipient computer system, the facility ensures that data sent to the recipient computer system through the bandwidth manager can be successfully received by the recipient computer system. Similarly, the facility ensures that data sent to the recipient computer system from computer systems other than the bandwidth manager that is accounted for in the maximum data rate established for the recipient computer system can be successfully received by the recipient computer system. Thus, the facility may be used to reserve bandwidth to the recipient computer system for multimedia streams, web browsing, electronic mail and other forms of messaging, and other network applications of any type.
In certain preferred embodiments of the invention, the bandwidth manager computer system receives messages from one or more message sources. Each received message is addressed to one or more recipient computer systems. The bandwidth manager preferably divides each message into one or more packets of a size based on contents of the message, such as a message type. This process is referred to as "packetizing" the message. The packets that are produced are ultimately sent to each recipient computer system to which the message is addressed, at a rate not exceeding the maximum data rate set for the
recipient computer system. Until these packets are transmitted to the recipient computer system, however, the bandwidth manager retains them in queues that it maintains for each recipient computer system.
The bandwidth manager preferably maintains a set of queues for each recipient computer system to which it is presently configured to forward messages. The queues of a set each have a different priority level. After a message is received and packetized, for each addressee recipient computer system, the bandwidth manager places the produced packets in the queue for the addressee recipient computer system having the proper priority based on the contents of the message, such as a message type contained in the message. When the bandwidth manager transmits packets to a recipient computer system, it first transmits packets stored in the queue for the recipient computer system having the highest priority, then transmits packets stored in the queue for the recipient computer system having the second-highest priority, etc. When the transmitted packets are received in the recipient computer system, they are reassembled into whole messages and processed on the recipient computer system. For example, visual information contained in the messages may be displayed by the recipient computer system. In certain preferred embodiments, the recipient computer system stores some of the received messages in a cache, so that a very short message can later be transmitted to the recipient computer system to quickly display the contents of the cached message. For instance, images whose messages can take several seconds to transmit to a client computer system may be pre-transmitted to the client computer system, then quickly displayed in response to such a "trigger" command. Using the facility's message prioritization scheme, messages containing trigger commands and other small administrative messages may be quickly transmitted to the recipient computer system ahead of other earlier- pending messages.
In order to ensure that data is transmitted to each recipient computer system at a data rate not exceeding the maximum data rate set for the
recipient computer system, the facility utilizes a calculated quantity called "minimum sleep time." Once a packet has been transmitted to a recipient computer system, the minimum sleep time is the nrinimum length of time that bandwidth manager must wait before sending the next packet to the recipient computer system to prevent the actual data rate to the recipient computer system from exceeding the maximum data rate for the recipient computer system. The facility calculates niinimum sleep time based upon the maximum data rate for the recipient computer system and the size of either the last packet sent to the recipient computer system or the next packet to be sent to the recipient computer system. In general, the facility transmits the next packet to the recipient computer system at or slightly after the minimum sleep time has elapsed.
In order to manage data relating to particular recipient computer systems in the bandwidth manager, the bandwidth manager preferably instantiates a programmatic object for each "active" recipient computer system to which the bandwidth manager is configured to send data. This "client object" preferably contains all of the state information needed to transmit to the recipient computer system messages addressed to it at a rate no larger than the maximum data rate specified for the recipient computer system, such as indications of all packets that need to be transmitted to the recipient computer system and their priorities and origination times; an indication of the last time a packet was sent to the recipient computer system; an indication of the next time a packet should be sent to the recipient computer system; an indication of the maximum data rate for the recipient computer system; and information needed to send a packet to the recipient computer system, such as the network address of the recipient computer system. Each client object preferably also exposes a conditional send method. When the conditional send method is invoked, if the current time is later than the next packet transmission time, then the method transmits the next packet to the recipient computer system. Otherwise, the conditional send method returns the next packet transmission time, so that the
conditional send method can be invoked again at or shortly after the next packet transmission time to transmit the next packet.
In accordance with an additional embodiment of the present invention, the facility is implemented in an HTTP server in order to operate with a recipient computer system whose interaction with the Internet is limited by a firewall security device that prevents direct interaction with the bandwidth manager. In this embodiment, the recipient computer system periodically sends an HTTP request to the HTTP server. In response to the HTTP request, the HTTP server contacts the bandwidth manager, transfers any packets pending for the recipient computer system in the queues of the bandwidth manager to the HTTP server, and sends some or all of these pending packets to the recipient computer system in an HTTP reply sent at a rate not exceeding the maximum data rate for the recipient computer system. In a further preferred embodiment, the HTTP server sends only some of the pending packets to the recipient computer system, but includes an indication that the recipient computer system should send additional HTTP requests to obtain the remaining pending packets. In order to fully describe the invention, a more detailed description of the implementation of various embodiments and aspects of the invention follows. Figure 1 is a network diagram showing a typical network in which the facility is implemented. The network shows a number of client computer systems, or "recipient computer systems," 101-105 that are all connected to the Internet 100. Clients 101 and 102 are connected to the internet 100 via 28.8K modems. Clients 103 and 104 are connected to a security firewall 110 via Ethernet connections, and from there to the Internet 100 via a Tl connection. The client 105 is connected to the Internet 100 via an ISDN connection. The clients 101-105 can receive data via the Internet 100 from servers, such as a web server, or "HTTP server," 120; a streaming multimedia server 130 for providing multimedia sequences using streaming delivery; and metered servers, such as metered servers 141 and 142, which provide information to the clients
through a bandwidth manager 140. The bandwidth manager 140 executes portions of the facility in order to limit the rate at which data is sent from the metered servers to each client to a data rate not larger than a maximum data rate specified for the client. Figure 2 is a high-level block diagram of a typical general- purpose computer system in the network in which portions of the facility operate. The computer system 200 contains a central processing unit (CPU) 210, input/output devices 220, and a computer memory (memory) 230. Among the input/output devices is a network connection 221, through which the computer system 200 may communicate with other connected computer systems, a storage device 222, such as a hard disk drive; and a computer- readable media drive 223, which can be used to install software products, including the facility, which are provided on a computer-readable medium, such as a CD-ROM. The memory 230 preferably contains computer programs and data. In computer systems that act as servers, the memory 230 and/or the storage device 222 preferably contain both data that is served to client computer systems as well as server software such as an HTTP server and/or a streaming multimedia server. While the facility is preferably implemented on computer systems configured as described above, those skilled in the art will recognize that it may also be implemented on computer systems having different configurations.
Figure 3 is a high-level block diagram showing typical components of a client computer system in which portions of the facility operate, such as client computer systems 101-105 shown in Figure 1. In addition to the components shown in Figure 2 and discussed above, the client computer system 300 preferably includes the following additional input/output devices: a display device 324, such as a video monitor, for displaying visual information; a keyboard 325 for inputting text; a pointing device 326, such as a mouse, for selecting positions within information displayed on the display device; and an audio output device 327, such as speakers, for outputting audio
information. Among the programs 331 stored in the memory 330 is preferably a web browser program that can issue HTTP requests to web servers and display the contents of the resulting HTTP responses. Many such browsers also support JavaScript, an HTTP scripting language. Some browsers further support Java, a largely hardware-independent language. While computer systems such as the one shown is preferably used as client computer systems, those skilled in the art will recognize that client computer systems having different configurations may also be used.
Figure 4 is a conceptual diagram showing, at a high level, the processing performed by the bandwidth manager. At the highest level, the bandwidth manager 410 transforms messages 401 addressed to particular recipient computer systems into message packets that are transmitted to the addressee recipient computer systems at a data rate no greater than the maximum data rate specified for each of the addressee recipient computer systems. As part of this process, the bandwidth manager in step 411 first divides each message into smaller packets. This process is referred to as packetization. In step 412, the bandwidth manager queues the packets making up the message in queues for each addressee. Finally, in step 413, the bandwidth manager dequeues and sends the queued message packets at a rate no greater than the maximum data rate for each addressee recipient computer system. These steps are discussed below in greater detail in conjunction with Figures 5-9.
Figure 5 is a flow diagram showing the steps preferably performed in a bandwidth manager by the facility in order to receive, packetize, and queue messages. In step 501, the facility receives a message. The message may either directly contain content data, or may contain a reference to content data available from the server. Each message also contains a list of addressees, recipient computer systems, or "clients" to which the message is to be transmitted. In step 502, the facility packetizes the message by dividing the message into one or more packets that are each no larger than a target packet
size. The target packet size is preferably specified with respect to certain contents of the message, such as a message type indication contained by the message. In steps 503-507, the facility loops through each client specified to receive the message. In step 504, the facility places the packets of the message on a queue for the current client. The client preferably has several different queues, each having a different priority. The facility preferably selects the appropriate queue by discerning the priority of the message based on the contents of the message, such as an indication of the type of the message contained in the message. These packets may be placed on the queue either directly or by reference. In step 505, if the queue to which the message packets were added, as well as any higher-priority queues, were emptied before the addition of the packets, then the facility continues in step 506, else the facility continues in step 507. In step 506, the facility recalculates the next time at which a packet is to be sent to the client based upon the size of the first new packet. After step 506, the facility continues as step 507. In step 507, the facility loops back to step 503 to process the next addressee client. After step 507, the facility continues in step 501 to process the next received message.
The steps shown in Figure 5 may be performed by one or more threads in the bandwidth manager. In particular, steps 501-502 may be performed in a first thread, and steps 503-507 may be performed in a second thread. Further, as is discussed in greater detail below, steps 505 and 506 relate to an embodiment in which the time at which the next packet is sent is based on the size of the next packet to be sent. In an alternative embodiment in which the time at which the next packet is sent is placed upon the size of the last packet sent, steps 505 and 506 are unnecessary and are omitted.
Figure 6 is a flow diagram showing the conceptual steps that are performed by the facility and the bandwidth manager to transmit messages to clients. Steps 601-605 are repeated each time a next send time is reached for a particular client. In step 602, the facility sends the highest-priority packet contained in the queues for the client. In step 603, the facility updates the last
send time for the client to the current time. In step 604, the facility recalculates the next send time for the client based upon the current time, and either the size of the new highest-priority packet in the queues for the client or on the size of the packet sent in step 602. In step 605, the facility loops back to step 601 to process the next client next send time that is reached.
The processing of step 604 is central to ensuring that data is sent to each client computer system at a rate not exceeding its maximum data rate. The next send time is calculated by adding to the last send time an amount of time equal to the size of a packet addressed to the client computer system divided by the maximum rate for the client computer system. In a first embodiment, the packet whose size is used for this calculation is the packet that was last sent. In a second embodiment of the invention, the packet whose size is used in this calculation is the next packet to be sent. Because the second embodiment relies on an identification of the next packet to be sent, and because new packets that are added to the queues for a client that are of a higher priority than the other queued packets for the client can change the identity of the next packet to be sent, in the second embodiment, the facility preferably recalculates the next send time each time a new packet is added to the queues for a client that becomes the highest-priority packet. Consider the following example comparing the two embodiments mentioned above. In the example, the current client has a maximum data rate of 10 kbps. The facility has just sent a 1,000-bit packet to the client, and will next send a 500-bit packet to the client. In accordance with a first embodiment, the facility adds to the current time a minimum of sleep time of the size of the packet just sent, 1,000 bits, divided by the maximum data rate of 10 Kbps to arrive at a minimum sleep time of .1 seconds. In accordance with a second embodiment, the facility determines the next sent time by adding to the current time a minimum sleep time equal to the size of the next packet to be sent, 500 bits, divided by the maximum data rate for the client of 10 kbps, or .05 seconds.
Figure 7 is a flow diagram showing the steps that are preferably actually performed by the facility in order to transmit packets to client computer systems. In step 701, the facility initializes an earlier next send time variable to a time that is far in the future. In steps 702-707, the facility loops through each client in the active list ~ that is, each client whose queues contain outgoing packets. In step 703, if the next send time for the client is later than the current time, then the facility continues in step 706, else the facility continues in step 704. In step 704, the facility sends the highest-priority packet queued for the client. This is the packet having the highest priority value that was least recently received in the bandwidth manager. The facility preferably uses information stored for the client, such as the client's network address, to send this packet to the client. As part of step 704, the facility removes the sent packet from the queues for the client. In step 705, the facility calculates the next send time for the client as discussed above in conjunction with step 604. After step 705, the facility continues in step 706. In step 706, the facility sets the value of the earliest next send time variable to the earlier of (1) the current value of the earliest next send time variable and (2) the next send time for the current client. In step 707, the facility loops back to step 702 to process the next client in the active list. After step 707, the earliest next send time variable contains the earliest next send time variable contains the earliest time at which any client is scheduled to send its next packet. In step 708, the facility sleeps until this earliest next send time. After step 708, the facility wakes and continues in step 701 to repeat the cycle.
In the second embodiment discussed above in which the size of the next packet to be sent is used to calculate minimum sleep time for a client, the sleep of step 708 may be interrupted to send a packet to a client to whose queues a new packet has been added as the new highest priority packet if the new packet is smaller than the former highest priority packet.
In certain embodiments, each active client is represented by a programmatic object. Such a "client object" contains data relating to the state
of the bandwidth manager's efforts on behalf of the client, including the contents of its queues, its last sent time, and its next send time. The client object preferably further implements a conditional send method that, when invoked, provides the functionality of steps 703-705. That is, the conditional send method determines the next send time for the client has been reached, and, if so, sends a packet to the client and recalculates the next send time for the client. If the next send time has not been reached, the conditional send method preferably returns an indication of the next send time, which can be used to schedule a future invocation of the conditional send method. Figures 8 and 9 are data structure diagrams showing the state preferably maintained by the facility for each active client. Figure 8 shows the queue data structure at a time before the transmission of the packet. It can be seen that the queue data structure 800 contains information for each of a number of active clients. For active client 1, the queue data structure 800 contains five queues: queue 810 for priority 1 packets, queue 815 for priority 2 packets, queue 820 for priority 3 packets, queue 825 for priority 4 packets, and queue 830 for priority 5 packets. The priority 1 packets in queue 810, packets 811, 812, and 813, are of the highest priority (most urgent), while packet 826 in queue 825 is of the lowest priority (least urgent). For each active client, the queue data structure 802 further includes an indication 805 of the last time at which packet was sent to active client 1 and an indication 806 of the next time at which a packet is to be sent to active client 1. The state of the queue data structure in Figure 8 corresponds to a current time of 2:06: 12.010.
Figure 9 is a data structure diagram showing the state of the queue data structure after a packet has been sent. Figure 9 corresponds to a current time of 2:06: 12.020. It can be seen that, while the priority 1 queue 910 still contains packets 912 and 913, the priority 1 queue 910 no longer contains packet 811 shown in Figure 8. This packet was sent at time 2:06: 12.018. After being sent, it was removed from priority 1 queue 910. Further, the last send time 905 and next send time 906 for active client 1 have been updated. The last
send time 905 now indicates the time at which packet 811 was sent, the next send time 906 indicates the time at which the new highest-priority packet 912 will be sent.
The packets pending for a particular client are described above in conjunction with Figures 8 and 9 as being represented in a number of queues, each having a different priority levels. In this description, the next packet selected for transmission to the client is always the packet least recently added to the highest-priority nonempty queue. In a further embodiment of the invention, the facility instead represents the pending packets for a client in a binary tree structure. Each packet is preferably represented as a node in the tree. Nodes representing new packets are added to the tree, and nodes representing sent packets are selected and removed from the tree, based on a two-component ordinality in which packet priority level is the high-order component and packet reference time is the low-order component. Using such a tree to represent pending packets can be both (1) more efficient than fixed queues, since no space is reserved for priorities at which no packets are sent, and (2) more flexible, as the priorities assigned to packets need not be within a predetermined set of possible priorities.
Figure 10 is a conceptual diagram showing, at a high level, the processing performed by the client computer system. The client computer system 1010 receives metered message packets 1001 from the bandwidth manager. In step 1002, the portion of the facility on the client computer system reassembles messages made up by the received metered message packets. In step 1003, based on the kind, or "class" of the message, the facility either continues in step 1004 if the message is of an uncached class, continues in step 1005 if the message is of a cached class, or continues in step 1006 if the message is of a trigger class. For messages of the uncached class, the contents of the message are immediately displayed in step 1004. Uncached messages are those whose content is to be displayed immediately upon delivery, such as chat messages. For messages of the cached class, the facility stores the message in
the cache in step 1005. Cached messages are those whose contents are not to be displayed immediately upon receipt, but are rather stored in the cache until a trigger message is received specifying the display of the contents of the cached message. Finally, if the message is of a trigger class, the trigger message specifies a cached message that is to be displayed in step 1006 in response to receiving the trigger message.
Figure 11 is a flow diagram showing the steps preferably performed by the portion of the facility that is in the client computer system in order to process received packets. In step 1101, the facility receives a packet from the bandwidth manager computer system. In step 1102, if the received packet is the first packet of a new message, then the facility continues in step 1103, else the facility continues in step 1104. In step 1103, the facility adds an entry to an incoming message store for the message. The incoming message store is designed to manage the packets of any messages that have not yet been received in their entirety. In a preferred embodiment, the incoming message store is implemented using a hash table that maps from a message identifier stored in each packet to the packets that have been received containing this message identifier. In one embodiment, the facility further preferably maintains a mapping to the message identifier for received messages from a second identifier for the message used in trigger messages and kill messages. The second identifier is preferably invariant across all the client computer systems, while the message identifier of a particular message may vary across the different client computer systems to which it is transmitted, since the bandwidth manager preferably assigns message identifiers serially for each client. After step 1103, the facility continues in step 1104.
In step 1104, the facility adds the received packet to the entry in the incoming message store for the message. In step 1105, if the incoming message store now contains the complete message, then the facility continues in step 1106, else the facility continues in step 1101 to receive the next mcoming packet. In step 1106, the facility removes the complete message from the
incoming message store and processes the message based upon a message type indication contained in the message. The processing of step 1106 is discussed in greater detail below in conjunction with Figures 12, 15, and 16.
A first type, or "class" of message that is processed by the facility is uncached messages. As mentioned above, uncached messages are those whose contents are immediately displayed upon receipt of a message. Figure 12 is a flow diagram showing the steps preferably performed by the facility to process an uncached message. In step 1201, the facility displays the contents of the message. The steps then conclude. Figures 13 and 14 show the processing of an uncached message.
Figure 13 is a display diagram showing a user interface preferably displayed by the facility. In the user interface, the client window 1300 contains several visual components, each of which can be designated to receive messages addressed to the client computer system. Components 1321, 1322, and 1323 are all image components that can display images received in messages. Component 1310 is a chat window that can display chat lines 1311-1314 contained on chat messages received by the client computer system. The user may also type a new chat line into field 1331, and send it to other chat participants by pressing button 1332. Figure 14 is a display diagram showing the user interface after the receipt of an uncached chat message. It can be seen that, while Figure 14 is similar to Figure 13, an additional chat line 1415 has been added to chat lines 1311-1314 shown in Figure 13. The facility preferably does so immediately in response to receiving the last packet of a message containing chat line 1415. Figure 15 is a flow diagram showing the steps preferably performed in the client computer system by the facility to process a message of the cached class. Such messages include those that contain images. In steps 1501, the facility stores the message in a message retention cache. The message retention cache is preferably implemented using a hash table that maps from the
secondary message identifier of the message to the contents of the message. After step 1501, these steps conclude.
Figure 16 is a flow diagram showing the steps preferably performed in the client computer system by the facility in order to process a trigger message. Each trigger message preferably includes the secondary identifier of the cached message whose contents are to be displayed. In step 1601, if the message identified by the secondary identifier contained in the trigger message is stored in the message retention cache, then the facility continues in step 1606, else the facility continues in step 1602. In step 1602, if a portion of the identified message has been received and is stored in the incoming message store, then the facility continues in step 1604, else the facility continues in step 1603. In step 1603, the facility waits for the receipt of the first packet of the identified message. This waiting step preferably involves periodically checking the mcoming message store for the arrival of the first packet at an interval such as .5 seconds. After step 1603, the facility continues in step 1604. In step 1604, until the last packet of the identified message is received, the facility displays a progress meter indicating the partial extent to which the identified message has been received. This progress meter is preferably displayed at the location in the user interface at which the contents of the identified message will eventually be displayed. In step 1605, once the last packet of the identified message is received in the client computer system, the facility moves the identified message to the message retention cache. In step 1606, the facility displays the identified message contained in the message retention cache. After step 1606, these steps conclude. Note that the identified message is preferably not deleted from the message retention cache at this time, permitting the identified message to be redisplayed again in the future when another trigger message is received identifying this cached message identifying this cached message.
Figures 17 and 18 show the processing of a cached message. Figure 17 is a display diagram showing the display of contents of the cached
message in response to receiving a trigger message. By comparing Figure 17 to Figure 14, it can be seen that, in response to receiving a message containing image 1724, then receiving a trigger command identifying image 1724 stored in the message retention cache, the facility has displayed image 1724 in place of image 1422.
Figure 18 is a display diagram showing the display of a progress meter in accordance with step 1604 of Figure 16. By comparing Figure 18 to Figure 17, it can be seen that the display of image 1724 has been replaced with a progress meter 1825 in response to receiving a trigger message for a cached message that has not yet been received in its entirety. As additional packets for this message are received, the facility updates the progress meter to indicate that more of the image has been downloaded. As soon as the last packet of the message is received, the facility preferably replaces the display of the progress meter 1825 with the display of the contents of the new image. Figures 19 and 20 describe the processing of additional types of messages used to maintain the contents of the message retention cache. Figure 19 is a flow diagram showing the steps preferably performed by the facility in order to process a message deletion message. A message deletion message is preferably sent to remove a cached message from the message retention cache that is no longer needed. Such messages identify a single cached message to be deleted from the message retention cache, preferably by the secondary identifier of the message. In step 2001, the facility deletes the cached message identified by the message deletion message from the message retention cache. After step 1901, these steps conclude. Figure 20 is a flow diagram showing the steps preferably performed by the facility in order to process a message retention cache clearing message. A message retention cache clearing message is preferably sent in order to remove all of the messages in the cache to make space for new cached messages. In step 2001, the facility deletes from the message retention cache all of the cached messages contained there. After step 2001, these steps conclude.
The approach described above for receiving and processing packets in the client computer system assumes both that (1) Java, or another fairly sophisticated Internet message-processing computer language may be executed on the client computer system, and (2) that the described metered message packets are able to travel unimpeded from the bandwidth manager computer system to the client computer system. These assumptions are not true in the case of every potential client computer system. As for assumption (1), many web browser programs presently in use do not provide for the execution of programs in Java or a similar language. Further, some client computer systems, such as client computer systems 103 and 104 shown in Figure 1, are connected to the Internet via a security firewall that intercepts certain types of packets transmitted to the client computer systems. In order to deliver messages to client computer systems having any of the above limitations, the facility preferably provides a second client implementation for use in these systems. The second client implementation utilizes simple HTTP requests generated by JavaScript scripts supported by most web browser programs presently in use. The second client implementation preferably uses a HTTP server or "web server," such as web server 120 shown in Figure 1 as an intermediary between the bandwidth manager and the client computer system. Because most security firewalls are configured to permit the flow of HTTP traffic between the clients and Internet web servers, it is generally possible to send HTTP requests from the client computer system to the web server, and to send HTTP responses from the web server to the client computer system.
The second client implementation preferably constitutes a compound HTML document that is loaded into the browser of the client computer system. The compound HTML document contains several frames each corresponding to one of the components 1310, 1321, 1322, and 1323 shown in Figure 13. Each frame in turn is controlled by a JavaScript script that issues HTTP requests to the web server to retrieve the contents for the frame.
In the second client implementation, designed to support chat lines and images, the messages containing retrieval of all information from the bandwidth manager is based on the retrieval of chat lines, which are generally sent to the client more frequently than new images. Figure 21 is a flow diagram showing the steps preferably performed by the facility in order to retrieve chat messages. These steps are preferably implemented in the JavaScript script executing in the frame for the chat component. The facility preferably repeats steps 2101-2109 every five seconds, or at another suitable interval for retrieving chat messages. In step 2102, the facility sends to the HTTP server an HTTP request for client packets containing the client identifier of the client and the component identifier of the chat component. In step 2103, the facility receives from the HTTP server any chat packets addressed to the client computer system. In step 2104, the facility displays the received chat packets in the chat component, as is shown in Figure 14. In step 2105, the facility further receives from the HTTP server the component identifiers of any components for which HTTP server also has packets for the client computer system. In steps 2106- 2108, the facility loops through each received component identifier. In step 2107, the facility sends a message from the chat component and frame to the components and frames identified by the current component identifier. In step 2108, the facility loops back to step 2106 to process the next received component identifier. In step 2109, after five seconds has elapsed, the facility continues in step 2101 to check for additional chat messages at the HTTP server. While the chat component preferably also contains functionality for sending chat messages generated by the user of the client computer system, these steps are not shown here.
Figure 22 is a flow diagram showing the steps preferably performed in the HTTP server in response to an HTTP request from the client for packets for a particular component. These steps are preferably implemented in the HTTP server computer system using a CGI script executing on the HTTP server. These steps receive as parameters a client identifier for the client
computer system that sends a request, and a component identifier indicating the component whose packets are to be retrieved. In step 2201, if the component identifier is the component identifier of the chat component, then the facility continues in step 2202, else the facility continues to step 2206. In step 2202, the facility retrieves all pending packets from the binding manager's queues for the client having the client identifier. The retrieved packets may include packets for the chat component, packets for the image components, or packets for other components. In step 2203, the facility caches any packets retrieved in step 2202 that specify components other than the chat component. In step 2204, the facility sends the packets retrieved in step 2202 that are chat packets to the client at or below the maximum data rate for the client. Step 2204 is preferably formed in the manner described above in conjunction with Figures 6 and 7. In step 2205, the facility sends to the client additional HTTP responses containing the component identifiers specified for the retrieved packets that were cached in step 2203. After step 2205, these steps conclude. In step 2206, where the request contains a component identifier other than the component identifier for the check component, the facility sends any cache packets specifying this component identifier to the client at or below the maximum data rate for the client. The facility preferably deletes the cache packets from the cache at this point. After step 2206, these steps conclude.
Figure 23 is a flow diagram showing the steps preferably performed by the facility in the second implementation of the client in components other than the chat component. These steps are preferably performed by a JavaScript script controlling each of the frames containing the non-chat components. In step 2301, the facility receives a message from the chat component indicating that the HTTP server has cached packets specifying this component. In step 2302, the facility sends an HTTP request to the HTTP server for packets containing the client identifier of the client computer system and the component identifier of this component. In step 2303, the facility receives from a HTTP server an HTTP response containing the component
packets. In step 2304, the facility displays the received component packets in the frame. After step 2304, the facility continues in step 2301 to receive the next message in the chat component.
While the present invention has been shown and described with reference to preferred embodiments, it will be understood by those skilled in the art that various changes or modifications in form and detail may be made without departing from the scope of the invention. For example, the functionality provided by the bandwidth manager may be distributed over multiple computer systems of various types. In particular, multiple bandwidth managers may be used for the same or different sets of metered servers. Where multiple bandwidth manager computer systems are used, they may be allocated in accordance with the geographic distribution of metered servers, the geographic distribution of clients, or in accordance with other factors. Also, while the preferred embodiment of the invention is described in conjunction with messages containing chat and image data, the facility may be used to deliver information of all types. Further, the portion of the facility that operates on the client computer system may be straightforwardly adapted to a variety of different types of client computer systems and browser computer programs executing thereon.