1. Field of the Invention
The present invention generally relates to signal distribution in a network such as a digital home network, and more particularly, to methods and apparatuses for providing load balanced signal distribution to client devices in such a network.
2. Background Information
Signal distribution networks, such as digital home networks, have become increasingly popular in today's society. For example, in a digital home network that receives audio and/or video signals from a signal source such as a satellite, devices/apparatuses known as “gateways” are often used to distribute signals to client devices, which may for example be embodied as set-top boxes (STBs).
One problem associated with conventional satellite gateway systems is that they do not support splitting satellite network feeds across multiple gateways. That is, a given network can be sourced from only one gateway at a time. Additionally, assuming relatively high bit rates (e.g., A3, etc.) and high definition content, a conventional system can easily result in a gateway exceeding its total output bandwidth at its output interface. For example, assuming a peak stream bit rate of 18 megabits per second, just 40 different H.264 streams are enough to consume an aggregate of 700-800 megabits per second on a GEI0 (i.e., Gigabit Ethernet Interface port 0) interface. In addition, when including spot beams, some satellite networks have more than 32 transponders and a transponder can support several video and audio channels. The inability to split such a network across multiple gateways means that a conventional system cannot simultaneously tune all its transponders.
The present invention described herein addresses the foregoing and/or other issues, and in particular, provides a new architecture that is capable of, among other things, preventing over-subscription of the output interface of a gateway, as well as providing flexibility in supporting new networks, larger numbers of satellite transponders, larger numbers of client devices, and gateway redundancy.
In accordance with an aspect of the present invention, a method is disclosed. According to an exemplary embodiment, the method comprises the steps of receiving a request from a client device for downloading video from one of a plurality of video sources, receiving respective load indicators from first and second video receiving devices capable of receiving the plurality of video sources, selecting one of the first and second video receiving devices according to the load indicators, and instructing the selected video receiving device to transmit the video from the one of the plurality of video sources using an address known by the client device.
In accordance with another aspect of the present invention, an apparatus is disclosed. According to an exemplary embodiment, the apparatus comprises means such as a first input for receiving a request from a client device for downloading video from one of a plurality of video sources, means such as a second input for receiving respective load indicators from first and second video receiving devices capable of receiving the plurality of video sources, means such as first control logic for selecting one of the first and second video receiving devices according to the load indicators, and means such as second control logic for instructing the selected video receiving device to transmit the video from the one of the plurality of video sources using an address known by the client device.
In accordance with yet another aspect of the present invention, another method is disclosed. According to an exemplary embodiment, the method comprises the steps of sending a load indicator from a video receiving device capable of receiving a plurality of video sources to a request server device, wherein the load indicator indicates a load associated with the video receiving device; receiving from the request server device, data indicating a requested program and a destination address of a client device associated with the requested program; and transmitting the requested program to the destination address.
In accordance with still another aspect of the present invention, another apparatus is disclosed. According to an exemplary embodiment, the apparatus comprises means such as control logic for determining a load indicator indicating a load associated with the apparatus; means such as an interface for sending the load indicator to a request server device; and wherein, in response to the load indicator, data indicating a requested program and a destination address of a client device associated with the requested program is received from the request server device, and the apparatus transmits the requested program to the destination address.
In accordance with yet another aspect of the present invention, another method is disclosed. According to an exemplary embodiment, the method comprises the steps of sending a request for a program from a client device to a request server device, receiving an address at the client device from the request server device in response to the request, receiving the requested program at the client device via a selected video receiving device using the address, and wherein the request server device selects the selected video receiving device from among a plurality of video receiving devices based on respective load indicators from the plurality of video receiving devices.
In accordance with still another aspect of the present invention, another apparatus is disclosed. According to an exemplary embodiment, the apparatus comprises means such as an output for sending a request for a program to a request server device; means such as an input for receiving an address from the request server device in response to the request and for receiving the requested program via a selected video receiving device using the address; and wherein the request server device selects the selected video receiving device from among a plurality of video receiving devices based on respective load indicators from the plurality of video receiving devices.
The above-mentioned and other features and advantages of this invention, and the manner of attaining them, will become more apparent and the invention will be better understood by reference to the following is description of embodiments of the invention taken in conjunction with the accompanying drawings, wherein:
The exemplifications set out herein illustrate preferred embodiments of the invention, and such exemplifications are not to be construed as limiting the scope of the invention in any manner.
Referring now to the drawings, and more particularly to
The load balancing architecture of
The load balancing solution provided by the architecture of
Load balancing according to principles of the present invention supports seamless failure reconfiguration and recovery. In the load-balanced system of
Load balancing according to principles of the present invention divorces the RTSP (Real Time Streaming Protocol) proxy server gateway 20 from streamer gateways 10, and divorces the network tuning and data streaming function from proxy server gateway 20. As such, a streamer gateway 10 or a proxy server gateway 20 constructed under the principles of this invention, is less complicated and costs less. For example, a Linux PC can be used as proxy server gateway 20 and a low cost microprocessor can be used in streamer gateways 10, which also include tuners, FPGAs (Field Programmable Gate Arrays), and Giga-bit controllers.
According to an exemplary embodiment, the following considerations may be taken into account when designing the load balancing system:
Referring now to
In
Proxy server gateway 20 is actually a reverse proxy because it acts as a proxy for all in-bound client RTSP traffic that will in part be forwarded to streamer gateways 10 hidden behind the single proxy server IP address. In contrast, a forward proxy acts as a proxy for out-bound traffic.
Independent of proxy server gateway 20 and streamer gateway 10 functionality, all gateways 10 and 20 may provide:
A multiple gateway system should allow only one DHCP, MTFTP, or proxy modem server active at one time.
Proxy Server Gateway 20 Functionality
Proxy server gateway 20 should provide the following services:
Proxy server gateway 20 receives and processes RTSP requests from all client devices (e.g., STBs 35) on the network (see
Streamer Gateway 10 Functionality
Streamer gateways 10 provide tuner management and video data pump functionality. Streamer gateways 10 should not provide RTSP server support to client devices (e.g., STBs 35) on the network (see
Streamer gateways 10 should communicate with proxy server gateway 20 to exchange the following information:
If proxy server gateway 20 is not enabled on the streamer gateway 10, proxy server-specific MIBs (mxuRtspServerConfig, mxuClientStatus, etc.) should return a “no such instance” message to SNMP queries, where mxuRtspServerConfig and mxuClientStatus represent the configuration of proxy server gateway 20 and the status of its client devices, respectively.
Proxy Server Gateway 20 Functional Partitioning
An RTSP software stack of proxy server gateway 20 includes the following software modules:
The distribution of the proxy RTSP server functionality preferably should be as shown in
Referring now to
In a loaded system, there will be a large percentage of streamer database 23 matches (hits) resulting in minimal RTP Session messaging over the local bus. The RTSP server module of proxy server gateway 20 preferably is single threaded and processes one client request at a time from request through response. It blocks until tune/RTP Session requests have been sent to DSFE device module 14 of streamer gateway 10 (see
Streamer gateways 10 manage their own tuner pools. Proxy server gateway 20 should not micromanage streamer tuner allocation. Proxy server gateway 20 will periodically query streamer triplet and RTP session status using the status commands detailed in Appendix A.2.
The above partitioning example means that channel acquisition module 13 and DSFE device module 14 runs only on streamer gateways 10, and permits porting the functionality of proxy server gateway 20 to a high performance, low cost platform (e.g., Linux, etc.) that can support more than 1000 users.
Proxy server gateway 20 should monitor the presence and operating states of streamer gateways 10 via periodic streamer SAP announcements sent on the local bus. Proxy server gateway 20 should also detect failed streamer gateways 10 and redistribute the data load across the remaining streamer gateways 10 of the given network.
Operation
Proxy RTSP Server SAP Listener Module
Proxy server gateway 20 will provide a listener module to monitor streamer gateway 10 network SAP announcements. The listener should join a particular multicast group, such as 239.255.255.255 port 19875. Upon reception of a streamer gateway 10's first SAP announcement the listener module should create a new application timer, AppTimer, instance and send a kRtspNewStreamerDetected message to proxy server gateway 20 indicating detection of a new streamer gateway 10. The AppTimer callback function is used to detect streamer SAP announcement failures. The timer is reloaded upon reception of the next streamer SAP announcement. If the timer expires the listener module will send a kRtspStreamerFailed message to proxy server gateway 20 indicating that the streamer gateway 10 has failed and the AppTimer instance should be deleted. The listener module should detect failed streamer gateways 10 that have come back online, and send a kRtspNewStreamerDetected message to proxy server gateway 20.
Proxy RTSP Server Module
The proxy RTSP server module is single threaded. It depends on a select( ) call to service client STB 35, as well as internal and local bus requests. According to an exemplary embodiment, the proxy RTSP server module implements the SAP announcement module, processes client RTSP protocol requests, manages the proxy server database, sends and receives messages from one or more streamer gateways 10, and receives and processes messages from the SAP announcement module.
i. SAP Listener Module Message Handling
Upon reception of a kRtspNewStreamerDetected message proxy server gateway 20 should create a new Streamer class/module instance and add its networks into the applicable RtspStreamerMedia instances. Proxy server gateway 20 should populate the Streamer instance with one ProxyRtspDsfeMedia instance per announced network.
Upon reception of a kRtspStreamerFailed message proxy server gateway 20 should issue an mxuFailDetectGatewayServiceFailure trap and delete the Streamer instance as well its corresponding entries in the RtspStreamerMedia instances.
ii. Aggregate Video Network SAP Announcement
Proxy server gateway 20 should maintain an up-to-date aggregate network SAP announcement and periodically multicast it to the video network. The announcement must be sent to a predefined multicast group such as 239.255.255.255 port 9875.
At boot time, proxy server gateway 20 should delay its aggregate network SAP announcement until mxuBaseStreamerCount (indicating the expected number of streamers in the system) unique SAP announcements have been received, or until a predefined interval, such as two minutes have elapsed, in order to determine which streamer gateways 10 are present and functional. The aggregate announcement should include an entry for network 0xFFFE if local content insertion is enabled in the system.
iii. Streamer Selection Logic
Streamer gateway 10 selection should be fine-grained. Proxy server gateway 20 searches all Streamer instances for an active triplet that matches the requested triplet. If not found, it selects a qualified streamer gateway 10 having the lowest percent loading calculated, for example, as follows:
Streamer gateway 10 percent load=current load/load set point
Using percent load figures, rather than absolute load figures, permits streamer gateways 10 of varying load carrying capabilities to coexist and/or be seamlessly added into the system.
The selection logic creates an ordered list of qualified streamer gateways 10 based on the client request and current percent load statistics. Lightly loaded streamer gateways 10 are preferred over heavily loaded streamer gateways 10. To limit loading on a gateway having both proxy server and streamer functionality, the load set point may be set to a fraction of the maximum load setting. The resulting action is that proxy server gateway 20 should tend to prefer external streamer gateways 10 because they should have a lower percent loading.
Referring now to
StreamerSelect:
iv. Maximum Client Restriction
Proxy server gateway 20 should enforce a maximum number of client devices (e.g., STBs 35) based on metrics such as TCP connection count. The preferred default maximum is 500 client device connections. New TCP connection requests may be silently refused when the maximum count is reached. The client device count may be overridden with a setting extracted from a valid SW License Key.
Proxy server gateway 20 should send a SNMP trap if the maximum number of connections is active and a new connection request is received. A trap should be sent the first time this occurs and every predetermined number of occurrences thereafter. Proxy server gateway 20 could enforce a maximum number of clients based on RID. Proxy server gateway 20 could for example send a 503: ServiceUnavailable response if the maximum number of RTSP client devices is being served and a RTSP Setup request from a new RID is received.
Inter-Gateway Communication
Local bus communication between proxy server gateway 20 and streamer gateways 10 should be over UDP (see
Proxy server gateway 20 should initiate all communication with streamer gateways 10. Illustratively, proxy server gateway 20 is a client (master) and streamer gateway 10 is a server (slave). Streamer gateway 10 server socket should be bound to a particular UDP port such as port 1554 (see
Proxy server gateway 20 should monitor message delivery success using a send and receive counter. The send counter should be incremented when proxy server gateway 20 sends a message to a streamer gateway 10. The receive counter should be incremented when proxy server gateway 20 receives an acknowledgement from the streamer gateway 10. Each message should have a unique send sequence number that is returned in the acknowledgement. TCP messaging may be used as well especially if data from a loaded system shows an unacceptable amount of message loss. Refer to Appendix A for the detailed format of each message.
v. RTP Session Messages
Proxy server gateway 20 sends 3 types of RTP Session messages to streamer gateways 10:
vi. Status Request Message
Proxy server gateway 20 sends 2 types of status request messages to streamer gateways 10:
The Status Request polling interval will be 2 seconds. It will not be MIB-settable.
Streamer Gateway 10 Status Reporting
Streamer gateways 10 should maintain a list of active triplets and return this information in the Status Request response message. Allocated triplets are reported as either good (St: D1) or failed (St: D0). When a tuner loses lock or cannot be tuned, a streamer gateway 10 should automatically try to use another free tuner to fulfill the tune request. If the streamer gateway 10 tries all available tuners and fails, the Status Request entry for this triplet will indicate failure (St: D0).
Proxy server gateway 20 should use the triplet status to look up the corresponding DsfeSetting slot(s) representing a tuner in its database. If a triplet status indicates failure, proxy server gateway 20 should update its database and mark the slot as failed. The slot failure time should be set to the current time. Proxy server gateway 20 should tear down all RTP sessions associated with the failed triplet and reset the client RTSP cookies. These cookies relate client RTSP sessions to the underlying RTP sessions that carry the requested programs.
vii. Proxy Server Error Handling
Each slot resource should maintain a watchdog counter. The counter is reset to a predefined number, such as 3, when the corresponding triplet status is received from a streamer gateway 10. If the streamer gateway 10 does not acknowledge a triplet previously added by the proxy server gateway 20, the counter is decremented. When it reaches zero, the slot has timed out and the following action should be taken:
If proxy server gateway 20 receives a triplet status message containing an unknown triplet, proxy server gateway 20 should send a SessionDelete message indicating that the session will be deleted to the streamer gateway 10 containing the unknown triplet along with a predefined destination IP address, such as 255.255.255.255. The streamer gateway 10 should tear down all RTP sessions associated with this triplet and free the tuner resource.
Static Tuning Support
Static tuning is a troubleshooting mode used to validate satellite cable feeds and/or tuner operation. Except for slot type (static/dynamic) and triplet status, proxy server gateway 20 should not manage or track streamer gateway 10 tuner allocation, either static or dynamic.
Static tuners are indicated in the streamer gateway 10 status response messages (St: S1 to St: S32). If the streamer gateway 10 cannot move the existing (dynamic) RTP sessions to a free tuner, the streamer gateway 10 will indicate a dynamic tuner failure (St: D0) for the existing triplet and proxy server gateway 20 should send a teardown to the streamer gateway 10. Video glitches seen on RTP sessions associated with static tuning changes should be acceptable.
Streamer Gateway 10 SAP Announcer
Streamer gateway 10 network announcements should be sent to predefined local bus multicast group, such as 239.255.255.255 port 19875. The following streamer gateway 10 SAP announcement features may be needed to support load balancing.
SDP Session Bandwidth
Streamer announcements should provide the following new SDP session bandwidth attributes:
The set point and maximum load information is set by MIB elements mxuStreamerConfigMaxLoad and mxuStreamerConfigLoadSetpoint.
SDP Session Connection Information
Since streamer media connection information (c) is actually set on a to per-streamer basis and not on a per-network basis, the network SAP announcement SDP media attribute connection information (c) should be a single SDP session attribute. The multicast start and range information is by MIB elements mxuIpServicesAddrMcastStart and mxuIpServicesAddrMcastEnd.
SDP Media Information X-dsfe-count
Announcements should indicate supported networks and number of tuners for a given polarization setting. The network SAP announcement SDP media attribute X-dsfe-count should be as follows:
A streamer gateway 10 is configured for (NW 0 L, NW 15 L+R, and NW 1H) as follows:
The corresponding SAP announcement is as follows:
Session Announcement Protocol
Session Description Protocol
An LCI streamer gateway 10 capable of 10 GBPS (8000 MBPS usable) is located at IP address 10.0.30.3 is configured for network FFFE (=65534 decimal) as follows:
NW FFFE: 4 local channels are available, plus a program guide channel. The streamer gateway 10 uses base multicast IP address 239.255.100.0.
The corresponding SAP announcement is as follows:
Session Announcement Protocol
Session Description Protocol
Dynamic Announcements
Streamer gateways 10 could periodically update their SAP announcement content to incorporate failed tuner information or changes in the bandwidth set point. Proxy server gateway 20 would update its database accordingly.
Gateway Reboot Scenarios
Gateway reboots fall into three categories:
The latter two cases are of interest as follows:
Streamer-Only Reboot
Proxy server gateway 20 should use the kRtspStreamerFailed and kRtspNewStreamerDetected messages to indicate streamer gateway 10 failure and/or reboot. Failed streamer gateways 10 should be removed from the streamer database and the data load redistributed across remaining streamer gateways 10. Likewise, newly operational streamers should be seamlessly added to the database and over time the video load is redistributed across the streamer gateway 10 population.
Proxy Server-Only Reboot
It is a design goal to minimize video disruption due to a proxy server gateway 20 reboot. The proxy server gateway 20 boot sequence is as follows:
Following boot up, proxy server gateway 20 should request streamer triplet and RTP session status from all known streamer gateways 10. It must reconstruct its database prior to processing any client RTSP requests.
The proxy server boot sequence can be as follows:
Local Content Insertion
The LCI (local content insertion) streamer gateway(s) 10 should be one or more standalone PCs and/or dumb IP cameras. Client setup requests for any network that contains a reserved PID (0xFFO-0xFFF) bypass the normal RTSP proxy server/streamer operation. Proxy server gateway 20 should determine the multicast group offset based on the requested PID and transponder number. Each streamer gateway 10 (one PID reserved for each) could support up to 16 channels (multicast groups), one per transponder frequency setting.
Dumb IP Camera
Proxy server gateway 20 should provide a separate application module, if enabled, to generate and stream the local content program guide. This application should also generate a network FFFE SAP announcement on the local bus to indicate the local content base multicast IP address. The SAP announcement connection information indicates the local content base multicast IP address for all streamer gateways 10. It could also indicate the number of available local channels.
PC streamer gateway 10
PC streamer gateways 10 will generate their own streamer SAP announcements for network FFFE. They will also generate a minimal program guide on one or more multicast groups within the streamer multicast range.
Exemplary Classes (Proxy Server Gateway 20)
RtspStreamerMedia Class
One instance is created per network.
Private Data:
Streamer Gateway 10 Class
One instance is created per streamer gateway 10.
Private Data:
ProxyRtspDsfeMedia Class
One instance is created per streamer gateway 10 per network.
Private Data:
TripletMediaCookie Class
One instance is created per client RTSP session and stored in the RtspServerConnection instance.
Private Data:
Slot Class
One instance is created per streamer gateway 10 triplet.
Private Data:
TripletRtpSession Class
One instance is created per streamer RTP session and is stored in a streamer Slot list.
Private Data:
AppTimer Class
One instance is created per streamer gateway 10.
Private Data:
SAPAnnouncement Class
One instance is created per detected streamer gateway 10.
Private Data:
Proxy server gateway 20 must implement a SAP listener module. This module sends the following new message types to the proxy RTSP server module:
As described earlier the proxy RTSP server module must use the new Streamer, RtspStreamerMedia, and ProxyRtspDsfeMedia classes instead of the 1.x RtspDsfeMedia class.
When streamer gateway 10 and proxy server gateway 10 reside within the same gateway chassis, the proxy server gateway 20 initialization code is independent of the streamer gateway 10 initialization code.
The proxy server module should return RTSP statistics and issue RTSP SetupParseError (indicating parsing errors) and ServerTerminatedSession (indicating session termination) traps. DsfeAllocationError and McastAllocationError traps should be handled by the streamer gateway 10's RTP library 12 (see
2. Streamer Gateway 10
Each streamer gateway 10 implements a module to monitor the local bus socket. This module generally emulates the RTSP stack as follows:
The RTP library interface module must be enhanced to return a triplet status code for use in responding to proxy server streamer status request messages. The streamer server initialization code should independent of the proxy RTSP server initialization code.
Exemplary Configuration Parameters
The following configuration file/SNMP MIB parameters are checked at boot time to configure the gateways.
If mxuRtspServerConfigProxyEnable is true, the proxy RTSP server module is started. If false, configuration settings are ignored and also treated as false:
mxuNetworkAuditAdminEnabled
mxuRtspServerConfigStreamerCount is used by proxy server gateway 20 at boot time to indicate the expected number of streamer gateways 10 in the system. Proxy server gateway 20 will delay its aggregate network SAP announcement until it has received mxuRtspServerConfigStreamerCount unique SAP announcements, or, until a predefined interval, such as two minutes, have expired.
If mxuStreamerConfigStreamerEnable is true, the streamer gateway 10 SAP announcer is enabled. If false, the streamer gateway 10 SAP announcement is disabled, and the proxy server gateway 20 should not send new RTP session requests to that streamer gateway 10.
Exemplary APIs
These APIs are globally Accessible APIs.
bool is ProxyServer(void)
This function returns the boot state of configuration file parameter mxuRtspServerConfigProxyEnable.
bool is Streamer(void)
This function returns true if at boot time there are one or more active mxuRtspDsfeMediaConfigRowStatus configuration file entries. Additionally, at least one active mxuRtspSessionConfigRowStatus entry must exist.
Example usage: The SNMP agent will use this API to regulate MIB access to the RTSP server MIBs.
bool is ActiveStreamer(void)
This function returns true if both mxuStreamerConfigStreamerEnable and is Streamer( ) is true.
Example usage: Streamer gateway 10 will use this API to regulate SAP announcements.
According to the principles of the invention, proxy server gateway 20 should be able to support over 2000 client devices (e.g., STBs 35). The STB client request module should expose a UDP socket at a predefined port, such as port 554, to support UDP-based STB clients.
Referring now to
At step 510, proxy server gateway 20 receives a request signal from a client device STB 35. According to an exemplary embodiment, the request signal indicates a request that a particular program be downloaded (i.e., streamed) to the requesting client device STB 35.
At step 520, proxy server gateway 20 determines whether it needs to allocate a new tuner from streamer gateways 10 to accommodate the request received at step 510. For example, if one of the streamer gateways 10 is already tuning a signal source (e.g., transponder) that carries the requested program, a new tuner is not required. Alternatively, if one of the streamer gateways 10 is not already tuning a signal source that carries the requested program, a new tuner is required.
If the determination at step 520 is positive, process flow advances to step 530 where proxy server gateway 20 receives receiving respective load indicators from streamer gateways 10. According to an exemplary embodiment, the respective load indicators indicate respective percentages of load set points for streamer gateways 10. Step 530 is performed periodically so that proxy server gateway 20 can keep apprised of the current load indicators associated with each of the streamer gateways 10.
At step 540, proxy server gateway 20 selects one of the streamer gateways 10 according to the load indicators. According to an exemplary embodiment, proxy server gateway 20 selects at step 540 the streamer gateway 10 that has the lightest load according to the respective load indicators received at step 530.
At step 550, proxy server gateway 20 instructs the particular streamer gateway 10 selected at step 540 to transmit the program requested at step 510 to the requesting client device STB 35 at a particular destination address. From step 550, process flow advances to step 580 where proxy server gateway 20 returns the destination address to the requesting client device STB 35 so that it can receive the requested program which is being transmitted by the selected streamer gateway 10. According to an exemplary embodiment, the requesting client device STB 35 may already know the destination address prior to the execution of step 580. In this manner, step 580 may be performed to simply confirm the destination address to the requesting client device STB 35.
Referring back to step 520, if the determination at that step is negative (e.g., no need to allocate a new tuner), process flow advances to step 560 where proxy server gateway 20 determines if it needs to create or update an RTP session or program identifiers (PIDs). If the determination at step 560 is negative, this indicates that the program requested at step 510 is already being provided by one of the streamer gateways 10. Accordingly, in this case, process flow advances to step 580 where proxy server gateway 20 simply provides the applicable destination address to the requesting client device STB 35 so that it can receive the requested program which is already being transmitted by one of the streamer gateways 10.
Alternatively, if the determination at step 560 is positive, process flow advances to step 570 where proxy server gateway 20 selects the particular streamer gateway 10 having the existing tuned tuner (i.e., the streamer gateway 10 that is already tuning a signal source (e.g., transponder) that carries the requested program). From step 570, process flow advances to step 550 as previously described herein.
Referring now to
At step 610, streamer gateway 10 sends its load indication to proxy server gateway 20. According to an exemplary embodiment, each streamer gateway 10 performs step 610 on a periodic basis so that proxy server gateway 20 can keep apprised of the current load indicators associated with streamer gateways 10. As indicated above, the load indicator sent at step 610 indicates a percentage load associated with the particular streamer gateway 10.
At step 620, streamer gateway 10 receives a program request and a is destination address. According to an exemplary embodiment, streamer gateway 10 receives from proxy server device 20, data indicating a requested program and a destination address of a client device STB 35 associated with the requested program. Also according to an exemplary embodiment, step 620 is performed in response to proxy server device 20 determining that the streamer gateway 10 receiving the program request and destination address has a lowest load among the plurality of streamer gateways 10.
At step 630, streamer gateway 10 transmits the requested channel to the destination address. According to an exemplary embodiment, streamer gateway 10 transmits the requested program to the destination address of the requesting client device STB 35 and thereby enables a user at the client device STB 35 to listen to and/or view the requested program.
Referring now to
At step 710, STB 35 sends a request signal to proxy server gateway 20. According to an exemplary embodiment, the request signal indicates a request that a particular requested program be downloaded to the requesting client device STB 35.
At step 720, STB 35 receives a response message from proxy server gateway 20 and joins a multicast group indicated in the response message. That is, assuming that the requested program is already available on the network from one of the streamer gateways 10, the response message from to proxy server gateway 20 may include a multicast network address which can be used by the STB 35 to access the requested program.
At step 730, STB 35 receives the requested program via a streamer gateway 10 selected by proxy server gateway 20 using the multicast network address. According to an exemplary embodiment, the client device STB 35 receives the requested program via a streamer gateway 10 which has been selected by proxy server gateway 20 from among the plurality of streamer gateways 10 based on their respective load indicators. STB 35 then decodes and outputs the received program.
According to another exemplary embodiment, if one of the streamer gateways 10 is sending requested video data from a video source (e.g., television channel) using a unicast, proxy server gateway 20 may send a signal requesting the sending streamer gateway 10 to convert the unicast into a multicast, and may also send a multicast network address to a client device STB 35 requesting the video source so that the client device STB 35 can receive the video data from the video source using the multicast network address.
The principles of
A.1 RTP Session Messages
Session Messages consist of the following format. Each line ends with a <CR><LF>.
The request must include all fields. Order is not important. All fields are ASCII text.
SESSIONADD/Request
A.1.2 SessionAdd Response Message
The response must include all fields except for StatusReason, which is optional.
SESSIONADD/Response
A.1.3 SessionUpdate Request Message
The request should include triplet and destination address, and other dsfe/session fields that are to be updated. Order is not important.
SESSIONUPDATE/Request
A.1.4 SessionUpdate Response Message
The response must include all fields except for StatusReason, which is optional.
SESSIONUPDATE/Response
A.1.5 SessionDelete Request Message
The request identifies the triplet and destination address.
If the destination address is 255.255.255.255, the streamer gateway 10 must delete all RTP sessions associated with the requested triplet and free the tuner resource.
If the triplet value is 0xFFFFFFFF and the destination address is 255.255.255.255, the streamer gateway 10 must delete all RTP sessions and free all triplets (tuner resources) on this streamer gateway 10.
SESSIONDELETE/Request
A.1.6 SessionDelete Response Message
The response must include all fields except for StatusReason, which is optional.
SESSIONDELETE/Response
A.2 Status Messages
Status Messages consist of the following format. Each line ends with a <CR><LF>.
The request identifies the fields of interest.
STREAMERSTATUS/Request
A.2.2 Streamer Status Response Message
The streamer gateway 10 will generate a response message that contains the requested loading statistic followed by an array of triplet status entries. The number of entries returned is specified by NumTriplets.
The triplet status (St) field is up to 3 characters as follows:
The streamer gateway 10 will never report a failed static tuner (St: S0). It will also keep trying to tune a static tuner. More than one tuner can be statically assigned to the same triplet setting. In this case the status field indicates how many tuners are using the triplet setting. When dynamic tuning, the status field must indicate either 1 (good) or 0 (failed) tuners.
An example status request response, assuming the streamer has 3 active triplets where one of them is statically tuned:
STREAMERSTATUS/Response
The largest message response occurs when the streamer reports status on 32 unique triplets.
A.2.3 Session Status Request Message
The message must include media path value, triplet value and at least one additional request field.
SESSIONSTATUS/Request
A.2.4 Session Status Response Message
The fields requested in the session status request message must be included in the response message. All sessions for the requested triplet are sent in one response message. The number of sessions returned is specified by NumSessions. Sessions are 3-tuples grouped as (PIDs, destination address, destination port.) Also note that A3 parameter request fields (alpha, pilot, gold-code, amc-mode, & pls) are returned only if the triplet refers to a tuner in A3 mode.
SESSIONSTATUS/Response
An example session request response, assuming a legacy tuner and the streamer has 3 active sessions:
SESSIONSTATUS/Response
A.1 Rain Fade
A.1.1 Some Tuners Affected
If a streamer gateway 10 detects a tuner unlock and free tuners are available, the streamer gateway 10 will move the RTP sessions to a free tuner in that chassis. Proxy server gateway 20 will not need to have knowledge of the movement. If no free tuners are available in that chassis or if they are all tried and fail, the streamer will indicate the triplet failure in the next STREAMERSTATUS response message. Once the streamer gateway 10 indicates failure, it must stop trying to move the session. Once a streamer gateway 10 has indicated triplet tune failure, proxy server gateway 20 will redirect the triplet to another streamer.
A.1.2 All Tuners Affected
It is possible that all tuners unlock in a rain fade. This could happen across all streamer gateways 10. Based on STREAMERSTATUS response the proxy server gateway 20 will mark a streamer gateway 10's triplet (slot) as error and update the slot time to the current time. If no slots are free across streamers the proxy will forward the new setup requests to the streamer gateway 10 with the oldest error slot. If proxy server gateway 20 tries all error slots yet STREAMERSTATUS continues to indicate failure, proxy server gateway 20 could send a 503: Service Unavailable message to the client device (e.g., STB 35). Current STB software does not alter its behavior upon reception of a 503: ServiceUnavailable response. Until it does, this proposed operation adds no value.
A.2 Static Tuning Failure
If a statically tuned tuner can not lock or loses lock, the streamer will NOT indicate a St: S0 failure in the STREAMERSTATUS response message. The streamer will continue to indicate St: S1. The streamer must continue to try to recover the statically tuned tuner.
A.3 Proxy Server Reboot
During a proxy server gateway 20 reboot all client STB cookies are lost. Following reboot the proxy server gateway 20 will respond with a 454: Session Not Found to a STB that issues a Setup request containing a previous (and now unknown) RTSP session number. In actual operation however, this does not seem to be a problem: while the proxy server gateway 20 is down, the STB TCP connection is reset and the STB issues new setup requests not containing a RTSP session number.
Streamer Gateways 10:
As described herein, the present invention provides a method and apparatus for providing load balanced signal distribution to client devices in a network. While this invention has been described as having a preferred design, the present invention can be further modified within the spirit and scope of this disclosure. This application is therefore intended to cover any variations, uses, or adaptations of the invention using its general principles. Further, this application is intended to cover such departures from the present disclosure as come within known or customary practice in the art to which this invention pertains and which fall within the limits of the appended claims.
This application claims the benefit, under 35 U.S.C. §365 of International Application PCT/US2008/013640, filed Dec. 12, 2008, which was published in accordance with PCT Article 21(2) on Sep. 3, 2009 in English and which claims the benefit of United States provisional patent application No. 61/067585, filed Feb. 29, 2008.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US2008/013640 | 12/12/2008 | WO | 00 | 8/26/2010 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2009/108176 | 9/3/2009 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5761416 | Mandal et al. | Jun 1998 | A |
6195680 | Goldszmidt et al. | Feb 2001 | B1 |
6889385 | Rakib et al. | May 2005 | B1 |
7133922 | She et al. | Nov 2006 | B1 |
20030009761 | Miller et al. | Jan 2003 | A1 |
20030174648 | Wang et al. | Sep 2003 | A1 |
20030212784 | Nguyen | Nov 2003 | A1 |
20040261116 | Mckeown et al. | Dec 2004 | A1 |
20050039213 | Matarese et al. | Feb 2005 | A1 |
20050071882 | Rodriguez et al. | Mar 2005 | A1 |
20050250511 | Xiao et al. | Nov 2005 | A1 |
20050283818 | Zimmermann et al. | Dec 2005 | A1 |
20060035610 | Potrebic | Feb 2006 | A1 |
20070027017 | Hachitani | Feb 2007 | A1 |
20070027983 | Bowra et al. | Feb 2007 | A1 |
20070174287 | McEnroe et al. | Jul 2007 | A1 |
20090025042 | Lubbers et al. | Jan 2009 | A1 |
20090222875 | Cheng et al. | Sep 2009 | A1 |
20090235317 | Igarashi | Sep 2009 | A1 |
20100050215 | Wester et al. | Feb 2010 | A1 |
Number | Date | Country |
---|---|---|
101084682 | Dec 2007 | CN |
1619853 | Jan 2006 | EP |
20047592 | Jan 2004 | JP |
2004-80566 | Mar 2004 | JP |
2004158969 | Jun 2004 | JP |
2008508807 | Mar 2008 | JP |
2008510367 | Apr 2008 | JP |
2008-530830 | Aug 2008 | JP |
2008536419 | Sep 2008 | JP |
2009503680 | Jan 2009 | JP |
2009-520421 | May 2009 | JP |
2009524346 | Jun 2009 | JP |
WO0122688 | Mar 2001 | WO |
2005002062 | Jan 2005 | WO |
2005020621 | Mar 2005 | WO |
WO2006015186 | Feb 2006 | WO |
2006137894 | Dec 2006 | WO |
2007071560 | Jun 2007 | WO |
Entry |
---|
International Search Report, dated Mar. 23, 2009. |
Number | Date | Country | |
---|---|---|---|
20100333150 A1 | Dec 2010 | US |
Number | Date | Country | |
---|---|---|---|
61067585 | Feb 2008 | US |