Intelligent client architecture computer system and method
First Claim
1. A method of implementing synchronized distributed objects comprising:
- a local computing device requests data from a remote computing device to be used in a transaction;
the local computing device checks local resources for the data required;
upon failing to locate the required data locally, the local computing device formats a request for the required data to the remote computing device;
the local computing device sends the formatted request to the remote computing device;
the remote computing device receives the formatted request and unpacks the formatted request to remove formatting elements needed for transport;
the remote computing device interprets the formatted request from the local computing device by comparing the formatted request to an object model on the remote computing device;
the remote computing device resolves the formatted request to a set of data access instructions that operate on database management software;
the database management software retrieves the requested data;
the remote computing device registers interest in the retrieved data by the local computing device that requested the data;
the remote computing device packages the retrieved data for transport to the local computing device;
the remote computing device delivers the retrieved data to the local computing device;
the local computing device receives the retrieved data and unpacks the formatted request to remove formatting elements needed for transport;
the local computing device adds the retrieved data to a local data storage resources device;
the local computing device copies the retrieved data and delivers the retrieved data to the transaction;
the local computing device stores the retrieved data in a transaction data cache used to support the transaction, the transaction data cache being separate from a main local data cache and separate from a main local data mass storage area;
the local computing device registers the data as used by the transaction;
the local data storage resources device is updated to reflect changes made at the remote computing device by other users or by automated processes;
the local computing device operates the transaction, thereby accumulating changes in the data stored in the transaction data cache;
the changes in the data stored in the transaction data cache are compared against a log of data changes to the local data storage resources device after retrieving remote data;
the local computing device detects a local data collision conflict based upon the comparison of the data stored in the transaction data cache and the local data storage resources device;
the local computing device notifies the transaction that the local data collision conflict occurred;
the transaction resolves the local data collision conflict in an application-specific manner;
the local computing device formats the resolved local data collision conflict for transport to the remote computing device;
the local computing device transports the resolved local data collision conflict to the remote computing device for remote data conflict checking and long-term persistence;
the remote computing device receives the resolved local data collision conflict and unpacks formatting elements added for transport;
the remote computing device compares the resolved local data collision conflict to data items changed by the other users or by the automated processes;
the remote computing device stores the data items changed by the other users or by the automated processes as queued data changes;
the remote computing device detects a remote data change collision conflict based upon the comparison of the resolved local data collision conflict and the queued data changes;
the remote computing device notifies the local computing device that the remote data change collision conflict occurred;
the local computing device forwards the notification to the transaction for resolution in the application-specific manner and sends a message to the remote computing device indicating resolution of the remote data change collision conflict;
the remote computing device then detects a remote database collision conflict based upon comparison of the results of the resolved local data collision conflict and a persistent data store on the remote computing device;
the remote computing device notifies the local computing device that the remote database collision conflict occurred;
the local computing device forwards the notification to the transaction for resolution in the application-specific manner and sends a message to the remote computing device indicating resolution of the remote database collision conflict;
the remote computing device updates the persistent data store on the remote computing device;
the remote computing device checks a registration table to determine other computing devices that must be notified of the resolution of the remote database collision conflict performed by the local computing device and the remote computing device;
the remote computing device transmits the results of the resolution of the remote database collision conflict to the local computing device and other computing devices affected by the remote database collision conflict;
the local computing device and the other computing devices update the main local data cache based upon the resolution of the remote database collision conflict; and
the local computing device purges data from the transaction data cache.
1 Assignment
0 Petitions
Accused Products
Abstract
A collision detection and data synchronization mechanism operates to expand the speed and capability of distributed applications. The execution environment employs collision detection and data synchronization to distribute data objects to appropriate network nodes to support local processing. The collision detection and data synchronization mechanism defines the set of processes and algorithms used to track distributed data objects and to manage changes to the distributed objects throughout a network of intelligent computing devices. Data and code are distributed to local computing devices necessitating tracking and synchronizing updates. The system and method ensures that data updates received during the course of a local transaction do not unwillingly affect the results of other transactions by notifying the local computing devices of changes to the data that are subject of the transaction. These conflicts are then resolved in the applications, and notification of the resolution is sent to the remaining intelligent computing devices.
44 Citations
15 Claims
-
1. A method of implementing synchronized distributed objects comprising:
-
a local computing device requests data from a remote computing device to be used in a transaction; the local computing device checks local resources for the data required; upon failing to locate the required data locally, the local computing device formats a request for the required data to the remote computing device; the local computing device sends the formatted request to the remote computing device; the remote computing device receives the formatted request and unpacks the formatted request to remove formatting elements needed for transport; the remote computing device interprets the formatted request from the local computing device by comparing the formatted request to an object model on the remote computing device; the remote computing device resolves the formatted request to a set of data access instructions that operate on database management software; the database management software retrieves the requested data; the remote computing device registers interest in the retrieved data by the local computing device that requested the data; the remote computing device packages the retrieved data for transport to the local computing device; the remote computing device delivers the retrieved data to the local computing device; the local computing device receives the retrieved data and unpacks the formatted request to remove formatting elements needed for transport; the local computing device adds the retrieved data to a local data storage resources device; the local computing device copies the retrieved data and delivers the retrieved data to the transaction; the local computing device stores the retrieved data in a transaction data cache used to support the transaction, the transaction data cache being separate from a main local data cache and separate from a main local data mass storage area; the local computing device registers the data as used by the transaction; the local data storage resources device is updated to reflect changes made at the remote computing device by other users or by automated processes; the local computing device operates the transaction, thereby accumulating changes in the data stored in the transaction data cache; the changes in the data stored in the transaction data cache are compared against a log of data changes to the local data storage resources device after retrieving remote data; the local computing device detects a local data collision conflict based upon the comparison of the data stored in the transaction data cache and the local data storage resources device; the local computing device notifies the transaction that the local data collision conflict occurred; the transaction resolves the local data collision conflict in an application-specific manner; the local computing device formats the resolved local data collision conflict for transport to the remote computing device; the local computing device transports the resolved local data collision conflict to the remote computing device for remote data conflict checking and long-term persistence; the remote computing device receives the resolved local data collision conflict and unpacks formatting elements added for transport; the remote computing device compares the resolved local data collision conflict to data items changed by the other users or by the automated processes; the remote computing device stores the data items changed by the other users or by the automated processes as queued data changes; the remote computing device detects a remote data change collision conflict based upon the comparison of the resolved local data collision conflict and the queued data changes; the remote computing device notifies the local computing device that the remote data change collision conflict occurred; the local computing device forwards the notification to the transaction for resolution in the application-specific manner and sends a message to the remote computing device indicating resolution of the remote data change collision conflict; the remote computing device then detects a remote database collision conflict based upon comparison of the results of the resolved local data collision conflict and a persistent data store on the remote computing device; the remote computing device notifies the local computing device that the remote database collision conflict occurred; the local computing device forwards the notification to the transaction for resolution in the application-specific manner and sends a message to the remote computing device indicating resolution of the remote database collision conflict; the remote computing device updates the persistent data store on the remote computing device; the remote computing device checks a registration table to determine other computing devices that must be notified of the resolution of the remote database collision conflict performed by the local computing device and the remote computing device; the remote computing device transmits the results of the resolution of the remote database collision conflict to the local computing device and other computing devices affected by the remote database collision conflict; the local computing device and the other computing devices update the main local data cache based upon the resolution of the remote database collision conflict; and the local computing device purges data from the transaction data cache.
-
-
2. A method of implementing synchronized distributed objects comprising:
-
requesting data from a remote computing device to be delivered to a local computing device that initiated the request, the requested data to be used in a transaction; checking local resources available to the local computing device for the data required; formatting a data request to the remote computing device from the local computing device upon failing to locate the required data locally; sending the data request from the local computing device to the remote computing device; receiving the formatted data request at the remote computing device and unpacking the formatted data request to remove formatting elements needed for transport; interpreting the formatted data request using the remote computing device to compare the formatted data request to an object model on the remote computing device; resolving the data request to a set of data access instructions that operate on database management software; retrieving the requested data using the database management software as a retrieval tool; registering interest of the local computing device that requested the retrieved data; packaging the retrieved data for transport from the remote computing device to the local computing device; delivering the retrieved data to the local computing device; receiving the retrieved data at the local computing device and unpacking the retrieved data to remove formatting elements needed for transport; adding the retrieved data to a local storage resources device available to the local computing device; copying the retrieved data and delivering the retrieved data to the transaction; storing the retrieved data in a transaction data cache used to support the transaction, the local computing device storing the retrieved data, and the transaction data cache being separate from a main local data cache and separate from a main local data mass storage area; registering the retrieved data as used by the transaction; operating the transaction, thereby accumulating changes in the data stored in the transaction data cache; comparing the changes in the data stored in the transaction data cache against a log of data changes to the local storage resources device after retrieving data from the remote computing device; detecting a local data collision conflict by using the local computing device to compare the data stored in the transaction data cache and the local storage resources device; notifying the transaction that the local data collision conflict occurred; resolving the local data collision conflict utilizing the transaction to resolve the local data collision conflict in an application-specific manner; formatting the resolved local data collision conflict for transport from the local computing device to the remote computing device; transporting the formatted resolved local data collision conflict from the local computing device to the remote computing device for remote data conflict checking and long-term persistence; receiving the formatted resolved local data collision conflict at the remote computing device and unpacking formatting elements that were added for transport; comparing the formatted resolved local data collision conflict to data items changed by other users or by automated processes; storing the data items changed by the other users or by the automated processes as queued data changes; detecting a remote data change collision conflict by using the remote computing device to compare the formatted resolved local data collision conflicts and the queued data changes; detecting a remote database collision conflict by using the remote computing device to compare the resolved local data collision conflict to a persistent data store; sending notification of a remote database collision conflict from the remote computing device to the local computing device; forwarding the notification from the local computing device to the transaction for resolution of the remote database collision conflict in the application-specific manner; sending a message from the local computing device to the remote computing device indicating resolution of the remote database collision conflict; updating the persistent data store on the remote computing device; checking a registration table available to the remote computing device to determine if other computing devices must be notified of the resolution of the remote database collision conflict performed by the local computing device; transmitting the results of the resolution of the remote database collision conflict from the remote computing device to the local computing device and to other computing devices affected by the remote database collision conflict; updating the main local data cache at the local computing device and the other computing devices based upon the resolution of the remote database collision conflict; and cleaning data from the transaction data cache at the local computing device. - View Dependent Claims (3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15)
-
Specification