1. Field
The present disclosure relates generally to communication systems, and more particularly, relates to the analysis and traversal of any object model at run-time in a cloud-based environment, without the need for access to the original object model or source code, although this information can be used if desired or available.
2. Background
The “cloud” is a next generation computing system that provides elasticity in using physical/virtual servers. A cloud-based environment includes computing resources, both physical and virtual servers, that can be dynamically and rapidly scaled and that are available via a network. Thus, a cloud-based environment includes the centralization of computing resources over a network. This enables systems to be built out in a horizontal manner, and enables services on demand. The cloud includes servers and back end databases that are accessible via access points such as web browsers at an access device.
Cloud computing software systems typically include multiple cloud components communicating with each other over application programming interfaces, such as web services. Cloud computing includes Web-based processing. Shared resources, software and information can be provided to computers and other access devices on demand via the Internet.
This provides a new delivery model for Information Technology (IT) services based on the Internet. Users can access web-based tools or applications via a web browser similar to the program being installed locally on their own computer.
Cloud computing architecture includes, e.g., a front end and a back end. The front end is seen by the client, i.e. the computer user. This front end includes the client's network (or computer) and the applications used to access the cloud via a user interface such as a web browser. The back end of the cloud computing architecture (e.g. the ‘cloud’ itself) includes computers, servers and data storage devices.
Cloud clients can include computer hardware and/or software that relies on cloud computing for application delivery or that is designed to deliver cloud services. This may include various access devices such as computers, phones, operating systems, browsers, and other devices.
Cloud computing provides agility, improving with users' ability to rapidly and inexpensively re-provision technological infrastructure resources; reduced costs; scalability; and device and location independence, by enabling users to access systems using a web browser regardless of their location or what device they are using (e.g., personal computer (PC) or mobile devices). As infrastructure is off-site (typically provided by a third-party) and accessed via the Internet, users can connect from anywhere. Cloud computing also enables resources to be shared across a large pool of users.
Applications may be run on a single server that includes a third party system and source code. To cloud enable this system and source code, without making any changes to the third party system, requires a virtualization of the application in the cloud. Each system includes its own basic model and corresponding object data.
Typically, knowledge of a third party's source code is necessary to provide run-time information for and add behavior to a running system. However, when building systems that run in a cloud environment, it would be beneficial to provide tool chains that are quick and easy to use and that will work in connection with existing run-time systems without modification or access to original source code.
In light of the above described problems and unmet needs, a system and method for analysis and traversal of object models is presented herein for third party systems. New state and behaviors can be added to existing systems at run-time without the need for access to the original object model or source code. This allows cloud-based tools and system enhancements to be provided without direct access to the third party source code and without making any changes to the third party system. This is done by creating a canonical meta object model, from run-time and/or static type/schema information, which is then utilized at run-time. The meta object model enables in-place object model analysis and traversal and the attachment/association of new state and behavior to existing objects and object models.
Aspects presented herein solve a large class of computing problems through object model analysis and traversal. For example, aspects of the present invention can address deep copy, serialization, transactions, transactional memory, and in-process and distributed garbage collection.
Aspects may include, for example, a method, system, and computer program product for performing in-place object model analysis for a third party system having third party source code, including receiving information from a third party system at run-time, the information including a plurality of items, each item comprising at least one selected from a group consisting of an object and a type; analyzing the received, third party items at run-time; creating a re-usable meta schema based on the analysis; and caching the re-usable meta-schema.
Additional aspects may include, for example, a method, system, and computer program product for performing in-place object model traversal for a third party system having a third party source code, including receiving an item, the item comprising an instance of at least one of an object and a type; accessing a cached meta schema, the meta schema comprising a plurality of handlers for objects and types; determining, via a processing device, whether the instance has previously been visited in the cached meta schema; determining whether an instance handler is registered for the item in the cached meta schema; and accessing the registered instance handler, after it is determined that the handler is registered for the item in the cached meta schema.
Additional advantages and novel features of these aspects of the invention will be set forth in part in the description that follows, and in part will become more apparent to those skilled in the art upon examination of the following or upon learning by practice of the invention.
Various aspects of the systems and methods will be described in detail, with reference to the following figures, wherein:
These and other features and advantages of this invention are described in, or are apparent from, the following detailed description of various example illustrations and implementations.
The detailed description set forth below in connection with the appended drawings is intended as a description of various configurations and is not intended to represent the only configurations in which the concepts described herein may be practiced. The detailed description includes specific details for the purpose of providing a thorough understanding of various concepts. However, it will be apparent to those skilled in the art that these concepts may be practiced without these specific details. In some instances, well known structures and components are shown in block diagram form in order to avoid obscuring such concepts.
Several aspects of systems capable of interacting in a cloud-based environment will now be presented with reference to various apparatus and methods. These apparatus and methods will be described in the following detailed description and illustrated in the accompanying drawings by various blocks, modules, components, circuits, steps, processes, algorithms, etc. (collectively referred to as “elements”). These elements may be implemented using electronic hardware, computer software, or any combination thereof. Whether such elements are implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system.
By way of example, an element, or any portion of an element, or any combination of elements may be implemented using a “processing system” that includes one or more processors. Examples of processors include microprocessors, microcontrollers, digital signal processors (DSPs), field programmable gate arrays (FPGAs), programmable logic devices (PLDs), state machines, gated logic, discrete hardware circuits, and other suitable hardware configured to perform the various functionality described throughout this disclosure. One or more processors in the processing system may execute software. Software shall be construed broadly to mean instructions, instruction sets, code, code segments, program code, programs, subprograms, software modules, applications, software applications, software packages, routines, subroutines, objects, executables, threads of execution, procedures, functions, etc., whether referred to as software, firmware, middleware, microcode, hardware description language, or otherwise.
Accordingly, in one or more example illustrations, the functions described may be implemented in hardware, software, firmware, or any combination thereof. If implemented in software, the functions may be stored on or encoded as one or more instructions or code on a computer-readable medium. Computer-readable media includes computer storage media. Storage media may be any available media that can be accessed by a computer. By way of example, and not limitation, such computer-readable media can comprise random-access memory (RAM), read-only memory (ROM), Electrically Erasable Programmable ROM (EEPROM), compact disk (CD) ROM (CD-ROM) or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to carry or store desired program code in the form of instructions or data structures and that can be accessed by a computer. Disk and disc, as used herein, includes CD, laser disc, optical disc, digital versatile disc (DVD), floppy disk and Blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.
Computer system 200 includes one or more processors, such as processor 204. The processor 204 is connected to a communication infrastructure 206 (e.g., a communications bus, cross-over bar, or network). Various software implementations are described in terms of this example computer system. After reading this description, it will become apparent to a person skilled in the relevant art(s) how to implement the invention using other computer systems and/or architectures.
Computer system 200 can include a display interface 202 that forwards graphics, text, and other data from the communication infrastructure 206 (or from a frame buffer not shown) for display on a display unit 230. Computer system 200 also includes a main memory 208, preferably RAM, and may also include a secondary memory 210. The secondary memory 210 may include, for example, a hard disk drive 212 and/or a removable storage drive 214, representing a floppy disk drive, a magnetic tape drive, an optical disk drive, etc. The removable storage drive 214 reads from and/or writes to a removable storage unit 218 in a well-known manner. Removable storage unit 218, represents a floppy disk, magnetic tape, optical disk, etc., which is read by and written to removable storage drive 214. As will be appreciated, the removable storage unit 218 includes a computer usable storage medium having stored therein computer software and/or data.
In alternative implementations, secondary memory 210 may include other similar devices for allowing computer programs or other instructions to be loaded into computer system 200. Such devices may include, for example, a removable storage unit 222 and an interface 220. Examples of such may include a program cartridge and cartridge interface (such as that found in video game devices), a removable memory chip (such as an EPROM, or programmable read only memory (PROM)) and associated socket, and other removable storage units 222 and interfaces 220, which allow software and data to be transferred from the removable storage unit 222 to computer system 200.
Computer system 200 may also include a communications interface 224. Communications interface 224 allows software and data to be transferred between computer system 200 and external devices. Examples of communications interface 224 may include a modem, a network interface (such as an Ethernet card), a communications port, a Personal Computer Memory Card International Association (PCMCIA) slot and card, etc. Software and data transferred via communications interface 224 are in the form of signals 228, which may be electronic, electromagnetic, optical or other signals capable of being received by communications interface 224. These signals 228 are provided to communications interface 224 via a communications path (e.g., channel) 226. This path 226 carries signals 228 and may be implemented using wire or cable, fiber optics, a telephone line, a cellular link, a radio frequency (RF) link and/or other communications channels. In this document, the terms “computer program medium” and “computer usable medium” are used to refer generally to media such as a removable storage drive 214, a hard disk installed in hard disk drive 212, and signals 228. These computer program products provide software to the computer system 200. The invention is directed to such computer program products.
Computer programs (also referred to as computer control logic) are stored in main memory 208 and/or secondary memory 210. Computer programs may also be received via communications interface 224. Such computer programs, when executed, enable the computer system 200 to perform the features of the present invention, as discussed herein. In particular, the computer programs, when executed, enable the processor 210 to perform the features of the present invention. Accordingly, such computer programs represent controllers of the computer system 200.
In an implementation where the invention is implemented using software, the software may be stored in a computer program product and loaded into computer system 200 using removable storage drive 214, hard drive 212, or communications interface 220. The control logic (software), when executed by the processor 204, causes the processor 204 to perform the functions of the invention as described herein. In another implementation, the invention is implemented primarily in hardware using, for example, hardware components, such as application specific integrated circuits (ASICs). Implementation of the hardware state machine so as to perform the functions described herein will be apparent to persons skilled in the relevant art(s).
In yet another implementation, the invention is implemented using a combination of both hardware and software.
Discovering and analyzing a system's object model can be done statically (compile time) and/or dynamically (run-time). The static/compile time approach is the traditional approach used by compilers and static tool chains. It requires access to source code and/or static object model/schema definitions.
Current systems use static analysis of source code and/or static object model/schema definitions. When run-time information is used, it is generally used to determine object types. Instead of this previous approach, aspects presented herein dynamically create a rich meta object model and framework that is used to analyze dynamic systems in a generalized way. Very high performance is obtained via the extensive use of model and results caching. A dynamic run-time approach is a more advanced approach and requires support for run-time information, such as introspection/reflection, within the language run-time. Most modern languages support run-time type information. A static approach may be used when a run-time approach is not available.
Thus, analysis and traversal of object models for third party systems and source code can be made at run-time without the need for access to the original object model or source code. This allows cloud-based tools to be provided without direct access to the third party source code and without making any changes to the third party system. This is done by creating a canonical meta object model, from run-time and/or static type/schema information, which is then utilized at run-time. The meta object model enables the in-place object model analysis and traversal.
Aspects presented herein solve a large class of computing problems through object model analysis and traversal. For example, aspects can address deep copy, serialization, transactions, transactional memory, and in-process and distributed garbage collection.
Prior to the analysis in
For example, in
As each attribute is extracted, a determination is made as to whether there are more attributes to process. If there are additional attributes to process, the attribute matches are filtered. If the attribute matches filter criteria, the attribute is stored in a type-to-attribute cache. Once stored in the cache, a determination is made as to whether the attribute has already been analyzed by determining whether it has been registered. If so, the handler for the attribute can be obtained and an indication is made that the handlers are being visited
Once all attributes have been processed, a determination is made whether to sort the attributes. Sort order is varied based on application requirements. If a sort order is specified the attributes in the type-to-attribute cache are sorted and the sorting is stored, otherwise the natural order is stored.
Thereafter, a determination is made whether to analyze methods for the type at 412 in
The analysis results allow the discovery of the type hierarchy, attributes, and methods. For each type analyzed, a child-to-parent and parent-to-child relationship can be discovered to provide the type hierarchy. The attributes can be discovered, and this information is combined with the discovered hierarchy relationships to provide all attributes for the type. The methods can also be discovered. This information is then combined with the hierarchy information to provide all the methods for a type.
The depth of the hierarchy, attributes, and methods can all be filtered to provide subsets or views of the object model. Multiple subsets can exist simultaneously. The discovered results can also be ordered to enforce desired ordering during object model traversal. In languages where the types do not change at run-time, the results from the analysis performed in
Traversing the types in the type system requires accounting for previously visited types lest an infinite loop be created. Thus, each type discovered is checked to determine whether it has already been traversed. If it has been traversed, it is not traversed again, breaking the traversal cycle.
The analysis in
Thus, aspects include obtaining run-time information from a third party system, performing an analysis of a plurality of objects from the third party system, building a re-useable meta schema based on the analysis, caching the re-useable meta schema, and then applying run-time behaviors to the stored meta schema during traversal.
For example, if run-time object serialization behavior is desired the analysis in
If the instance has not been previously visited, it is determined whether the instance meets filter criteria at 512. If so, the run-time type information is imported at 514 and it is determined whether the handlers are registered for this instance at 516. If handlers are registered, an indication is made that the handlers are being visited at 518. At steps 520 and 522, it is determined whether the attributes and/or methods are to be visited. Once this determination is made, the previously analyzed attributes or methods are retrieved from the type analysis cache at 524 and 526. As
Thus, once an object model has been discovered, either statically or dynamically, the object instance's attributes and methods can be traversed at run-time. The entire object graph associated with an object instance can be traversed. Specifically, for an object, each of its attributes can be obtained, and if an attribute is itself an object or object reference, that object can in turn be traversed.
Traversing object instances requires accounting for previously visited instances lest an infinite loop be created. Thus, each object instance discovered is checked to see if it has already been traversed. If it has been traversed it is not traversed again, breaking the traversal cycle.
The above method provides a generalized mechanism for analyzing and then traversing any object model. In order for this general technique to be useful (e.g., implementing useful functions beyond object model discovery and run-time object traversal itself) a traversal handler interface/API is defined.
As objects and their attributes/methods are traversed the traversal handler interface/API can be called at well defined points in the traversal process.
Aspects of
Operations on objects (e.g., during traversal) are often based on object type. When source code is available and can be modified these operations are generally implemented as methods. However, when source code is not available or when the source code cannot or should not be modified, another approach is needed. Type handlers are the generalized solution to this problem.
A type handler is an arbitrary association of type to object, where the object can be an abstract interface, callback, etc. When looking up a handler for a given type the type hierarchy is followed and the “best” match is found.
Each time a new registration or de-registration is performed, the cache can be cleared.
At step 702, information is received from a third party system, the information including a plurality of objects and/or types items. The information may pertain to both run-time structure and/or compile time structure.
At step 704, the received objects/types are analyzed at run-time. This analysis can be performed without accessing the third party object model and/or the third party source code for the objects/types. This analysis may include a determination of whether each of the objects/types has previously been analyzed 710. If an object/type has previously been analyzed, the method may include accessing a cached analysis handler for the item. The analysis may further include determining attributes, methods, and/or supertypes for each object/type 712, as illustrated in more detail in
At step 706, a re-usable meta schema is created based on the analysis from 704. This may include, for example, pre-computing a type hierarchy for the plurality of analyzed object models.
At step 708, the re-usable meta-schema is cached.
This traversal 804 may be performed without accessing the third party object model/source code for the additional object/type.
Aspects of the methods described in
If the instance has not previously been visited, the method may further include analyzing the instance at run-time 914, creating a handler based on the analysis 916, and storing the handler in the cached meta schema 918.
This may include accessing at least one of a plurality of previously analyzed attributes and a plurality of previously analyzed methods for the instance 912, wherein the previously analyzed attributes and methods are stored in the cached meta schema.
Aspects of the method illustrated in
Aspects of the present invention may further include an automated system for object model analysis including means for receiving objects/types from a third party system; means for analyzing, via a processing device, the received, third party objects/types at run-time; means for creating a re-usable meta schema based on the analysis; and means for caching the re-usable meta-schema. The means may include, for example, components illustrated in
Aspects may further include an automated system for object model analysis. The system may include at least one processor, a user interface functioning via the at least one processor, and a repository accessible by the at least one processor. The processor may be configured to receive objects/types from a third party system at run-time; analyze, via a processing device, the received objects/types at run-time; create a re-usable meta schema based on the analysis; and cache the re-usable meta-schema.
Aspects may further include a computer program product comprising a non-transitory computer readable medium having control logic stored therein for causing a computer to perform object model analysis, the control logic code for: receiving objects/types from a third party system; analyzing, via a processing device, the received objects/types at run-time; creating a re-usable meta schema based on the analysis; and caching the re-usable meta-schema.
Aspects may further include an automated system for in-place object model analysis. The system may include means for receiving a third party object/type item; means for accessing a cached meta schema, the meta schema comprising a plurality of handlers for objects and types; means for determining, via a processing device, whether the instance has previously been visited in the cached meta schema; means for determining whether an instance handler is registered for the item in the cached meta schema; and means for accessing the registered instance handler, after it is determined that the handler is registered for the item in the cached meta schema.
Aspects may further include an automated system for in-place object model analysis. The system may include at least one processor, a user interface functioning via the at least one processor, and a repository accessible by the at least one processor. The processor may be configured to receive a third party object/type item; access a cached meta schema, the meta schema comprising a plurality of handlers for objects and types; determine, via a processing device, whether the instance has previously been visited in the cached meta schema; determine whether an instance handler is registered for the item in the cached meta schema; and access the registered instance handler, after it is determined that the handler is registered for the item in the cached meta schema.
Aspects may further include a computer program product comprising a non-transitory computer readable medium having control logic stored therein for causing a computer to perform object model analysis, the control logic code for: receiving a third party object/type item; accessing a cached meta schema, the meta schema comprising a plurality of handlers for objects and types; determining, via a processing device, whether the instance has previously been visited in the cached meta schema; determining whether an instance handler is registered for the item in the cached meta schema; and accessing the registered instance handler, after it is determined that the handler is registered for the item in the cached meta schema.
While this invention has been described in conjunction with the example aspects of implementations outlined above, various alternatives, modifications, variations, improvements, and/or substantial equivalents, whether known or that are or may be presently unforeseen, may become apparent to those having at least ordinary skill in the art. Accordingly, the example illustrations, as set forth above, are intended to be illustrative, not limiting. Various changes may be made without departing from the spirit and scope of the invention. Therefore, the invention is intended to embrace all known or later-developed alternatives, modifications, variations, improvements, and/or substantial equivalents.
This application claims the benefit of U.S. Provisional Application No. 61/424,294 entitled “IN-PLACE OBJECT MODEL ANALYSIS AND TRAVERSAL SYSTEM AND METHOD THEREOF” filed on Dec. 17, 2010, which is expressly incorporated by reference herein in its entirety.
Number | Date | Country | |
---|---|---|---|
61424294 | Dec 2010 | US |