OBSERVING AND REPORTING CHANGES IN COMPLEX SOFTWARE DEPENDENCIES
An observation system includes mechanisms for efficiently tracking the state of source components, which include functions, arguments, or values, etc. In one implementation, an observing component requests that a source component processes a request. The observation system then identifies all possible components in a dependency chain for the request, and all such components that are configured for change notifications. A dependency registry stores a representation of each identified component that is configured for change notifications. Any time any component configured for change notifications changes, including indirectly related components, the observing component can be immediately notified of the change, without having to reprocess the entire set of component dependencies.
Latest Microsoft Patents:
This Application is a continuation of, and claims the benefit of and priority to, U.S. patent application Ser. No. 12/037,000, filed on Feb. 25, 2008, and entitled “OBSERVING AND REPORTING CHANGES IN COMPLEX SOFTWARE DEPENDENCIES,” which application is expressly incorporated herein by this reference in its entirety.
BACKGROUND1. Background and Relevant Art
Application programs used within computerized systems typically include a number of different components or modules that depend on each other for various different reasons. For example, a simple calculator application program might include an output display component, which depends on receiving one or more values from a calculation module, which in turn depends on receiving one or more number and function inputs before executing a calculation and passing it to the display component. Thus, the output component would be dependent not only on the display component, but on each of the various components that receive input from the number or function keys in a device. One will appreciate that such dependencies can become even more complex, particularly when individual application programs depend on each other for various values.
For example, a computerized system might include an attached display device, and one or more display application programs that render output to be displayed. The one or more display application programs driving the display device, however, may be configured somewhat passively to display information only when the underlying information is directly passed to the output module (i.e., listening for pushed information). Even then, the display application may be configured only to send new rendering information to the display device whenever a user refreshes the display. Such a scenario is fairly common with internet browser programs that are used to view information contained in internet websites. If the information in the internet websites that the user would like to view is continually changing, the user may need to continually refresh the internet browser in order to see the changes.
For example, a user may execute one or more display applications to view one or more different accounts (e.g., internet banking), each of which may include continually updated information. The display application may be further configured to filter this information so that only the largest two accounts are ever added together and displayed. In such a situation, therefore, there may be multiple different components used to display the information, including one or more underlying interfaces for reporting each of the account values, as well as one or more intermediate interfaces for determining which of the accounts has the greatest value, and are to be added. Unfortunately, depending on how each of these underlying interfaces may be configured, the display application could be displaying stale or even inaccurate account information almost instantaneously. For example, during the brief time the account values were passed to the intermediate calculation interface, and before the corresponding values have been calculated and passed to the display interface, one or more of the underlying accounts could have been updated again.
Conventional mechanisms for refreshing data in a dependency chain such as this tend to be either completely passive, or computationally expensive. In a passive configuration, the underlying components in the dependency chain simply wait for a recalculation request from the top down, such as when a user manually requests a refresh through the display application. In a completely automated configuration, however, each interface and component in a dependency chain might be configured to continually request updates from each other every few seconds. Alternatively, the display application might be configured to continually request updates from the underlying intermediate interfaces by some predetermined interval. Automated implementations such as these tend to be computationally expensive for a number of different reasons, and thus often difficult to apply on a broad basis.
For example, some underlying components in a dependency chain may change often, while other underlying components may change rarely or infrequently. With reference to the above-identified account example, some accounts may be accessed and updated frequently, while others may be updated rarely if ever. Performing the same number of refresh requests on each underlying account is thus unnecessary. While using a frequent refresh configuration for small numbers of components that change infrequently may not cause too many problems, a frequent refresh rate with a large number of components that are continually changing (e.g., stock ticker data) could potentially crash or freeze a computer system.
In addition, if all of the interfaces are not appropriately configured, an important dependency could be missed, and a generic refresh command could still result in an inaccurate calculation. Referring to the example above, a generic refresh command to revalue and calculate the previously added largest two accounts could potentially miss the fact that another account had been updated and thus displaced one of the originally added accounts. Although it is possible that each underlying account could be configured to send a signal to another intermediate component each time there is an update to the account, this can also result in other difficulties, particularly if there are any updates or changes to the intermediate components in subsequent software upgrades. Such problems can be particularly acute with large, continually changing dependency chains in complex software.
Accordingly, there are a number of difficulties associated maintaining current values within software dependency chains that can be addressed.
BRIEF SUMMARYImplementations of the present invention provide systems, methods, and computer program products configured to efficiently report data freshness to components that depend on a plurality of other components. In particular, implementations of the present invention include one or more mechanisms that allow an observation system identify one or more source components in a complex dependency chain, and to identify those components that are configured to change at some point. Implementations of the present invention further include one or more mechanisms that allow the observing component to directly identify that one of the underlying source components in the dependency chain has changed, without necessarily having to reprocess the entire dependency chain of components.
For example, a method from the perspective of an observation system of reporting data freshness directly to an observing component can involve receiving one or more requests from an observing component to process data corresponding to one or more source components. The method can also involve during processing, identifying one or more additional components from which the one or more source components depend. In this case, at least one of the one or more additional components is configured for change notification. In addition, the method can involve storing in a registry one or more representations of the additional components configured for change notification. Furthermore, the method can involve indicating to the observing component directly that one or more of the one or more identified additional components have changed.
In addition, a method from the perspective of an observing component of observing data freshness in indirectly related components can involve an observing component calling one or more source components. In this case, calling the one or more source components further involves processing by one or more additional components from which the one or more source components depend. The method can also involve creating one or more dependency registries for the call to the one or more source components. In addition, the method can involve the dependency registry receiving the identity of all of the one or more source components and one or more additional components that are configured for change notifications. Furthermore, the method can involve identifying from the dependency registry that at least one additional component has changed.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
Additional features and advantages of the invention will be set forth in the description which follows, and in part will be obvious from the description, or may be learned by the practice of the invention. The features and advantages of the invention may be realized and obtained by means of the instruments and combinations particularly pointed out in the appended claims. These and other features of the present invention will become more fully apparent from the following description and appended claims, or may be learned by the practice of the invention as set forth hereinafter.
In order to describe the manner in which the above-recited and other advantages and features of the invention can be obtained, a more particular description of the invention briefly described above will be rendered by reference to specific embodiments thereof which are illustrated in the appended drawings. Understanding that these drawings depict only typical embodiments of the invention and are not therefore to be considered to be limiting of its scope, the invention will be described and explained with additional specificity and detail through the use of the accompanying drawings in which:
Implementations of the present invention extend to systems, methods, and computer program products configured to efficiently report data freshness to components that depend on a plurality of other components. In particular, implementations of the present invention include one or more mechanisms that allow an observation system identify one or more source components in a complex dependency chain, and to identify those components that are configured to change at some point. Implementations of the present invention further include one or more mechanisms that allow the observing component to directly identify that one of the underlying source components in the dependency chain has changed, without necessarily having to reprocess the entire dependency chain of components.
Accordingly, and as will be understood more fully herein, implementations of the present invention allow software components that are entirely agnostic of their existence to participate between change-notifying sources and observers/observing components. In one implementation, this can be done by building look-aside state (e.g., dependency registry) for the current thread(s) of execution, which picks up dependencies on source components as they are drawn upon by an ongoing computation. Observers (observing components) can then receive notification whenever at least one of the source components notifies of a change using any number of push or pull-style mechanisms. If desired, notified observers can then re-run the necessary computations throughout the dependency chain to detect whether or not those changes affect the observer's own state and, if so, take appropriate action to regain currency.
For example, and as discussed more fully herein, an observing component indicates that it wants to observe by publishing state somewhere indicating that dependencies should be gathered (e.g., into a “dependency registry”). The observing component then executes arbitrary code. During this execution, components that are aware of change notifications will also execute code. Code that is aware of (or configured for) change notifications can then register with the observation system, indicating that the given component is change-notification-aware, and may at a future time indicate that it has become out of date. This process can repeat until all code in the dependency chain completes processing.
In one implementation, the observing component can then indicate that it is done observing, and then identify whether any change notification dependencies were gathered by the system during execution. The observing component can also store a status indicator associated with this particular round of execution for future reference. The observing component can also register a listener callback with the observation system through the created dependency registry. The listener will, in turn, be called at a future time when any of the components that are gathered, and are configured for dependent change notifications, change.
To these and other ends described herein, therefore, implementations of the present invention include gathering dynamic dependencies encountered by actual code execution, and gathering dependencies with no modifications to intermediary code. In addition, implementations of the present invention include forming ambient dependency gathering scopes, and chaining of scopes to form directed graphs, including fine-grained suppression or isolation of scopes. In some cases, the dependencies can even be automatically dropped if they are invalidated before the gathering process completes. One will appreciate that implementations of the present invention can be configured to properly handle cycles and multi-threading, and can be easily integrated with traditional point-notification mechanisms.
In any case, there are a number of ways these components can depend on each other for various values or calculations, in both direct and indirect dependency contexts. For example, component F (130) might be configured to generate output display data that directly depends on one or more calculations by component D (120). This output display data generated by component F, in turn, might thus directly depend on certain other calculations or values provided by source component D and indirectly to some extent on component E. To calculate these values, component D might first retrieve values from one or all of components A, B, and C, and/or also consider a value provided by component E.
In this case,
As understood more fully herein, at least one way that this can be accomplished is at least in part is via one or more processes in which the observation system 100 directs the collection of dependencies based on one or more processing requests by a given component (e.g., component F). As understood more fully herein, this also involves the observation system 100 identifying components that are configured for “change notifications.” In general, “change notifications” refers to a specific software component configuration in which the component publishes or otherwise reports its value changes, or even the mere fact of a value change. In conventional notification systems, a directly dependent component will identify the published change by registering a listener or other similar form of watching object with the source component. In the present example, therefore, components B and C will have identified themselves as proffering change notifications to component E, and component E will then listen to change notifications from components B and C.
In the case of other components further along the dependency chain, however,
In any event,
For example, per component F′s request 160 to call component D, each time processing module 140 encounters a particular software component in a dependency chain, processing module 140 asks if that particular component will or can change. If the given component (e.g., components A or B) is configured with static values (e.g., a non-changing string name), then the component might respond that no change is possible. In some cases, the given component may not even respond at all. In such a case, processing module 140 can then determine either that changes are unlikely, or unavailable, and update the registry 145 accordingly (e.g., messages 135a/b).
For example,
In the illustrated implementation, however,
In addition, dependency registry 145 can include still additional information about each component in the dependency chain, such as information based on a particular state value for each component at execution. For example, at the time of the initial call by component F, each of components A-E may comprise some initial value used in the processing, such as a particular string or number value. As a result,
Along these lines, one will appreciate that there may be instances in which one or more of the identified dependencies has already changed during the collection process. In such cases, component F (130) and/or system 100, generally, can be configured to simply discard the dependency registry 145 and start over as desired. In such a case, therefore, one will appreciate that dependency registry 145(a) represents a completed collection of dependencies that have not yet changed.
In any event, there are any number of additional configurations and mechanisms that system 100 and/or component F (130) can implement to identify changes in the dependency chain. For example,
One will appreciate that since this change to one of the components' status means that particular component is out of date, this change also means that the overall dependency registry 145 is out of date. Accordingly,
For example,
Regarding push-style changes, for example, component F could register a listener with dependency registry 145 upon completion of the entire collection process by processing module 140. In one implementation, this can mean that component F configures dependency registry 145 with change notifications when initially setting up dependency registry 145, and simply registers a listener with dependency registry 145. iIf component F registers a listener with dependency registry 145, component F will identify an overall change to the dependency chain anytime any status indicator for any of the component A-E changes in dependency registry 145.
Regarding pull-style mechanisms, component F may be configured to continually query dependency registry 145 to identify if the registry or components therein is/are out of date. Component F can be configured to perform this query as quickly as every few milliseconds or minutes, and even less frequently in terms of hours, days, or weeks, depending on the type of calculations and available resources that can or should be devoted to these requests. In either case, the results are effectively the same as described above with regard to the push-style mechanisms (e.g., resulting in message 160), and can be based on virtually any level of granularity. For example, the contents of message 160 can include a mere statement that registry 145b has changed (i.e., that some unnamed components in the dependency chain have changed), or that a specific one of the one or more components has changed. As shown, for example, message 160 indicates specifically in this case that component C has changed.
Component F 130 can then identify how exactly to process the received information. For example, component F could present one or more values to a user via a display output (or via a message to some other component) that indicates that a particular value in the dependency chain is now out of date. If component C was the value of a checking account that has now been updated, component F might then automatically display a flag next to the account name/number. However provided, another entity (e.g., a user, or automated entity) can then make a determination about how to proceed. For example, a user might then refresh their account browser to refresh and obtain the updated value, which, in turn, would cause component F to reprocess all calculations in the dependency chain, as before. Similarly, component F 130 could make its own determinations to reprocess all components in the dependency chain.
Accordingly,
In addition to the foregoing, implementations of the present invention can also be described in terms of methods comprising one or more acts for accomplishing a particular result. For example,
For example,
In addition,
Furthermore,
In addition,
In addition,
Furthermore,
Accordingly,
The embodiments of the present invention may comprise a special purpose or general-purpose computer including various computer hardware, as discussed in greater detail below. Embodiments within the scope of the present invention also include computer-readable media for carrying or having computer-executable instructions or data structures stored thereon. Such computer-readable media can be any available media that can be accessed by a general purpose or special purpose computer.
By way of example, and not limitation, such computer-readable media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to carry or store desired program code means in the form of computer-executable instructions or data structures and which can be accessed by a general purpose or special purpose computer. When information is transferred or provided over a network or another communications connection (either hardwired, wireless, or a combination of hardwired or wireless) to a computer, the computer properly views the connection as a computer-readable medium. Thus, any such connection is properly termed a computer-readable medium. Combinations of the above should also be included within the scope of computer-readable media.
Computer-executable instructions comprise, for example, instructions and data which cause a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims.
The present invention may be embodied in other specific forms without departing from its spirit or essential characteristics. The described embodiments are to be considered in all respects only as illustrative and not restrictive. The scope of the invention is, therefore, indicated by the appended claims rather than by the foregoing description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.
Claims
1. At an observation system in a computerized environment comprising a plurality of interrelated software components including one or more observing components that depend from one or more source components, which further depend from one or more additional components, a method of reporting data freshness in the one or more additional components directly to the one or more observing components, comprising the acts of:
- processing data corresponding to one or more source components;
- during processing, identifying one or more additional components, wherein at least one of the one or more additional components is configured for change notification;
- storing in a registry: (i) at least one representation of the one or more additional components, the at least one representation indicating whether a corresponding one of the one or more additional components is configured for change notification; and (ii) one or more status indicators for each component configured for change notification;
- identifying a change to the at least one additional component;
- changing the one or more status indicators corresponding to the at least one additional component in the registry; and
- indicating that one or more of the one or more identified additional components have changed.
2. The method as recited in claim 1, further comprising receiving one or more requests from an observing component to process data corresponding to the one or more source components.
3. The method recited in claim 2, wherein the observing component is only indirectly dependent on the one or more additional components via at least one of the one or more source components.
4. The method as recited in claim 1, further comprising registering a listener for the observing component with the registry.
5. The method recited in claim 1, wherein the registry is a dependency registry.
6. The method as recited in claim 1, wherein indicating that the one or more of the one or more identified additional components have changed is made to the observing component directly, and includes receiving a request from the observing component to determine whether the registry is up to date.
7. The method as recited in claim 1, further comprising identifying the at least one additional components that is configured for change notifications.
8. The method as recited in claim 7, wherein identifying the at least one additional component that is configured for change notification includes querying each source or additional component to determine whether the component will never change.
9. The method as recited in claim 7, wherein identifying the at least one additional component that is configured for change notifications further comprises:
- receiving no response to the query for change; or receiving a response that the at least one component can change.
10. The method as recited in claim 7, further comprising identifying at least one component that is not configured for change notifications.
11. The method as recited in claim 10, wherein identifying the at least one component that is not configured to change further comprises receiving a response from the queried component that the component will never change.
12. The method as recited in claim 1, further comprising reporting to the observing component that the at least one additional component has changed.
13. The method as recited in claim 1, wherein indicating that the one or more additional components have changed includes reporting to the observing component that the registry is out of date.
14. One or more computer-readable media storage devices having stored therein computer executable instructions that, when executed by one or more processors of a computing system cause the computing system to perform a method of reporting data freshness in one or more additional components directly to one or more observing components, the method including:
- processing data corresponding to one or more source components;
- during processing, identifying one or more additional components, wherein at least one of the one or more additional components is configured for change notification;
- storing in a registry: (i) at least one representation of the one or more additional components, the at least one representation indicating whether a corresponding one of the one or more additional components is configured for change notification; and (ii) one or more status indicators for each component configured for change notification;
- identifying a change to the at least one additional component;
- changing the one or more status indicators corresponding to the at least one additional component in the registry; and
- indicating that one or more of the one or more identified additional components have changed.
15. The one or more computer-readable media storage devices recited in claim 14, wherein the method includes registering a listener with the registry to identify when any of the additional components that are registered for change notifications have changed.
16. The one or more computer-readable media storage devices recited in claim 14, the method including querying the registry to determine whether the registry has changed.
17. The one or more computer-readable media storage devices recited in claim 14, the method further including, after identifying that the at least one additional component has changed, calling the one or more source components again.
18. The one or more computer-readable media storage devices recited in claim 17, the method including the observing component providing output that indicates that a value associated with the at least one additional component is now out of date.
19. The one or more computer-readable media storage devices recited in claim 18, wherein calling the one or more source components again is based on a response to the provided output that the additional component is out of date.
20. A data storage device usable within an observation system of a computerized environment that includes a plurality of software components, the data storage device comprising:
- one or more computer-readable media devices; and
- at least one dependency registry stored on the one or more computer-readable media devices, the at least one dependency registry including:
- for each of the plurality of software components: a component identification section providing a unique identification of a respective one of the plurality of software components; a change notification section identifying whether or not the respective one of the plurality of software components is configured for change notification and identification to an observer component upon a change made to the respective one of the plurality of software components; and a status section including an indication of only one of: (i) the respective one of the plurality of software components has changed;
- and (ii) the respective one of the plurality of software components has not changed.
Type: Application
Filed: Jan 28, 2011
Publication Date: Jun 2, 2011
Patent Grant number: 8214340
Applicant: MICROSOFT CORPORATION (Redmond, WA)
Inventors: Clemens A. Szyperski (Redmond, WA), Geoffrey M. Kizer (Seattle, WA), Joshua R. Williams (Seattle, WA), Anthony J. Moore (Seattle, WA)
Application Number: 13/016,859
International Classification: G06F 7/00 (20060101); G06F 17/00 (20060101);