A method and system utilizing one or more data generating computing devices as default data warehouses in the event of a primary data warehouse failure are provided. A data warehouse provides an environment in which data from one or more data servers in one or more locations, or premises, is aggregated in a central database. In the event of a system failure, in which communication between the data warehouse and one or more servers is disrupted, a warehouse ticket file, stored on secure, distributed ticket servers, is used to identify and initialize at least one of the data servers as a failover data warehouse. Once communication between the premises and its primary data warehouse is restored, the data collected during the failover is transferred to the primary data warehouse and purged from the failover data warehouse.
|
0. 35. A method for providing fault tolerant data warehousing, the method comprising:
obtaining an indication that a primary data warehouse is inoperable to receive data from a first premises server;
identifying an alternate data warehouse to receive the data;
transmitting information identifying the alternate data warehouse to the first premises server, wherein:
if the primary data warehouse is inoperable to receive data, the first premises server attempts to establish contact with and transmit data to the identified alternate data warehouse; and
if the primary data warehouse is subsequently available to receive data, the first premises server transmits data to the primary data warehouse; and suspends data transmission to the alternate data warehouse.
0. 31. In a data collection and processing system including two or more premises servers for collecting data and transmitting the data to a primary data warehouse, a method for providing fault tolerant data warehousing, the method comprising:
obtaining information identifying an alternate data warehouse to receive a set of data when a primary data warehouse is inoperable to receive the set of data;
transmitting the set of data to the identified alternate data warehouse;
wherein the alternate data warehouse is selected from the two or more premises servers;
obtaining an indication that the primary data warehouse can receive data;
transmitting data to the primary data warehouse upon obtaining the indication; and
suspending data transmission to the alternate data warehouse.
1. In a data collection and processing system including two or more premises servers for collecting data and transmitting the data to a primary data warehouse, a method for providing fault tolerant data warehousing, the method comprising:
obtaining a set of data to be transmitted to a primary data warehouse;
obtaining an indication that the primary data warehouse is inoperable to receive the set of data;
obtaining information identifying an alternate data warehouse to receive the set of data; and
transmitting the set of data to the identified alternate data warehouse;
wherein the alternate data warehouse is selected from the two or more premises servers;
obtaining an indication that the primary data warehouse can receive data;
transmitting data to the primary data warehouse upon obtaining the indication; and
suspending data transmission to the alternate data warehouse.
0. 33. In a data collection and processing system including two or more premises servers for collecting data and transmitting the data to a primary data warehouse, a method for providing fault tolerant data warehousing, the method comprising:
suspending transmission of data between a premises server and a primary data warehouse when the primary data warehouse is inoperable to receive data from the premises server;
accessing a database associated with the premises server to obtain an identification of an alternate data warehouse associated with the premises server;
transmitting premises data to the alternate data warehouse;
wherein the alternate data warehouse is selected from the two or more premises servers;
obtaining an indication that the primary data warehouse can receive data;
transmitting data to the primary data warehouse upon obtaining the indication; and;
suspending data transmission to the alternate data warehouse.
24. A system for providing fault tolerant data warehousing comprising:
two or more premises servers in communication with a number of data generating devices, wherein the premises servers transmit collected data for storage;
a primary data warehouse for receiving the collected data from transmitted by the premises servers;
a database server in communication with the premises server for:
providing an identification of an alternate data warehouse upon a failure of the primary data warehouse;
causing data to be transmitted to the alternate data warehouse upon providing the identification of the failure;
providing an identification that the primary data warehouse can receive data;
suspending data transmission to the alternate data warehouse upon the identification that the primary data warehouse can receive data;
causing data to be transmitted to the primary data warehouse; and
wherein the alternate data warehouse is selected from the two or more premises servers.
12. In a data collection and processing system including two or more premises servers for collecting data and transmitting the data to a primary data warehouse, a method for providing fault tolerant data warehousing, the method comprising:
obtaining a set of data to be transmitted to a primary data warehouse;
obtaining an indication that the primary data warehouse is inoperable to receive the set of data;
accessing a database associated with a premises server to obtain an identification of an alternate data warehouse associated with the premises server;
suspending transmission of data between the premises server and the primary data warehouse;
transmitting premises data to the alternate data warehouse;
wherein the alternate data warehouse is selected from the two or more premises servers;
obtaining an indication that the primary data warehouse can receive data;
transmitting data to the primary data warehouse upon obtaining the indication; and
suspending data transmission to the alternate data warehouse.
2. The method as recited in
3. The method as recited in
transmitting a request to obtain an alternate data warehouse including one or more selection attributes; and
obtaining information identifying an alternate data warehouse based upon a processing of the selection attributes.
4. The method as recited in
5. The method as recited in
6. The method as recited in
7. The method as recited in
8. The method as recited in
9. The method as recited in
10. A computer-readable medium storage device having computer-executable instructions for performing the method recited in
11. A computer system having a processor, a memory and an operating environment, the computer system operable to perform the method recited in
13. The method as recited in
14. The method as recited in
transmitting a request to obtain an alternate data warehouse including one or more selection attributes; and
obtaining information identifying an alternate data warehouse based upon a processing of the selection attributes.
15. The method as recited in
16. The method as recited in
17. The method as recited in
18. The method as recited in
19. The method as recited in
20. The method as recited in
21. The method as recited in
22. A computer-readable medium storage device having computer-executable instructions for performing the method recited in
23. A computer system having a processor, a memory and an operating environment, the computer system operable to perform the method recited in
25. The system as recited in
26. The system as recited in
27. The system as recited in
28. The system as recited in
29. The system as recited in
30. The system as recited in
0. 32. A computer-readable storage device having stored thereon, computer-executable instructions that, if executed by a computing device, cause the computing device to perform the method of claim 31.
0. 34. A computer-readable storage device having stored thereon, computer-executable instructions that, if executed by a computing device, cause the computing device to perform the method of claim 33.
0. 36. A computer-readable storage device having stored thereon, computer-executable instructions that, if executed by a computing device, cause the computing device to perform the method of claim 35.
0. 37. The method of claim 35, wherein identifying an alternate data warehouse comprises obtaining a static file that includes a pre-assigned alternate data warehouse for the first premises server.
0. 38. The method of claim 35, wherein identifying an alternate data warehouse comprises obtaining a dynamically-generated warehouse ticket file that identifies the alternate data warehouse based upon at least one factor.
0. 39. The method of claim 38, wherein the at least one factor includes at least one of:
available memory resources at a plurality of potential alternate data warehouses; or
availability of a corresponding communication network.
0. 40. The method of claim 35, wherein the alternate data warehouse comprises a first alternate data warehouse, the method further comprising:
obtaining an indication that the first premises server is unable to establish contact with and transmit data to the identified first alternate data warehouse;
identifying a second alternate data warehouse to receive the data; and
transmitting information identifying the second alternate data warehouse to the first premises server.
0. 41. The method of claim 35, wherein the primary data warehouse is inoperable to receive data from the first premises server due to a system fault making the primary data warehouse inoperable to receive data from a subset of a plurality of premises servers, the method further comprising:
identifying a corresponding alternate data warehouse to receive data from each of the subset of the plurality of premises servers; and
transmitting information identifying the corresponding alternate data warehouse to each of the subset of the plurality of premises server.
|
This application claims the benefit of U.S. Provisional Application No. 60/371,273, entitled System and Method for Providing A Fault-Tolerant Data Warehouse Environment, and filed on Apr. 9, 2002. U.S. Provisional Application No. 60/371,273 is incorporated by reference herein.
The present invention relates generally to data storage systems, and in particular, to a method for providing fault-tolerant data warehousing.
Generally described, most corporate and governmental entities utilize computer systems, computer networks, and integrated devices that generate vast amounts of electronic data. In some cases, data is generated, processed, and discarded after serving an intended purpose. In other cases, corporate, governmental, or other entities require that data be stored and maintained for future use. Such storage methods and systems may be generically referred to as “archival.” Accordingly, many data generating users look for storage solutions that correspond to the type and amount of data to be archived.
A growing category of archival is known as data warehousing. Data warehousing refers to the various activities involved in the acquisition, management, and aggregation of data from various sources into a centralized repository, such as a database. The database may be hosted by one or more servers, at least some of which may be physically proximate. Additionally, the central data warehouse may be a virtualized central repository in which a number of distributed servers pool and share data. In a typical application, a data warehouse stores time-oriented data that may be gathered from disparate sources. Data warehousing may be distinguished from the broader category of data archival in that the data warehouse maintains the stored data in a static manner. Because warehoused data cannot be modified (only added to or deleted) it may be used for analysis over time or by type. The data warehouse may also include metadata used to organize and characterize the data. In addition to the ability to store and retrieve data, many database storage solutions also include some type of data restoration process or system that enable data recovery in the event of a hardware and/or software failure. This is generally referred to as storage recovery. One embodiment for storage recovery relates to “mirrored” storage solutions in which one or more identical, redundant data repositories are maintained to replicate, or mirror, the archived data contained in a primary repository. In the event some or all of the data is lost from the primary repository, one or more complete copies of the data exists in the mirrored storage repositories. Accordingly, mirrored storage solutions provide for data recovery in the event that the primary storage repository fails to replicate previously stored data. However, once the primary storage repository fails, the data warehouse cannot continue to collect new data. Accordingly, any new data transmitted to the data warehouse would be lost, or the data processing system may have to shut down.
One attempt to provide additional data warehouse fault tolerance, referred to generally as failover support, relates to the use of a clustered database to transfer data to an alternate collection point in the event of a primary repository failure. In accordance with this embodiment, a database is installed across two or more servers that are linked together, such that each server in the clustered database is logically viewed as a node on the network. To provide for true failover support, the server nodes do not share processing resources. Environments in which storage and processing resources are not shared between nodes are generally referred to as “shared nothing” architectures. Shared-nothing environments are better suited to large, complex databases supporting unpredictable queries, as in data warehousing. Although a shared-nothing environment potentially allows for continued data collection in the event of a failure, the costs involved in providing and maintaining multiple servers for storage redundancy are prohibitive for many potential users. Accordingly, a clustered database approach may not present an affordable solution for many data warehouse applications.
Therefore, there is a need for a resource-efficient, fault-tolerant solution for data warehousing that will provide continuity of the data warehouse function in the event of a network, hardware, or software failure.
A method and system utilizing one or more data generating computing devices as default data warehouses in the event of a primary data warehouse failure are provided. A data warehouse provides an environment in which data from one or more data servers in one or more locations, or premises, is aggregated in a central database. In the event of a system failure, in which communication between the data warehouse and one or more servers is disrupted, a warehouse ticket file, stored on secure, distributed ticket servers, is used to identify and initialize at least one of the data servers as a failover data warehouse. Once communication between the premises and its primary data warehouse is restored, the data collected during the failover is transferred to the primary data warehouse and purged from the failover data warehouse.
In accordance with an aspect of the present invention, a fault tolerant data warehousing method is provided. The method may be implemented in a data collection and processing system including two or more premises servers for collecting data and transmitting the data to a primary data warehouse. In accordance with the present invention, a premises server obtains a set of data to be transmitted to a primary data warehouse. The premises server obtains an indication that the primary data warehouse is inoperable to receive the set of data. The premises server then obtains a set of data identifying an alternate data warehouse and transmits the set of data to the identified alternate data warehouse. The alternate data warehouse is selected from the two or more premises servers.
In accordance with a further aspect of the present invention, a method for providing fault tolerant data warehousing is provided. The method is implemented in a data collection and processing system including two or more premises servers for collecting data and transmitting the data to a primary data warehouse. In accordance with the method, a premises server obtains a set of data to be transmitted to a primary data warehouse and an indication that the primary data warehouse is inoperable to receive the set of data. The premises server accesses a database associated with a premises server to obtain an identification of an alternate data warehouse associated with the premises server. The premises server suspends the transmission of data between the premises server and the primary data warehouse and transmits premises data to the alternate data warehouse. The alternate data warehouse is selected from the two or more premises servers.
In accordance with a further aspect of the present invention, a system for providing fault tolerant data warehousing is provided. The system includes two or more premises servers in communication with a number of data generating devices. The premises servers transmit collected data for storage. The system also includes a primary data warehouse for receiving the collected data from the premises servers. The system further includes a database server in communication with the premises server for providing an identification of an alternate data warehouse upon a failure of the primary data warehouse. The alternate data warehouse is selected from the two or more premises servers.
The foregoing aspects and many of the attendant advantages of this invention will become more readily appreciated as the same become better understood by reference to the following detailed description, when taken in conjunction with the accompanying drawings, wherein:
As described above, aspects of the present invention may be embodied in a WWW or Web site accessible via the Internet. As is well known to those skilled in the art, the term “Internet” refers to the collection of networks and routers that use the Transmission Control Protocol/Internet Protocol (“TCP/IP”) to communicate with one another. A representative section of the Internet 20 is shown in
Furthermore, computers 28 and other related electronic devices can be remotely connected to either the LANs 24 or the WAN 26 via a digital communications device, modem and temporary telephone, or a wireless link. It will be appreciated that the Internet 20 comprises a vast number of such interconnected networks, computers, and routers and that only a small, representative section of the Internet 20 is shown in
The Internet has recently seen explosive growth by virtue of its ability to link computers located throughout the world. As the Internet has grown, so has the WWW. As is appreciated by those skilled in the art, the WWW is a vast collection of interconnected or “hypertext” documents written in HyperText Markup Language (“HTML”), or other markup languages, that are electronically stored at or dynamically generated by “WWW sites” or “Web sites” throughout the Internet. Additionally, client-side software programs that communicate over the Web using the TCP/IP protocol are part of the WWW, such as JAVA® applets, instant messaging, e-mail, browser plug-ins, Macromedia Flash, chat and others. Other interactive hypertext environments may include proprietary environments such as those provided in America Online or other online service providers, as well as the “wireless Web” provided by various wireless networking providers, especially those in the cellular phone industry. It will be appreciated that the present invention could apply in any such interactive communication environments, however, for purposes of discussion, the Web is used as an exemplary interactive hypertext environment with regard to the present invention.
A Web site is a server/computer connected to the Internet that has massive storage capabilities for storing hypertext documents and that runs administrative software for handling requests for those stored hypertext documents as well as dynamically generating hypertext documents. Embedded within a hypertext document are a number of hyperlinks, i.e., highlighted portions of text which link the document to another hypertext document possibly stored at a Web site elsewhere on the Internet. Each hyperlink is assigned a Uniform Resource Locator (“URL”) that provides the name of the linked document on a server connected to the Internet. Thus, whenever a hypertext document is retrieved from any Web server, the document is considered retrieved from the World Wide Web. Known to those skilled in the art, a Web server may also include facilities for storing and transmitting application programs, such as application programs written in the JAVA® programming language from Sun Microsystems, for execution on a remote computer. Likewise, a Web server may also include facilities for executing scripts and other application programs on the web server itself.
A remote access user may retrieve hypertext documents from the World Wide Web via a Web browser program. A Web browser, such as Netscape's NAVIGATOR® or Microsoft's Internet Explorer, is a software application program for providing a user interface to the WWW. Upon request from the remote access user via the Web browser, the Web browser requests the desired hypertext document from the appropriate web server using the URL for the document and the HyperText Transport Protocol (“HTTP”). HTTP is a higher-level protocol than TCP/IP and is designed specifically for the requirements of the WWW. HTTP runs on top of TCP/IP to transfer hypertext documents and user-supplied form data between server and client computers. The WWW browser may also retrieve programs from the web server, such as JAVA applets, for execution on the client computer. Finally, the WWW browser may include optional software components, called plug-ins, that run specialized functionality within the browser.
Referring now to
With reference now to
In an illustrative embodiment of the present invention, each premises 202 is associated with a premises server 204. The premises server 204 may be local to each premises 202 or otherwise in communication with a premises 202. Each premises server 204 may be in communication with a number of monitoring devices 205 operable to generate data to be archived. In an illustrative embodiment of the present invention, the monitoring devices 205 can include one or more biometric identification devices, including, but not limited to, voice identification devices, image capture devices (e.g., video motion capture and still image capture), microphones, fingerprint identification devices, retinal identification devices, DNA identification devices, and the like. The monitoring devices 205 can also include smoke, fire and carbon monoxide detectors. The monitoring devices 205 can further include door and window access detectors, glass break detectors, motion detectors, audio detectors, metal detectors, explosive detectors and/or infrared detectors. Still further, the monitoring devices 205 may include pressure-sensitive mats or planar surfaces. Still further, the monitoring devices 205 can include conventional panic buttons, global positioning satellite (“GPS”) locators, other geographic locators, medical indicators, and vehicle information systems. The monitoring devices 205 can also be integrated with other existing information systems, such as inventory control systems, accounting systems, reservation systems, point-of-sale terminals/systems, and the like. It will be apparent to one skilled in the relevant art that additional or alternative monitoring devices 205 corresponding to a specific monitoring function may be practiced with the present invention. Additionally, the device data can include binary, textual, graphical, and any combination thereof generated by a monitoring device 205. The device data can include raw data originating from a monitoring device 205 or data processed by the monitoring device 205 after it is captured, by the premises server 204, or any other computing device. Additionally, the premises server 204 may obtain data to be archived from other sources, such as third-party monitoring systems, and the like.
The premises server 204 may also be in communication with a local data repository 206, a data warehouse ticket location database 208, a data warehouse identity ticket database 210, and a data warehouse control data database 212. Further, the premises 202 can include a client computer 214 operable to communicate with the premises server 204 and additional components of the fault tolerant data warehouse environment 200.
With reference now to
With continued reference to
In an actual embodiment of the present invention the various components of the fault tolerant data warehouse environment 200 may communicate via a global communication network, such as Internet 20. Alternatively, some or all of the components may communicate via private or semi-private communication networks.
The premises server 204 also includes a processing unit 302, an optional display 304, a device interface 306 and a mass memory 308, all connected via a communication bus, or other communication device. The device interface 306 includes hardware and software components that facilitate interaction with a variety of the monitoring devices via a variety of communication protocols including TCP/IP, X10, digital I/O, RS-232, RS-485 and the like. Additionally, the device interface 306 facilitates communication via a variety of communication mediums including telephone land lines, wireless networks (including cellular, digital and radio networks), cable networks and the like. In an actual embodiment of the present invention, the device interface 306 is implemented as a layer between the server hardware and software applications utilized to control the individual monitoring devices. It will be understood by one skilled in the relevant art that alternative interface configurations may be practiced with the present invention.
The mass memory 308 generally comprises a RAM, ROM, and a permanent mass storage device, such as a hard disk drive, tape drive, optical drive, floppy disk drive, or combination thereof. The mass memory 308 stores an operating system 310 for controlling the operation of the premises server 204. It will be appreciated that this component may comprise a general-purpose server operating system as is known to those skilled in the art, such as UNIX, LINUX™, or Microsoft WINDOWS NT®.
The mass memory 308 also stores program code and data for interfacing with various monitoring devices 206 and for transmitting the monitoring device data. More specifically, the mass memory 308 stores a device interface application 312 in accordance with the present invention for obtaining monitoring device data from a variety of devices and for manipulating the data for processing. The device interface application 312 comprises computer-executable instructions which, when executed by the premises server 204 obtains and transmits device data as will be explained below in greater detail. The mass memory 308 also stores an output interface application program 314 for transmitting processed device data to one or more external system components, including the data warehouse 216 and the ticket server 222. The operation of the output interface application 314 will be described in greater detail below. It will be appreciated that these components may be stored on a computer-readable medium and loaded into the memory of the premises server using a drive mechanism associated with the computer-readable medium, such as a floppy, CD-ROM, DVD-ROM drive, or network drive 300.
The data warehouse 216 also includes a processing unit 402, an optional display 404 and a mass memory 406, all connected via a communication bus, or other communication device. The mass memory 406 generally comprises a RAM, ROM, and a permanent mass storage device, such as a hard disk drive, tape drive, optical drive, floppy disk drive, or combination thereof. The mass memory 406 stores an operating system 408 for controlling the operation of the data warehouse 216. It will be appreciated that this component may comprise a general-purpose server operating system.
The mass memory 406 also stores program code and data for interfacing with various premises servers 204 and processing the monitoring device data received from the premises servers. More specifically, the mass memory 406 stores a premises server interface application 410 in accordance with the present invention for communicating with a number of premises servers 204. The premises server interface application 410 includes computer-executable instructions that, when executed by the data warehouse 216 obtains and transmits device data as will be explained below in greater detail. The mass memory 406 also stores a data processing application 412 for processing data received by the data warehouse 416 216. The operation of the data processing application 412 will be described in greater detail below. It will be appreciated that these components may be stored on a computer-readable medium and loaded into the memory of the premises server using a drive mechanism associated with the computer-readable medium, such as a floppy, CD-ROM, DVD-ROM drive, or network drive 400.
The ticket server 222 also includes a processing unit 502, an optional display 504 and a mass memory 506, all connected via a communication bus, or other communication device. The mass memory 506 generally comprises a RAM, ROM, and a permanent mass storage device, such as a hard disk drive, tape drive, optical drive, floppy disk drive, or combination thereof. The mass memory 506 stores an operating system 508 for controlling the operation of the central server. It will be appreciated that this component may comprise a general-purpose server operating system.
The mass memory 506 also stores program code and data for interfacing with various premises servers 204 and associating a data warehouse for each premises server. More specifically, the mass memory 506 stores a premises server interface application 510 in accordance with the present invention for communicating with a number of premises servers 204. The premises server interface application 510 includes computer-executable instructions which, when executed by the data warehouse 216 obtains and transmits data warehouse assignments as will be explained below in greater detail. The mass memory 506 also stores a data processing application 512 for processing data warehouse assignments for a number of premises servers 204. The operation of the data processing application 512 will be described in greater detail below. It will be appreciated that these components may be stored on a computer-readable medium and loaded into the memory of the premises server using a drive mechanism associated with the computer-readable medium, such as a floppy, CD-ROM, DVD-ROM drive, or network drive 400.
In one aspect of the present invention, each premises server 204 is associated with at least one data warehouse 216 for transmitting monitoring device data for storage. In an illustrative embodiment of the present invention, a data warehouse 216 is designated as the primary data repository for a premises server 204. The premises server 204 may transmit data as it is generated by the various monitoring devices 205. Additionally, the premises server 204 may initiate a transfer of data upon the occurrence of a condition, such as a pre-established time period, or a detected event. The premises server 204 may encode the data to facilitate its transmission over the communication network 20. Additionally, the premises server 204 may also utilize various types of additional encoding for securing the transmission of data. One skilled in the relevant art will appreciate that transmission of data to a data warehouse 216 may include additional implementation details.
In accordance with the present invention, one or more events may occur that prevent a premises server 204 from transmitting data to a designated primary data warehouse 216. In one aspect of the present invention, hardware, software, and/or communication media errors may prevent a premises server 204 from establishing reliable communications with the designated primary data warehouse 216. For example, a data warehouse 216 may detect an error and attempt to transmit an error notification to its assigned premises servers 204. In another example, a premises server 204 may detect an inability to confirm the proper transmission of data and transmit an error notification to other premises servers. In another aspect of the present invention, one or more users from a client computer 214 may implement a reassignment of a data warehouse 216. For example, a system administrator may implement a reassignment of a data warehouse 216 to perform scheduled maintenance. As will be explained in greater detail below, upon the detection of an event that may prevent a premises server 204 from transmitting data, one or more premises servers 204 will be reassigned as alternative data warehouses to allow for the continuous processing of data by any number of premises servers in the fault tolerant data warehouse environment 200.
With reference now to
At block 604, the data processing application 512 of the ticket server 222 identifies an alternative data warehouse available for a given premises server 204 associated with the data warehouse 216. In an illustrative embodiment of the present invention, the data processing application 512 obtains a warehouse ticket file corresponding to the premises server 204 that indicates another premises server in the fault tolerant data warehouse environment 200 that will serve as an alternative data warehouse. The warehouse ticket file may be a static file that includes pre-assigned alternative premises servers 204. Alternatively, the warehouse ticket file may be dynamically generated based upon a variety of factors, including available memory resources of a variety of premises servers 204, communication network availability, and the like. In one embodiment, the warehouse ticket file may also indicate that a particular premises server 204 may serve as its own alternative data warehouse.
At block 606, the ticket server 222 transmits the identified alternative data warehouse to all applicable premises servers 204. In one embodiment of the present invention, the ticket server 222 may transmit an alternative data warehouse to a single premises server 204. Additionally, the ticket server 222 may transmit an alternative data warehouse to any number of premises servers 204 that are affected by the event. For example, if only a portion of the communication network is not available, the ticket server 222 may transmit alternative data warehouses for all premises servers 204 affected by the communication network unavailability.
At block 608, the premises server(s) obtain the transmitted data warehouse ticket and attempt to contact the designated alternate data warehouse at block 610. In an illustrative embodiment of the present invention, the warehouse ticket can include control and contact information that allows the premises server 204 to contact the alternate data warehouse. Additionally, the control and contact information may also include special processing information for a particular alternate data warehouse. Additionally, some or all of the control information may be stored in the warehouse control archive database 210. At decision block 612, a test is conducted to determine whether the alternate data warehouse is available. If the alternative data warehouse is not available, the routine 600 returns to block 604, where the ticket server 222 attempts to identify another alternate data warehouse. With reference to
At decision block 616, a test is conducted to determine whether primary data warehouse 216 is available. In an illustrative embodiment of the present invention, the premises server 204 may periodically test the communication network to determine whether the primary data warehouse 216 is available. Alternatively, the data warehouse 216 may transmit a notification when it is available. If the primary data warehouse 216 remains unavailable, the routine 600 returns to block 614. If the primary data warehouse 216 is available, at block 618, the premises server 204 is instructed to begin transmitting data to the primary data warehouse. At block 620, the alternate data warehouse transmits the temporarily stored data to the primary data warehouse. At block 622, the routine 600 terminates.
While illustrative embodiments of the invention have been illustrated and described, it will be appreciated that various changes can be made therein without departing from the spirit and scope of the invention.
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
4216375, | Feb 01 1978 | HOUSEHOLD COMMERCIAL FINANCIAL SERVICES, INC ; SHI ACQUISITION CORP | Self-contained programmable terminal for security systems |
4218690, | Feb 01 1978 | HOUSEHOLD COMMERCIAL FINANCIAL SERVICES, INC ; SHI ACQUISITION CORP | Self-contained programmable terminal for security systems |
4581634, | Nov 18 1982 | Security apparatus for controlling access to a predetermined area | |
4714995, | Sep 13 1985 | Northrop Grumman Corporation | Computer integration system |
4721954, | Dec 18 1985 | Marlee Electronics Corporation | Keypad security system |
4816658, | Sep 10 1984 | CASI-RUSCO INC , A CORP OF FLORIDA | Card reader for security system |
4837568, | Jul 08 1987 | Remote access personnel identification and tracking system | |
4839640, | Sep 24 1984 | ADT Inc. | Access control system having centralized/distributed control |
4962473, | Dec 09 1988 | ITT Corporation | Emergency action systems including console and security monitoring apparatus |
4998279, | Nov 30 1984 | EMC Corporation | Method and apparatus for personal verification utilizing nonpredictable codes and biocharacteristics |
5097505, | Nov 30 1984 | EMC Corporation | Method and apparatus for secure identification and verification |
5210873, | May 25 1990 | CSI Control Systems International, Inc. | Real-time computer system with multitasking supervisor for building access control or the like |
5367624, | Jun 11 1993 | Consilium, Inc. | Interface for controlling transactions in a manufacturing execution system |
5475375, | Oct 16 1985 | GE SECURITY, INC | Electronic access control systems |
5475378, | Jun 22 1993 | Canada Post Corporation | Electronic access control mail box system |
5544062, | Jan 31 1995 | Automated system for manufacturing of customized military uniform insignia badges | |
5600368, | Nov 09 1994 | Rovi Technologies Corporation | Interactive television system and method for viewer control of multiple camera viewpoints in broadcast programming |
5614890, | Dec 27 1993 | MOTOROLA SOLUTIONS, INC | Personal identification system |
5629981, | Jul 29 1994 | Texas Instruments Incorporated | Information management and security system |
5654696, | Oct 16 1985 | GE SECURITY, INC | Method for transferring auxillary data using components of a secure entry system |
5678039, | Sep 30 1994 | Borland Software Corporation | System and methods for translating software into localized versions |
5680328, | May 22 1995 | Omnitracs, LLC | Computer assisted driver vehicle inspection reporting system |
5682142, | Jul 29 1994 | SIENA FUNDING LLC | Electronic control system/network |
5729471, | Mar 31 1995 | The Regents of the University of California | Machine dynamic selection of one video camera/image of a scene from multiple video cameras/images of the scene in accordance with a particular perspective on the scene, an object in the scene, or an event in the scene |
5742286, | Nov 20 1995 | International Business Machines Corporation | Graphical user interface system and method for multiple simultaneous targets |
5768119, | Apr 12 1996 | Fisher-Rosemount Systems, Inc | Process control system including alarm priority adjustment |
5870733, | Jun 14 1996 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Automated system and method for providing access data concerning an item of business property |
5903455, | Feb 06 1996 | Fisher-Rosemount Systems, Inc. | Interface controls for use in a field device management system |
5923264, | Dec 22 1995 | Schlage Lock Company LLC; Harrow Products LLC | Multiple access electronic lock system |
5960174, | Dec 20 1996 | Square D Company | Arbitration method for a communication network |
6064723, | Sep 16 1994 | AVAYA Inc | Network-based multimedia communications and directory system and method of operation |
6233588, | Dec 02 1998 | UTC Fire & Security Americas Corporation, Inc | System for security access control in multiple regions |
6356949, | Jan 29 1999 | Intermec IP CORP | Automatic data collection device that receives data output instruction from data consumer |
6587857, | Jun 30 1998 | CITICORP CREDIT SERVICES, INC USA | System and method for warehousing and retrieving data |
7003560, | Nov 03 1999 | Accenture Global Services Limited | Data warehouse computing system |
20010044879, | |||
20020019945, | |||
20020029263, | |||
20020044879, | |||
20020059423, | |||
20020072934, | |||
20020116389, | |||
20020138427, | |||
20030191773, | |||
20030208572, | |||
EP804031, | |||
RE35336, | Aug 14 1992 | HOUSEHOLD COMMERCIAL FINANCIAL SERVICES, INC ; SHI ACQUISITION CORP | Self-contained programmable terminal for security systems |
WO128251, | |||
WO9707486, | |||
WO128251, | |||
WO9707486, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Feb 20 2003 | ALEXANDER, BRUCE | VIGILOS, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 048137 | /0431 | |
May 30 2008 | VIGILOS, INC | Hatoshi Investments JP, LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 047799 | /0070 | |
Aug 07 2009 | Hatoshi Investments JP, LLC | (assignment on the face of the patent) | / | |||
Aug 26 2015 | Hatoshi Investments JP, LLC | CHEMTRON RESEARCH LLC | MERGER SEE DOCUMENT FOR DETAILS | 037275 | /0316 | |
Aug 26 2015 | Hatoshi Investments JP, LLC | Intellectual Ventures Fund 83 LLC | CORRECTIVE ASSIGNMENT TO CORRECT THE ASSIGNEE NAME PREVIOUSLY RECORDED AT REEL: 037275 FRAME: 0316 ASSIGNOR S HEREBY CONFIRMS THE MERGER | 038612 | /0375 | |
Dec 30 2016 | Intellectual Ventures Fund 83 LLC | CHEMTRON RESEARCH LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 041469 | /0177 | |
Dec 27 2018 | INTELLECTUAL VENTURES ASSETS 122 LLC | ROVI Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 048143 | /0615 | |
Dec 27 2018 | INTELLECTUAL VENTURES ASSETS 127 LLC | ROVI Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 048143 | /0615 | |
Jan 07 2019 | CHEMTRON RESEARCH LLC | INTELLECTUAL VENTURES ASSETS 122 LLC | NUNC PRO TUNC ASSIGNMENT SEE DOCUMENT FOR DETAILS | 047923 | /0215 | |
Jan 15 2019 | ROVI Corporation | Rovi Technologies Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 048143 | /0607 | |
Nov 22 2019 | Rovi Guides, Inc | HPS INVESTMENT PARTNERS, LLC, AS COLLATERAL AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 051143 | /0468 | |
Nov 22 2019 | Veveo, Inc | HPS INVESTMENT PARTNERS, LLC, AS COLLATERAL AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 051143 | /0468 | |
Nov 22 2019 | Rovi Technologies Corporation | HPS INVESTMENT PARTNERS, LLC, AS COLLATERAL AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 051143 | /0468 | |
Nov 22 2019 | Rovi Solutions Corporation | HPS INVESTMENT PARTNERS, LLC, AS COLLATERAL AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 051143 | /0468 | |
Nov 22 2019 | Veveo, Inc | MORGAN STANLEY SENIOR FUNDING, INC , AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 051110 | /0006 | |
Nov 22 2019 | TIVO SOLUTIONS, INC | MORGAN STANLEY SENIOR FUNDING, INC , AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 051110 | /0006 | |
Nov 22 2019 | Rovi Guides, Inc | MORGAN STANLEY SENIOR FUNDING, INC , AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 051110 | /0006 | |
Nov 22 2019 | Rovi Technologies Corporation | MORGAN STANLEY SENIOR FUNDING, INC , AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 051110 | /0006 | |
Nov 22 2019 | Rovi Solutions Corporation | MORGAN STANLEY SENIOR FUNDING, INC , AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 051110 | /0006 | |
Nov 22 2019 | TIVO SOLUTIONS, INC | HPS INVESTMENT PARTNERS, LLC, AS COLLATERAL AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 051143 | /0468 | |
Jun 01 2020 | HPS INVESTMENT PARTNERS, LLC | Rovi Solutions Corporation | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 053458 | /0749 | |
Jun 01 2020 | HPS INVESTMENT PARTNERS, LLC | Rovi Technologies Corporation | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 053458 | /0749 | |
Jun 01 2020 | HPS INVESTMENT PARTNERS, LLC | Rovi Guides, Inc | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 053458 | /0749 | |
Jun 01 2020 | HPS INVESTMENT PARTNERS, LLC | Veveo, Inc | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 053458 | /0749 | |
Jun 01 2020 | HPS INVESTMENT PARTNERS, LLC | TIVO SOLUTIONS, INC | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 053458 | /0749 | |
Jun 01 2020 | MORGAN STANLEY SENIOR FUNDING, INC | Veveo, Inc | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 053481 | /0790 | |
Jun 01 2020 | MORGAN STANLEY SENIOR FUNDING, INC | TIVO SOLUTIONS, INC | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 053481 | /0790 | |
Jun 01 2020 | MORGAN STANLEY SENIOR FUNDING, INC | Rovi Guides, Inc | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 053481 | /0790 | |
Jun 01 2020 | Rovi Solutions Corporation | BANK OF AMERICA, N A | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 053468 | /0001 | |
Jun 01 2020 | Rovi Technologies Corporation | BANK OF AMERICA, N A | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 053468 | /0001 | |
Jun 01 2020 | Rovi Guides, Inc | BANK OF AMERICA, N A | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 053468 | /0001 | |
Jun 01 2020 | TIVO SOLUTIONS INC | BANK OF AMERICA, N A | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 053468 | /0001 | |
Jun 01 2020 | Invensas Corporation | BANK OF AMERICA, N A | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 053468 | /0001 | |
Jun 01 2020 | INVENSAS BONDING TECHNOLOGIES, INC | BANK OF AMERICA, N A | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 053468 | /0001 | |
Jun 01 2020 | Tessera, Inc | BANK OF AMERICA, N A | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 053468 | /0001 | |
Jun 01 2020 | TESSERA ADVANCED TECHNOLOGIES, INC | BANK OF AMERICA, N A | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 053468 | /0001 | |
Jun 01 2020 | DTS, INC | BANK OF AMERICA, N A | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 053468 | /0001 | |
Jun 01 2020 | PHORUS, INC | BANK OF AMERICA, N A | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 053468 | /0001 | |
Jun 01 2020 | iBiquity Digital Corporation | BANK OF AMERICA, N A | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 053468 | /0001 | |
Jun 01 2020 | Veveo, Inc | BANK OF AMERICA, N A | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 053468 | /0001 | |
Jun 01 2020 | MORGAN STANLEY SENIOR FUNDING, INC | Rovi Solutions Corporation | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 053481 | /0790 | |
Jun 01 2020 | MORGAN STANLEY SENIOR FUNDING, INC | Rovi Technologies Corporation | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 053481 | /0790 | |
Aug 15 2022 | Rovi Technologies Corporation | ADEIA TECHNOLOGIES INC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 069048 | /0223 |
Date | Maintenance Fee Events |
Dec 31 2014 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Jan 31 2019 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Jan 15 2016 | 4 years fee payment window open |
Jul 15 2016 | 6 months grace period start (w surcharge) |
Jan 15 2017 | patent expiry (for year 4) |
Jan 15 2019 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jan 15 2020 | 8 years fee payment window open |
Jul 15 2020 | 6 months grace period start (w surcharge) |
Jan 15 2021 | patent expiry (for year 8) |
Jan 15 2023 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jan 15 2024 | 12 years fee payment window open |
Jul 15 2024 | 6 months grace period start (w surcharge) |
Jan 15 2025 | patent expiry (for year 12) |
Jan 15 2027 | 2 years to revive unintentionally abandoned end. (for year 12) |