The present invention is related to the following co-pending U.S. applications:
MULTIMEDIA INFORMATION COMPUTER SYSTEM AND METHOD OF OPERATION OF A PLAYLIST SCHEDULER, Ser. No. 09/420,802, filed on Oct. 19, 1999, and assigned to the assignee of the present invention; METHOD AND SYSTEM FOR OPTIMIZATION OF DISTRIBUTION TO REDUCE STORAGE REQUIREMENTS IN A DIGITAL MEDIA DISTRIBUTOR, Ser. No. 09/524,082, assigned to the assignee of the present invention; METHOD AND SYSTEM FOR OBJECT RETRANSMISSION WITHOUT A CONTINUOUS NETWORK CONNECTION IN A DIGITAL MEDIA DISTRIBUTION SYSTEM, Ser. No. 09/773,047, as signed to the assignee of the present invention; and METHOD AND SYSTEM FOR ENSURING RELIABLE PLAYOUT IN A DMD SYSTEM, Ser. No. 09/523,827, assigned to the assignee of the present invention.
The present invention relates to digital media distribution and more particularly to web file server synchronization between a central site and remote sites.
Although broadcasters have sophisticated systems for inserting national commercials into a program stream, including integrated traffic and billing systems, there are numerous obstacles to implementing a system to insert local commercials at small markets into a national program feed distributed by satellite. Until now, such local spot insertion advertising was the responsibility of the local broadcaster or cable operator.
Inserting local advertising poses several non-trivial technical, logistical and business challenges. First, literally hundreds of widely distributed local operators (or affiliates) would need to receive the commercials. Ad agencies would then have to ship analog tapes to hundreds of organizations, with different traffic and billing systems. The analog tapes would need to be tested for quality assurance, tracked, and stored until needed. The tapes would then have to be distributed to video tape recorders and readied for computer controlled playout (analog) at the proper time, 24 hours a day, seven days a week. Such infrastructure generally exists at well-funded affiliates in major markets but is nonexistent and prohibitively expensive for smaller operators or affiliates in small markets.
Managing such tapes with ads for local commercials and inserting them properly into the program feed is a complex undertaking not well-suited for the smaller operators, especially for channels with smaller audiences in smaller markets. A quality broadcast involves more than excellent program material; it must also provide seamless insertion of national and local advertisements, promotions, and station identifications.
Equally important is the ability to maintain the integrity of the national television programming. Centralized control of the channel's programming (playout) is required to prevent local affiliates from tampering with the programming. In addition, it is important that there be synchronization between a plurality of remote sites and the centralized control to ensure that information is provided to each of the remote sites in a timely and efficient manner.
Typically each remote site will have their own file system, they will deposit their web content onto the central site server under their file system. The requirement is to deliver only the new or updated files to the remote sites and maintain the same directory structure. The remote site and central site file system must be in synch. If a remote site is down or unoperational for a number of days, central site must resend the latest copy (there could be multiple updates to the same file while the remote site is down) of the file(s) again once the remote site comes alive. In other words, a central site must know what's missing on the remote sites and be intelligent enough to send the missing or out-dated files.
Accordingly, a need exists for an efficient system for optimized distribution of digital media data to remote sites in a multimedia broadcast system from the central site. The present invention addresses such a need.
A method and system of synchronizing files between a central site and a plurality of remote sites is disclosed. The method and system comprises providing a list of files to the plurality of remote sites by the central site, prior to a callback time of the remote sites and reporting which of the files are missing by each of the plurality of remote sites to the central site. The method and system further includes determining within the central site which of the files needs to be sent to each of the plurality of remote sites.
Accordingly, a system and method in accordance with the present invention helps deliver content from a central site to multiple remote sites. A system and method in accordance with the present invention uses the DMD in conjunction with a software client described below to maintain the file synchronization between the central server and remote site servers.
The present invention relates to digital media distribution and more particularly to web file server synchronization between a central site and a plurality of remote sites. The following description is presented to enable one of ordinary skill in the art to make and use the invention and is provided in the context of a patent application and its requirements. Various modifications to the preferred embodiment and the generic principles and features described herein will be readily apparent to those skilled in the art. Thus, the present invention is not intended to be limited to the embodiment shown but is to be accorded the widest scope consistent with the principles and features described herein.
A block diagram of a DMD (digital media distributor) in accordance with the present invention is illustrated in
The remote site(s) 14 house the remote site server(s) 16. By way of example, a suitable remote site server 16 includes a Pentium processor-based device with a hard disk for local storage and a video switch card (to switch between program and commercial insertion) running software including Windows NT, DMD programming, Lotus Notes client, Program Loader, and Symantec pcANYWHERE. These unattended, computerized systems receive the local insertion and provide As-Run file generation. The remote site server 16 is a video server that receives and stores digitized spots utilized for local insertion at the cable head-end. The remote site server 16 receives digitally encoded ads via satellite or other distribution network. These spots are decoded to an analog signal and inserted into the cable or network operator feed at scheduled times, i.e., into scheduled local availability times. The remote site server 16 can be customized in various configurations based on the number of output channels required, the type of output format (e.g., NTSC, PAL), the amount of local storage required (i.e., the number of spots on disk), the type of network (satellite or terrestrial), the type of trigger for spot insertion (e.g., time of day, VITC, cue-tome, VBI trigger), the audio format and connections (stereo, mini-XLR or XLR), the redundancy requirements (RAID, mirrored disks), and the preview channel.
By way of example, the following provides a sample process that illustrates an example of one process which the DMD solution can support. A region, e.g., any grouping of one or many cable head-ends for cities, states, provinces, or countries, defined by cable or network operators in an area, sells a commercial in the local availability time. All remote site servers 16 within the same region play the same material at the same time, including all network programs, national spots, local commercials, announcements, etc. The videotaped segment for the commercial is digitally encoded. The digital material is scheduled for delivery to each remote site server 16 prior to broadcast. The playlist, digitized spots, and the broadcast program stream are sent, via satellite, to all of the remote site servers 16 within the region. All of the remote site servers 16 within the region air the local spots for that region at the scheduled time. As-Run logs are retrieved by the central site 10 from the remote site servers 16. As-Run logs are sent to the local markets, reviewed, reconciled, and customers are billed. Commercials and As-Run logs are archived.
In accordance with the present invention, the central site 10 efficiently distributes objects and thus manages the resources of the remote site 14. By managing these resources, the central site 10 can determine when to send information to the remote site(s) 14. A main component in producing the management of the resources is the central site server 18. By way of example, a suitable central site server 18 includes an IBM RS/6000 F50 dual CPU system or a Pentium II compatible PC, running the IBM UNIX operating system, AIX, DB2 server software, Lotus Notes server software, ADSM, Windows NT (for PC-based central site server), and the DMD programming. Suitable components for the control workstations 19 include Pentium compatible PCs running Windows NT, Lotus Notes client, DB2 client, Microsoft Internet Explorer, and DMD programming.
The central site server 18 includes software on a suitable computer readable medium that is architected using a layered model, in which each layer isolates the upper layers from the details of the lower layers and individual components within a layer provide a unique set of services, as is well appreciated by those skilled in the art.
Underneath the top layer is a layer 24 of specialized components including a stage manager component 26, an uplink server component 28, and a transmission scheduler component 30. This layer 24 may also include specialized components for creating commands and interpreting responses from SIBs, managing access to all the database queues and other data stores, and providing automated agents that run based on time or events to manage the external interfaces, e.g., processing files received from traffic systems. The stage manager 26 manages any tape related activity, the uplink server 28 manages transmissions through the uplink network (12,
Also included as a next layer is a programming layer 32. The layer 32 includes the programming libraries and APIs (application programming interfaces) that are used to build the specialized components. The lower two layers include an operating system layer 34 and a hardware layer 36 for the fundamental operation of the central site server 18, as is well appreciated by those skilled in the art.
There are two entities at the central site 10 that are utilized in accordance with the present invention for synchronizing the files of the central site 10 with the files of the plurality of remote sites 14, a file system synchronization (FSS) helper application 25 and an automated central site operations (ACSO) mechanism 27. Each of the remote sites 14 has an entity referred to as the FSS remote site operations (FSS RSO) mechanism 29.
A system and method in accordance with the present invention makes possible one way synchronization between a central site 10 and a plurality of remote sites 14. Additionally, using the system and method in accordance with the present invention, all remote sites 14 which subscribe to the same file system can be grouped and connected back to the central site 10 at the same time. Callback time can be programmed in the remote site application. At a predetermined, configurable period of time, such as five minutes before the callback time, the central site server prepares the latest loadlist for that group and sends it to the remote sites 14, thus giving remote sites 14 enough time to prepare for the “missing file list” and determine which files can be deleted from the remote site server 16.
In a preferred embodiment, the time is synchronized between central site 10 and remote sites 16. This is important because the time is used to determine the call back time and when the loadlist is generated on the central site. Time synchronization can be performed either by installing GPS clocks at the central site and all remote sites or by using time synchronization programs, such as NTP time server, W32Time from Microsoft Windows Resource Kit.
The central site 10 waits for the remote sites 14 to callback and report which files are missing. The central site 10 will wait until timeout (five minutes, for example, after the scheduled callback). After the remote sites 14 in the same group call back and deposit their “missing file list”, the central site server will consolidate the list and determine if any files can be multicasted to multiple remote sites 14. The central site 10 can support multiple groups by partitioning the central site server into multiple file systems.
Accordingly, a system and method in accordance with the present invention helps deliver content from a central site to multiple remote sites. A system and method in accordance with the present invention uses the DMD in conjunction with a software client described below to maintain the file synchronization between the central server and remote site servers. To describe the features of the present invention in more detail, refer now to the following discussion in conjunction with the accompanying figure.
DMD-Integrated File System Synchronization
A method and system in accordance with the present invention ensures that the desired files in a specified file system are available on a remote site or sites 14 in the same file. Referring back to
A remote site 14 may not receive files, for example, during power outages or bad weather. The central site 10, however, automatically keeps a master inventory of files as specified in a monitored file system for which there is a parallel file system at every remote site 14. Each of the remote sites 14 are configured to report back to the central site 10 at a pre-defined time, based on a callback scheduling algorithm. These report back periods are used to provide, among other data, information about the files that a remote site 14 will need. In so doing, the remote sites 14 save the most reliable information therewithin.
All remote sites 14 can be synchronized according to a central site's file system (or web server). A loadlist, which consists of file name, file path, file size, and timestamp of the file, is generated by the central site server and sent over to the remote sites 14. Each of the remote site servers 16 uses the latest loadlist to compare with the previously executed loadlist and then determines the files needed to be downloaded from the central site 10. The files can be deleted from the remote site 14. Filename, file path, file size, and the timestamp of the two loadlists are compared to determine new or updated files which need to be downloaded, and which files can be removed from the remote site's 14 local directory. The new or updated file list, which is called “missing file list”, is then sent from the remote site 14 back to the central site 10.
The central site 10 uses the “missing file list” from remote sites 14 and transmits the files to the remote site 14. The remote site 14 receives the “missing files” and uses the information in the loadlist (the file path field) to move the files to the proper directory.
To describe the present invention in more detail, refer now to the following discussion in conjunction with the accompanying figure.
Referring now to
In a preferred embodiment, the FSS helper 25 application, also running on an NT platform, prepares the list of the files in the file system (loadlist file), including the fall paths (directory structures), and the date-time stamp for each file. The loadlist file is date-time stamped and then transferred to the remote sites 14 ahead of the scheduled report back time, via step 304. The ACSO mechanism 27 then schedules the loadlist in a transmission queue within the DMD, via step 306. Next, the ACSO mechanism 27 transmits the loadlist to remote sites 14 ahead of the scheduled return time, via step 308.
Upon receiving the loadlist, the FSS RSO mechanism 29 compares the new loadlist against the last copy of the loadlist to create a list of files it will need, via step 310. These files may have changed, as evidenced by comparison of the date-time stamp of the files in the loadlist. The FSS RSO mechanism 29 then compares the list of needed files with an inventory of files that are to be found locally, via step 312, and builds a report of files “needed” for file system synchronization, via step 314.
The remote sites 14 then report back to the central site 10 upon a pre-defined schedule with the list of needed FSS files, via step 316. Once communications have been re-established, the central site 10 automatically begins the synchronization process, via step 318, and sends both additional files (and may also send commands) as needed, via step 320. If, for example, a remote site 14 has gone down for four days, it will make its comparisons with the last good “loadlist” and current inventory, and will report the list of needed FSS files based only on the latest information.
Additionally, the remote site 14 will send to the central site 10 a list of all the files that were delivered since the last report back to the central site 10, also via step 316. The ACSO mechanism 27 will then compare the list of delivered files with the list of files that the central site 10 believes the remote site 14 should have, and calculates a list of files that should have been delivered but are “missing” (i.e., the delivered files missing log), via step 322. The ACSO mechanism 27 will then add these missing files to the distribution list for this receiver.
The reports of needed FSS files, and lists of missing “delivered” files from earlier distribution requests, are handed off to the ACSO mechanism 27, which automatically determines which remote sites 14 share a need for the same files, and then optimizes the distribution of those files for multicasting to various groups of remote sites 14, via step 324.
Through the use of the “Needed FSS files” as well as the delivered log-based calculations for missing files, files do not need to be transferred that were perhaps once needed for synchronization purposes, but that are no longer needed (such as transient news stories which may have been replaced by updated accounts). A system and method in accordance with the present invention helps ensure that the unneeded files are not transferred while keeping remote site 14 content up-to-date. For example, if a remote site 14 were to go down on the third day of operation, and not return to service until the day six, files would not be automatically transferred that had been needed for days 4 and 5 unless they were specified as needed on day 6.
The ACSO mechanism 27 then transfers the files much as any other DMD transmission object to the plurality of remote sites 14, via step 326.
Upon receiving the files, the FSS RSO mechanism 29 interrogates its last known loadlist, which contains fall path information for every file in the NT file system, to determine the final location (i.e., directory) of the file, via step 328, and then moves the file to that directory, via step 330.
The system and method in accordance with the present invention has the following advantages over conventional systems:
1. The system and method is simple and scaleable. The central site 10 only needs to know the loadlist of its own server. No keeping track of each remote site “history file” is required. Work is distributed to each remote site 14. A remote site 14 uses the most recent loadlist and the previously executed loadlist to determine what needs to be transmitted from central site 10 and will send a request to central site 10 via a “missing file list”. When there are hundreds of thousands of remote sites 14 trying to connect back to the central site and sync the file system, figuring out who needs what requires a lot of computation time if all the work is done by the central site is a complex task.
2. The system and method operates automatically. The user does not need to be prompted to select the more current data.
Although the present invention has been described in accordance with the embodiments shown, one of ordinary skill in the art will readily recognize that there could be variations to the embodiments and those variations would be within the spirit and scope of the present invention. Accordingly, many modifications may be made by one of ordinary skill in the art without departing from the spirit and scope of the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
4724491 | Lambert | Feb 1988 | A |
4862268 | Campbell et al. | Aug 1989 | A |
5029014 | Lindstrom | Jul 1991 | A |
5055924 | Skutta | Oct 1991 | A |
5058096 | Ando et al. | Oct 1991 | A |
5099319 | Esch et al. | Mar 1992 | A |
5197047 | Witheridge et al. | Mar 1993 | A |
5216515 | Steele et al. | Jun 1993 | A |
5237682 | Bendert et al. | Aug 1993 | A |
5319648 | Bux et al. | Jun 1994 | A |
5345594 | Tsuda | Sep 1994 | A |
5392066 | Fisher et al. | Feb 1995 | A |
5412416 | Nemirofsky | May 1995 | A |
5424770 | Schmelzer et al. | Jun 1995 | A |
5428732 | Hancock et al. | Jun 1995 | A |
5432542 | Thibadeau et al. | Jul 1995 | A |
5442771 | Filepp et al. | Aug 1995 | A |
5450122 | Keene | Sep 1995 | A |
5463771 | Sotoyanagi et al. | Oct 1995 | A |
5485219 | Woo | Jan 1996 | A |
5493677 | Balogh et al. | Feb 1996 | A |
5495608 | Antoshenkov | Feb 1996 | A |
5499046 | Schiller et al. | Mar 1996 | A |
5515098 | Carles | May 1996 | A |
5532939 | Psinakis et al. | Jul 1996 | A |
5550863 | Yurt et al. | Aug 1996 | A |
5583561 | Baker et al. | Dec 1996 | A |
5584050 | Lyons | Dec 1996 | A |
5594490 | Dawson et al. | Jan 1997 | A |
5600366 | Schulman | Feb 1997 | A |
5600573 | Hendricks et al. | Feb 1997 | A |
5652613 | Lazarus et al. | Jul 1997 | A |
5659351 | Huber | Aug 1997 | A |
5666645 | Thomas et al. | Sep 1997 | A |
5726909 | Krikorian | Mar 1998 | A |
5727002 | Miller et al. | Mar 1998 | A |
5729735 | Meyering | Mar 1998 | A |
5745756 | Henley | Apr 1998 | A |
5758150 | Bell et al. | May 1998 | A |
5758345 | Wang | May 1998 | A |
5761432 | Bergholm et al. | Jun 1998 | A |
5809235 | Sharma et al. | Sep 1998 | A |
5826165 | Echeita et al. | Oct 1998 | A |
5835911 | Nakagawa et al. | Nov 1998 | A |
5857181 | Augenbraun | Jan 1999 | A |
5887243 | Harvey et al. | Mar 1999 | A |
5892535 | Allen et al. | Apr 1999 | A |
5907494 | Dangelo et al. | May 1999 | A |
5913039 | Nakamura et al. | Jun 1999 | A |
5920700 | Gordon et al. | Jul 1999 | A |
5956716 | Kenner et al. | Sep 1999 | A |
5960406 | Rasansky et al. | Sep 1999 | A |
5990884 | Douma et al. | Nov 1999 | A |
5990927 | Hendricks et al. | Nov 1999 | A |
5996025 | Day et al. | Nov 1999 | A |
6005534 | Hylin et al. | Dec 1999 | A |
6011758 | Dockes et al. | Jan 2000 | A |
6029045 | Picco et al. | Feb 2000 | A |
6034678 | Hoarty et al. | Mar 2000 | A |
6035323 | Narayen et al. | Mar 2000 | A |
6044381 | Boothby et al. | Mar 2000 | A |
6058422 | Ayanoglu | May 2000 | A |
6061683 | Alonso | May 2000 | A |
6088796 | Cianfrocca et al. | Jul 2000 | A |
6094680 | Hokanson | Jul 2000 | A |
6144999 | Khalidi et al. | Nov 2000 | A |
6151598 | Shaw et al. | Nov 2000 | A |
6170005 | Meandzija | Jan 2001 | B1 |
6185573 | Angelucci et al. | Feb 2001 | B1 |
6192363 | Yasumura | Feb 2001 | B1 |
6192410 | Miller et al. | Feb 2001 | B1 |
6212560 | Fairchild | Apr 2001 | B1 |
6222530 | Sequeira | Apr 2001 | B1 |
6253079 | Valentine et al. | Jun 2001 | B1 |
6256673 | Gayman | Jul 2001 | B1 |
6279157 | Takasu | Aug 2001 | B1 |
6298385 | Sparks et al. | Oct 2001 | B1 |
6330613 | Vlajnic et al. | Dec 2001 | B1 |
6336115 | Tominaga et al. | Jan 2002 | B1 |
6353831 | Gustman | Mar 2002 | B1 |
6370550 | Douma et al. | Apr 2002 | B1 |
6378036 | Lerman et al. | Apr 2002 | B2 |
6378129 | Zetts | Apr 2002 | B1 |
6385596 | Wiser et al. | May 2002 | B1 |
6405317 | Flenley et al. | Jun 2002 | B1 |
6411685 | O'Neal | Jun 2002 | B1 |
6412009 | Erickson et al. | Jun 2002 | B1 |
6434621 | Pezzillo et al. | Aug 2002 | B1 |
6434680 | Belknap et al. | Aug 2002 | B2 |
6438125 | Brothers | Aug 2002 | B1 |
6446108 | Rosenberg et al. | Sep 2002 | B1 |
6463585 | Hendricks et al. | Oct 2002 | B1 |
6466734 | Yuen et al. | Oct 2002 | B2 |
6473902 | Noritomi | Oct 2002 | B1 |
6487721 | Safadi | Nov 2002 | B1 |
6510558 | Linuma et al. | Jan 2003 | B1 |
6513069 | Abato et al. | Jan 2003 | B1 |
6526575 | McCoy et al. | Feb 2003 | B1 |
6535878 | Guedalia et al. | Mar 2003 | B1 |
6571391 | Acharya et al. | May 2003 | B1 |
6581076 | Ching et al. | Jun 2003 | B1 |
6647417 | Hunter et al. | Nov 2003 | B1 |
6687737 | Landsman et al. | Feb 2004 | B2 |
6698020 | Zigmond et al. | Feb 2004 | B1 |
6718425 | Pajakowski et al. | Apr 2004 | B1 |
6763523 | Sacilotto et al. | Jul 2004 | B1 |
6792615 | Rowe et al. | Sep 2004 | B1 |
6799326 | Boylan et al. | Sep 2004 | B2 |
6810527 | Conrad et al. | Oct 2004 | B1 |
7039930 | Goodman et al. | May 2006 | B1 |
7260785 | Ching et al. | Aug 2007 | B2 |
20020004936 | Aras | Jan 2002 | A1 |
20020016831 | Peled et al. | Feb 2002 | A1 |
20020077984 | Ireton | Jun 2002 | A1 |
20020092019 | Marcus | Jul 2002 | A1 |
20040210932 | Mori et al. | Oct 2004 | A1 |
20080059997 | Plotnick et al. | Mar 2008 | A1 |
Number | Date | Country |
---|---|---|
WO9608923 | Mar 1996 | WO |
Number | Date | Country | |
---|---|---|---|
20020111959 A1 | Aug 2002 | US |