1. Technical Field
The present invention relates to a system and method for implementing a unified model for integration systems. More particularly, the present invention relates to a system and method for using a unified model for expressing an application in a dataflow diagram without artificial boundaries that, in turn, allows for greater application optimization.
2. Description of the Related Art
Applications in the integration world are typically distinguished in categories such as Batch, Transactional and Continuous. Batch Integration Applications (IA) are mostly used where a new integrated solution replaces obsolete custom-built disparate applications and migration of the existing data is required. Transactional IA emerged mainly in the form of Business Process Management (BPM), where various applications implement a business process by exchanging requests and replies with each other under transaction guarantees. And, continuous IAs are emerging applications in the decision support domain. Complex Event Processing (CEP), Event Driven Architecture (EDA), Real-time Data Mining & Knowledge Extraction, Business Activity Monitoring (BAM) are all examples of continuous applications that continuously process time sequenced data from disparate applications to provide better understanding of the data that flows in the organization.
Dominant technologies in the world of enterprise integration are ETL (Extract, Transform, Load), EAI (Enterprise Application Integration) and EII (Enterprise Information Integration). Each of these technologies has advantages and disadvantages compared to the others and, therefore, none of these technologies prevails. Although these technologies have different capabilities, they still share many concepts and components, and in many times one technology may be used instead of the other.
An SQL (Select Query Language) model is the model behind EII systems that relational databases are based on. This model expressed in SQL is transformed into a dataflow tree directed graph. The graph vertices are set-operators and data sets flow between the operators as soon as they are available. The model behind ETL systems is also a dataflow model that is similar to SQL model although this model can express any directed acyclic graph rather than just tree graphs. The model behind EAI systems is the workflow model. The model can be expressed in BPEL and represent directed acyclic graphs where vertices are activities that are executed once on the incoming data.
A challenge found is that existing art has artificial distinctions that produce substantial redundancy. In addition, existing art does not provide a solution for continuous applications. Another challenge found is that each of the existing models has disadvantages compared to the other models and, therefore, selecting a system and model to use for designing an application may not always be clear to a solutions architect. In addition, many solutions may not be accomplished using existing models because of their disadvantages. As a result, a solutions architect may require a custom solution that is both expensive to develop and maintain. Furthermore, custom solutions are typically lower quality because the packaged software undergoes more rigorous testing.
What is needed, therefore, is a system and method that uses a unified model that encompasses the advantages of existing system models for expressing applications.
It has been discovered that the aforementioned challenges are resolved using a system, method, and computer program product for simulating data flow using a dataflow diagram in a dataflow computing system. The dataflow diagram includes a plurality of operators that each includes at least one input port or at least one output port. The dataflow diagram also includes a plurality of arcs that each connect one of the operator's output ports to a different operator's input port. In the dataflow diagram, a plurality of data items flow in streams along the arcs between the operators. A first operator groups the plurality of data items into a particle and performs computations on the particle grouping, which results in a computed plurality of data items. The first operator transmits the computed plurality of data items over one of the arcs to a second operator. In addition, the first operator produces control data items at one of its meta ports based upon meta-state transitions that are in response to the computations on the particle grouping. Finally, the first operator transmits the control data items to another operator that, in turn, controls the flow of the computed plurality of data items based upon the control data items.
In one embodiment, the system, method, and program product use the control data items to control the flow of the computed plurality of data items using a gate operator. In this embodiment, the gate operator prevents the computed plurality of data items from reaching a different operator until the control data items instruct the gate operator to provide the computed plurality of data items to the different operator.
In one embodiment, the system, method, and program product transmit the control data items to a second operator that instruct the second operator a time at which to process the computed plurality of data items. In another embodiment, the system, method, and program product subscribes the arc connected to the meta port to receiving only a subset of the plurality of control data items.
In one embodiment, the system, method, and program product group the particle corresponding to a repeating portion of hierarchy in a hierarchical data model of the plurality of data items flowing on the plurality of arcs.
In one embodiment, the system, method, and program product couple the plurality of control data items to external resource manipulation in order to indicate the start of or completion of the external resource manipulation. In another embodiment, the system, method, and program product include parallel execution of the plurality of data items using the plurality of operators. In yet another embodiment, the system, method, and program product select the parallel execution from the group consisting of a pipelined execution and a data-parallel execution.
In one embodiment, the system, method, and program product include one or more stateful operators that accumulate state across the plurality of data items included in the particle.
In one embodiment, the system, method, and program product compile the dataflow diagram into sequential executable code. In another embodiment the system, method, and program product include a meta-state at the first operator that corresponds to a current processing state associated with the computations performed on the plurality of data items included in the particle. In yet another embodiment, the system, method, and program product express a control dependency between a plurality of activities.
In one embodiment, the system, method, and program product specify the first operator and the second operator as independent processing constructs.
In one embodiment, the system, method, and program product include a block in the data flow diagram that includes the first operator and the second operator. In another embodiment, the system, method, and program product include a block meta-state that corresponds to meta-states associated with the first operator and the second operator. In yet another embodiment, the system, method, and program product include a block meta port on the block that produces block control data based on transitions of the block meta-state.
In one embodiment, the system, method, and program product use the dataflow diagram to correspond to a batch data processing application. In another embodiment, the system, method, and program product use the dataflow diagram to correspond to a stream data processing application. In yet another embodiment, the system, method, and program product use the dataflow diagram to correspond to an event processing application. In yet another embodiment, the system, method, and program product include graphical notations in the data flow diagram. In yet another embodiment, the system, method, and program product include a non-graphical language implementation in the data flow diagram.
The foregoing is a summary and thus contains, by necessity, simplifications, generalizations, and omissions of detail; consequently, those skilled in the art will appreciate that the summary is illustrative only and is not intended to be in any way limiting. Other aspects, inventive features, and advantages of the present invention, as defined solely by the claims, will become apparent in the non-limiting detailed description set forth below.
The present invention may be better understood, and its numerous objects, features, and advantages made apparent to those skilled in the art by referencing the accompanying drawings.
The following is intended to provide a detailed description of an example of the invention and should not be taken to be limiting of the invention itself. Rather, any number of variations may fall within the scope of the invention, which is defined in the claims following the description.
System 120 includes integrated language engine 130, components store 140, dataflow diagram store 150, and code store 160. Integrated language engine 130 receives inputs 110 from user 100 for creating a dataflow diagram. A dataflow diagram is a directed acyclic graph that includes components such as operators, arcs, and blocks to express an application. Using unified model components, artificial boundaries are not placed during the application design process, thus allowing optimizations to determine how to implement different design aspects in different ways (see
Integrated language engine 130 retrieves components from components store 140 corresponding to inputs 110, and inserts the components, such as operators and/or arcs, at locations specified by user 100 on a dataflow diagram. When user 100 is finished editing the dataflow diagram, integrated language engine 130 compiles the dataflow diagram and stores the compiled code in code store 160.
Integrated language engine 130 provides user 100 with the ability to design a complex integration involving combinations of transactions, batches, streaming and event-driven behavior in a single graphical design paradigm. In addition, integrated language engine 130 also provides user 100 with the ability to express such a design in a single tool without forcing the use of different tools for different eventual execution contexts too early in the design process.
At step 220, processing retrieves unified model components from components store 140, begins generating a dataflow diagram, which is stored in dataflow diagram store 150. The dataflow diagram may correspond to applications such as a batch data processing application, a stream data processing application, or an event processing application. The dataflow diagram may include graphical notations or a non-graphical language implementation. Components store 140 and dataflow diagram store 150 are the same as that shown in
A determination is made as to whether user 100 wishes to provide more input regarding the dataflow diagram, such as adding more operators and/or connecting operators using arcs (decision 230). If user 100 wishes to provide more input, decision 230 branches to “Yes” branch 232 which loops back to process more user input. This looping continues until user 100 is finished editing the dataflow diagram, at which point decision 230 branches to “No” branch 238.
At step 240, processing compiles the dataflow diagram stored in drawings store 150 using a compiler and optimizer, and stores the compiled code in code store 160. Processing, at step 250, executes the application code and ends at 260. Code store 160 is the same as that shown in
Operator 300 includes two “meta-ports” that operator 300 produces control data items, which are arc-level meta-port 340 and particle-level meta-port 350. Arc-level meta-port 340 provides an “arc-level” meta-state, which holds operator 300's state execution from a process initialization point to a process termination point. Particle-level meta-port 350 provides a “particle-level” meta-state, which provides an execution state of an input particle at any given point of time.
In addition, meta-ports 340 and 350 are associated with a “firing rule,” which defines meta-state transitions in which a meta-state particle proceeds through a meta-port. In one embodiment, particle-level meta-port 350 may send multiple particles for a single incoming particle when more than one transition is defined.
In addition, operator 300 obeys a producer-consumer model where data is being moved by value and not by reference. In other words, particles do not share data with other particles. Operator 300 maintains a meta-state for each input particle that holds the state of the execution. When operator 300 connects to another operator, asynchronous communication may be established. In one embodiment, a user may change to a synchronous communication between two operators. In this embodiment, the change corresponds to performance optimization, and the semantics may stay asynchronous.
Operator 300 may be “stateful” or “stateless” across input particles. When stateful, operator 300 maintains an internal state between steps of execution. For example, a window operator is an operator that collects multiple particles and generates a single particle based on a given window definition. In each execution step, the window operator consumes a single particle and updates its internal state until the window ends and the output particle is produced.
When stateless, operator 300 does not maintain an internal state between execution steps. For example, in a single execution step, a sort operator consumes a single particle, sorts the underling contents inside the particle, and produces a single particle containing the sorted content. At the end of the execution step, the sort operator does not preserve a state.
Operator A 540 and operator B 560 execute corresponding algorithms in “steps.” In each step, an operator consumes a single particle from an input port and produces a finite integer number of particles on each of its output ports.
The order of the particles in an arc is the order of arrival (FIFO). However, the order of the particles is only important when the operator is a stateful operator. Thus, in implementation, a system might process particles out of order for a stateless operator and reorder the particles again if necessary before a stateful operator. When a user explicitly creates an execution branch (for example by using the Switch operator), the user may be responsible for re-achieving the execution order when necessary through available constructs. In one embodiment, the invention described herein may automatically reestablish the execution order.
Regarding particles 520-526, each particle is strongly typed by its associated schema, and particles on the same arc adhere to the same schema.
Operator 600 provides particle 615 to operator 620 over arc 610. In turn, operator 620 processes particle 615 and provides particles 635, 645, and 655 to operators 660, 670, and 680 through arcs 630, 640, and 650, respectively.
Fissioning and fusing particles achieve a change of control granularity. Using a system that processes customer orders as an example, each order includes a set of parts. In this example, a single customer order may be viewed as a particle while the parts of the order are the sub-particles within that particle. The invention described herein allows the user to describe dependencies between operations in a granularity level of the parts or in a granularity level of the order. When a user expresses the dependency only in granularity level of an order, the system may further optimize the execution by processing the parts in parallel (e.g., as a wave. See below.). In addition, through this duality, the unified integration model combines workflow model semantics with dataflow model semantics.
In addition, an “uncertainty principle” allows a system to split a wave and reorder it during processing, and then logically reconstruct the wave into particles. In other words, the actual computation on information represented by a wave may include parallel execution such as pipeline execution and data parallelism. The user, however, may view the wave as if it is in single discrete particle steps.
Delete record operator 915 includes meta-port 918, which provides control data items to operator component 940 using dataflow arcs. Delete record operator 915 produces particles that carry metastates (i.e. control data items) on an arc (metastate A 925 and metastate B 920) for incoming particles that are processed. In one embodiment, the arc subscribes to receiving only a subset of the metastates. Multi-entry gate 940 receives metastate A 925 and metastate B 920, which enables particles 945 and 950 from multi-entry gate 940's data port to pass to insert record 960, thus achieving a required sequential processing.
From a reuse standpoint, the invention described herein allows a user to reuse components and combinations of components in different execution contexts with no difference in implementation or semantics. For example, dataflow diagram 1200 includes operators 1220 and 1240, which are both sort operator components, for different sort functions. Operator 1220 sorts by parts expiration date and operator 1240 sorts by part name. In addition, dataflow diagram 1200 includes operators 1270 and 1230, which are both merge operator components. Operator 1230 merges an unavailable part count per week with an available part count per week, whereas operator 1270 merges order and customer information with available part information.
In addition, dataflow diagram 1200 may include blocks, which are a grouping of operators. These blocks include a block meta-state that corresponds to meta-states of operators that are included in the block. The block also includes a meta port that produces block control data based upon transitions of the block meta-state.
Dataflow diagram 1200 also expresses control dependencies with dataflow semantics, which is shown using operators 1250 and 1260. This combination provides a convenient approach to expressing applications as well as specifying different control levels by changing particle granularity.
Furthermore, dataflow diagram 1200 preserves hierarchical dependencies. As can be seen using operators 1210, 1240, and 1260, single concepts may be separated into multiple concepts with the ability to preserve their hierarchical dependencies.
PCI bus 1314 provides an interface for a variety of devices that are shared by host processor(s) 1300 and Service Processor 1316 including, for example, flash memory 1318. PCI-to-ISA bridge 1335 provides bus control to handle transfers between PCI bus 1314 and ISA bus 1340, universal serial bus (USB) functionality 1345, power management functionality 1355, and can include other functional elements not shown, such as a real-time clock (RTC), DMA control, interrupt support, and system management bus support. Nonvolatile RAM 1320 is attached to ISA Bus 1340. Service Processor 1316 includes JTAG and I2C busses 1322 for communication with processor(s) 1300 during initialization steps. JTAG/I2C busses 1322 are also coupled to L2 cache 1304, Host-to-PCI bridge 1306, and main memory 1308 providing a communications path between the processor, the Service Processor, the L2 cache, the Host-to-PCI bridge, and the main memory. Service Processor 1316 also has access to system power resources for powering down information handling device 1301.
Peripheral devices and input/output (I/O) devices can be attached to various interfaces (e.g., parallel interface 1362, serial interface 1364, keyboard interface 1368, and mouse interface 1370 coupled to ISA bus 1340. Alternatively, many I/O devices can be accommodated by a super I/O controller (not shown) attached to ISA bus 1340.
In order to attach computer system 1301 to another computer system to copy files over a network, LAN card 1330 is coupled to PCI bus 1310. Similarly, to connect computer system 1301 to an ISP to connect to the Internet using a telephone line connection, modem 13135 is connected to serial port 1364 and PCI-to-ISA Bridge 1335.
While
One of the preferred implementations of the invention is a client application, namely, a set of instructions (program code) in a code module that may, for example, be resident in the random access memory of the computer. Until required by the computer, the set of instructions may be stored in another computer memory, for example, in a hard disk drive, or in a removable memory such as an optical disk (for eventual use in a CD ROM) or floppy disk (for eventual use in a floppy disk drive), or downloaded via the Internet or other computer network. Thus, the present invention may be implemented as a computer program product for use in a computer. In addition, although the various methods described are conveniently implemented in a general purpose computer selectively activated or reconfigured by software, one of ordinary skill in the art would also recognize that such methods may be carried out in hardware, in firmware, or in more specialized apparatus constructed to perform the required method steps.
While particular embodiments of the present invention have been shown and described, it will be obvious to those skilled in the art that, based upon the teachings herein, that changes and modifications may be made without departing from this invention and its broader aspects. Therefore, the appended claims are to encompass within their scope all such changes and modifications as are within the true spirit and scope of this invention. Furthermore, it is to be understood that the invention is solely defined by the appended claims. It will be understood by those with skill in the art that if a specific number of an introduced claim element is intended, such intent will be explicitly recited in the claim, and in the absence of such recitation no such limitation is present. For non-limiting example, as an aid to understanding, the following appended claims contain usage of the introductory phrases “at least one” and “one or more” to introduce claim elements. However, the use of such phrases should not be construed to imply that the introduction of a claim element by the indefinite articles “a” or “an” limits any particular claim containing such introduced claim element to inventions containing only one such element, even when the same claim includes the introductory phrases “one or more” or “at least one” and indefinite articles such as “a” or “an”; the same holds true for the use in the claims of definite articles.
Number | Name | Date | Kind |
---|---|---|---|
4145733 | Misunas et al. | Mar 1979 | A |
5021947 | Campbell et al. | Jun 1991 | A |
5465372 | Gottlieb et al. | Nov 1995 | A |
5555201 | Dangelo et al. | Sep 1996 | A |
5603018 | Terada et al. | Feb 1997 | A |
5724570 | Zeller et al. | Mar 1998 | A |
5801958 | Dangelo et al. | Sep 1998 | A |
5806062 | Chen et al. | Sep 1998 | A |
5822593 | Lamping et al. | Oct 1998 | A |
6192504 | Pfluger et al. | Feb 2001 | B1 |
6311265 | Beckerle et al. | Oct 2001 | B1 |
6601058 | Forster et al. | Jul 2003 | B2 |
6654952 | Nair et al. | Nov 2003 | B1 |
6772398 | Saluja et al. | Aug 2004 | B2 |
6801938 | Bookman et al. | Oct 2004 | B1 |
6832357 | Saluja et al. | Dec 2004 | B2 |
6918111 | Damron et al. | Jul 2005 | B1 |
6954749 | Greenblatt et al. | Oct 2005 | B2 |
7080088 | Lau | Jul 2006 | B1 |
7254590 | Mudunuri et al. | Aug 2007 | B2 |
7299458 | Hammes | Nov 2007 | B2 |
7392514 | Edwards | Jun 2008 | B2 |
7467371 | Meredith et al. | Dec 2008 | B1 |
20020080181 | Razdow et al. | Jun 2002 | A1 |
20030014379 | Saias et al. | Jan 2003 | A1 |
20030061575 | Saluja et al. | Mar 2003 | A1 |
20030191765 | Bargh et al. | Oct 2003 | A1 |
20030200538 | Ebeling et al. | Oct 2003 | A1 |
20040073545 | Greenblatt et al. | Apr 2004 | A1 |
20040117772 | Brand et al. | Jun 2004 | A1 |
20040123072 | Kailas et al. | Jun 2004 | A1 |
20040205058 | Kiji | Oct 2004 | A1 |
20040207665 | Mathur | Oct 2004 | A1 |
20040225999 | Nuss | Nov 2004 | A1 |
20050071359 | Elandassery et al. | Mar 2005 | A1 |
20050097561 | Schumacher et al. | May 2005 | A1 |
20050125436 | Mudunuri et al. | Jun 2005 | A1 |
20050251527 | Phillips et al. | Nov 2005 | A1 |
20050257194 | Morrow et al. | Nov 2005 | A1 |
20050257195 | Morrow et al. | Nov 2005 | A1 |
20060005173 | Eng | Jan 2006 | A1 |
20060048113 | Ozone et al. | Mar 2006 | A1 |
20060277392 | Bittner, Jr. | Dec 2006 | A1 |
20080052687 | Gonzales-Tuchmann et al. | Feb 2008 | A1 |
20080082984 | McDaniel | Apr 2008 | A1 |
20080134158 | Salz et al. | Jun 2008 | A1 |
20090063515 | Bar-or et al. | Mar 2009 | A1 |
20090063583 | Bar-Or et al. | Mar 2009 | A1 |
20090064157 | Bar-Or et al. | Mar 2009 | A1 |
Number | Date | Country | |
---|---|---|---|
20080133209 A1 | Jun 2008 | US |