Coordinated transactions (multi-leg transactions/trading, for example multi-leg stock trading) allow submission of multiple transaction requests (for example multiple stock trading requests) in a consolidated order, which will be executed atomically as a single transaction. One example of 2-leg transaction request (order) is to “buy 200 shares of stock A” AND “sell 300 shares of stock B”, which can get executed if and only if both orders can get executed.
Multi-leg trading offers considerably more flexibility over what one would get with conventional stock trading (single-leg trading). However, implementing multi-leg transaction processing (trading) efficiently in an electronic environment is difficult.
Embodiments of the invention provide a coordinated transaction processing system capable of providing primary-primary high availability via utilization of redundant peer nodes as well as minimal response time to queries via utilization of a messaging system between partner nodes. Embodiments of the invention ensure that peer nodes within a transaction processing system give consistent replies for the same multi-leg query. Embodiments of the invention provide that the multi-leg transactions and corresponding queries are inserted into a total ordered (global) queue so that peer nodes within the transaction processing system ascertain the same query in the same context and then give consistent replies for the query.
Various embodiments of the invention supply information necessary for generating messages which avoid deadlock situations been nodes of a transaction processing system. The messages can include, for example, “virtual replies” generated from queries so that when partner nodes within the transaction processing system are querying each other simultaneously, they will get virtual replies immediately instead of waiting for the queries to be processed and actual replies issued. In certain cases, embodiments of the invention provide virtual replies which reduce round-trip communication (query and reply) to a simplified one-way communication (query only). Accordingly, embodiments of the invention provide primary-primary high-availability for multi-leg trading such that a node failure will not disrupt the entire transaction processing system as well as ensuring that communication overhead from multi-leg trading is reduced.
In summary, one aspect of the invention provides an apparatus comprising: one or more processors; one or more computer readable storage mediums having computer readable program code embodied therewith, the computer readable program code being executable by the one or more processors and comprising: computer readable program code configured to synchronize transaction processing order among the apparatus and one or more peer nodes of a transaction processing system through a shared memory; and computer readable program code configured to issue one or more queries from the apparatus to one or more partner nodes within the transaction processing system; the one or more queries being configured to ascertain if the one or more partner nodes can process one or more transactions corresponding to the one or more queries.
Another aspect of the invention provides a method comprising:
issuing one or more queries from a first electronic device to one or more partner electronic devices within a multi-leg transaction processing system; the one or more queries being configured to ascertain if the one or more partner electronic devices can process one or more transactions corresponding to the one or more queries; and the one or more queries being further configured to enable the one or more partner electronic devices to generate an indication of one or more available transactions at the first electronic device.
A further aspect of the invention provides, in a system comprised of a plurality of nodes in which the plurality of nodes have shared memory to communicate with, a method for processing transactions comprising the steps of: receiving a plurality of transactions in a different order at two or more nodes of said plurality of nodes; receiving one or more messages from one or more other nodes of said plurality of nodes at said two or more nodes of said plurality of nodes, wherein the one or more messages results from processing one or more transactions via the one or more other nodes of the plurality of nodes; and using the shared memory by the two or more nodes of said plurality of nodes to determine a mutually agreeable order for handling said plurality of transactions and said one or more messages.
A still further aspect of the invention provides a computer program product comprising a computer readable storage medium having computer readable program code embodied therewith, the computer readable program code comprising: computer readable program code configured to issue one or more queries from a first node to one or more partner nodes within a multi-leg transaction processing system; the one or more queries being configured to ascertain if the one or more partner nodes can process one or more transactions corresponding to the one or more queries; and the one or more queries being further configured to enable the one or more partner nodes to generate an indication of one or more available transactions at the first node.
For a better understanding of embodiments of the present invention, together with other and further features and advantages thereof, reference is made to the following description, taken in conjunction with the accompanying drawings, and the scope of the claimed embodiments of the invention will be pointed out in the appended claims.
It will be readily understood that the components of the embodiments of the invention, as generally described and illustrated in the figures herein, may be arranged and designed in a wide variety of different configurations in addition to the described presently preferred embodiments. Thus, the following more detailed description of the embodiments of the invention, as represented in the figures, is not intended to limit the scope of the claims but is merely representative of selected presently preferred embodiments of the invention.
Reference throughout this specification to “one embodiment” or “an embodiment” (or the like) means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the invention. Thus, appearances of the phrases “in one embodiment” or “in an embodiment” or the like in various places throughout this specification are not necessarily all referring to the same embodiment.
Furthermore, the described features, structures, or characteristics may be combined in any suitable manner in one or more embodiments. In the following description, numerous specific details are provided to give a thorough understanding of embodiments of the invention. One skilled in the relevant art will recognize, however, that the various embodiments of the invention can be practiced without one or more of the specific details, or with other methods, components, materials, etc. In other instances, well-known structures, materials, or operations are not shown or described in detail to avoid obscuring aspects of the invention.
The illustrated embodiments of the invention will be best understood by reference to the figures/drawings. The following description is intended only by way of example, and simply illustrates certain selected presently preferred embodiments of the invention as claimed herein.
The flowchart and block diagrams in the figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the blocks may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
It should be noted that although this disclosure in large part focuses on discussion of embodiments of the invention as implemented in the context of electronic stock trading involving multi-leg transactions, various embodiments of the invention are applicable to a wide variety of contexts involving multi-leg transaction processing (coordinated transaction processing), including but not limited to publish/subscribe systems, online auctions, on-line stores generally and the like. Moreover, throughout this disclosure, embodiments of the invention are described using stock trades; however, the stock trades are used herein as non-limiting examples of transaction types that may be processed by embodiments of the invention. Other transaction types may be processed by embodiments of the invention as well, such as commodities, options and the like.
The inventors have recognized that a key problem with implementing multi-leg transaction processing is how to maintain high availability because high availability is a strict and mandatory requirement of all stock exchanges. Typically a stock trading system contains many execution venues (EV). Multiple EVs that are redundant and process the same stock symbol(s) (or for example the same stock types) for the sake of high-availability will be referred to herein as peer EVs. Multiple EVs processing multiple legs of a multi-leg order respectively will be referred to herein as partner EVs.
It should be understood that in single-leg trading, there are two existing high-availability (HA) paradigms for peer EVs: primary-secondary (also known as hot back-up) and primary-primary. Most stock exchanges only support primary-secondary high availability paradigm, while primary-primary is a more promising paradigm due to its significantly lower fail-over time. A primary-primary paradigm for single-leg trading that can be extended to multi-leg trading has been proposed, however, the inventors have recognized that at least two more challenges must be addressed for implementation to be optimal. First, peer EVs should give consistent replies for the same multi-leg query; and second, partner EVs should avoid deadlock situations, particularly when querying one another directly.
Accordingly, embodiments of the invention provide methods and systems to address these challenges and provide a complete solution for implementing multi-leg trading with high availability, including primary-primary high availability, in an electronic coordinated transaction processing system.
A presently preferred embodiment of the invention provides primary-primary high-availability for multi-leg trading such that a node (EV) failure will not disrupt the entire transaction processing system as well as ensures that communication overhead from multi-leg trading is reduced. In certain cases, embodiments of the invention provide messages such as “virtual replies” which reduce round-trip communication (query and reply) to a simplified one-way communication (query only).
The inventors have recognized that a first challenge is presented by the fact that peer EVs may be processing different orders (that is have different contexts) when they receive a multi-leg query from a partner EV. However, they must give consistent replies to the query so that the redundant nature of the peer EVs will not be broken. Moreover, the inventors have recognized that partner EVs may send queries to each other simultaneously. If the partners all keep waiting for the replies to their own queries and do not response the received queries, they will come to a deadlock. Accordingly, embodiments of the invention, among other advantages, provide solutions to these challenges.
Referring now to
As shown in
PCI local bus 50 supports the attachment of a number of devices, including adapters and bridges. Among these devices is network adapter 66, which interfaces computer system 100 to LAN, and graphics adapter 68, which interfaces electronic device 100 to display 69. Communication on PCI local bus 50 is governed by local PCI controller 52, which is in turn coupled to non-volatile random access memory (NVRAM) 56 via memory bus 54. Local PCI controller 52 can be coupled to additional buses and devices via a second host bridge 60.
Computer system 100 further includes Industry Standard Architecture (ISA) bus 62, which is coupled to PCI local bus 50 by ISA bridge 64. Coupled to ISA bus 62 is an input/output (I/O) controller 70, which controls communication between computer system 100 and attached peripheral devices such as a as a keyboard, mouse, and the like. A disk controller 72 connects a disk drive with PCI local bus 50. The USB Bus and USB Controller (not shown) are part of the Local PCI controller (52).
In the context of electronic stock trading, utilized for illustrating certain embodiments of the invention, the following trading policies should be observed. For single-leg orders: a) among all orders that have been received but not traded by an EV, an order that offers a better price should get traded earlier than other orders; and, b) for orders offering the same price, the order that comes earlier should get traded earlier than other orders. For multi-leg orders: a) among all orders that have been received but not traded by an EV, an order that offers a better price should get its reply received earlier than other orders; and, b) for orders offering the same price, the order that comes earlier should get its reply received earlier than other orders.
It should be understood generally that Thread A of a first EV, when issuing a query (for example a query to a partner EV Thread B regarding a multi-leg transaction), enables Thread B of the partner EV to generate a message (for example, a “virtual reply”), which is an indication (useable by Thread A of the partner EV) of the available, related transactions at the first EV (that issued the query). The partner EV can also issue a message (for example, an actual reply) to the query received in addition to the virtual reply it generates for itself, as discussed further herein.
To address the challenges involved by multi-leg trading described herein, EVs according to an embodiment of the invention work as follows:
Thread A will regard the reply as a “not doable”. For example, Thread A of EV X sends out a query about the order y1, and then checks the mailbox. If it gets a reply about the order y2 instead of y1, it will regard y1 as “not doable on EV Y”;
Referring to
If the item is determined not to be an order, it is determined to be a query (for example, can stock X sell in EVX?). Subsequently, it is determined if the virtual reply corresponding to this query (for example, stock Y can buy in EVY) is still in the mailbox at 402. If the virtual reply (stock Y can buy in EVY) is not in the mailbox, the query (for example, can stock X sell?) is discarded. This is because the virtual reply (stock Y can buy in EVY) was already utilized (and therefore cleared) by EVX, thus the query (can stock X sell?) will no longer be a valid query. This is because a virtual reply RY-to-X is used only when a query QX-to-Y initialized from the EVX is waiting for a reply from the EVY. So this query QX-to-Y must have been sent to the partner EVY and generated another virtual reply RX-to-Y on the partner EVY. Then, the query QY-to-X that generates the virtual reply RY-to-X is no longer needed to be replied since we already have a virtual reply RX-to-Y.
If it is determined at 402 that the virtual reply (stock Y can buy in EVY) is still in the mailbox, the virtual reply (stock Y can buy in EVY) is discarded and the corresponding query (can stock X sell?) can be processed. In other words, the query (can stock X sell?) finds its own corresponding virtual reply (stock Y can buy in EVY) if it is available in the mailbox prior to the query (can stock X sell?) being answered by EVX. This processing keeps the peer EVs (for example EVX and EVX′, not shown) synchronized in the primary-primary high availability architecture as it avoids unnecessary and redundant query processing.
If it is determined at 401 that the fetched item is an order, the initiative order (the order that is just fetched from the queue) is matched against the book (of unmatched orders). At 403 it is determined if there is a match for the initiative order in the book. If no match exists, the initiative order is placed in the book and must await an incoming match. However, if a match exists in the book as determined at 403, it is determined if the order involves only single leg order(s) at 404. If the order(s) is/are only single leg, the order is processed. However, if the item is not a limited to single leg order(s) (that is, it involves a multi-leg order), a query is sent to one or more partner EVs (which may be able to complete a leg of the multi-leg transaction and must be queried to determine this). A periodic check of the mailbox is conducted in order to determine when the reply is received.
Once the reply is received, it is determined if the reply is “doable” at 405, for example, it is determined if the reply matches the query issued and contains a positive answer that the queried order can be traded on the partner EV. If the trade is completed, it is determined if the order is completed (partial match is allowed, so here if an order is just partially traded, there would be a remaining part at 406 (also considered as an order). (The term “partial match” means for example, the original order is “buy 200 shares of stock A”, and 150 A shares are bought, then a remaining order is “buy 50 shares of stock A”)). If not, the remaining order cycle back to match the remaining portions of the order against the book, et cetera. However, if the order is completed, the next item can begin processing (fetch next item from the global queue).
If it is determined that the reply is not “doable” at 405 (that is, the reply does not match the query issued), the multi-leg order is placed in the bag. At 407 it is determined if the initiative order is a single leg order. If the initiative order is a single leg order, the process again loops back to match the initiative order against the book (check for new matches that may have arrived in the book or existing orders with worse prices). However, if the initiative order is not a single leg order, the process cycles back to start.
If the message is accepted, it is determined at 502 if the message is a query (or a reply). If the message is a reply, the reply is written to the mailbox. However, if the message is a query, the corresponding virtual reply is written to the mailbox and the query is queued to the total ordered (global) queue for subsequent processing by Thread A, as discussed herein.
Again it should be noted that the above examples utilize stocks (for example stocks having particular symbols, related stocks grouped as stock types and the like) to illustrate various aspects of the invention. However, stocks are used herein as non-limiting examples of transaction types that may be processed by embodiments of the invention. Other transaction types may be processed by embodiments of the invention as well, such as commodities, options and the like.
In brief recapitulation, embodiments of the invention broadly contemplate a primary-primary transaction processing system configured to synchronize redundant (peer) nodes via use of total ordered (global) queues and reduce transaction processing delay via utilization of virtual replies, thus avoiding deadlock between partner nodes.
As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method or computer program product. Accordingly, aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “service,” “circuit,” “module” or “system.” Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer (device), partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
This disclosure has been presented for purposes of illustration and description but is not intended to be exhaustive or limiting. Many modifications and variations will be apparent to those of ordinary skill in the art. The embodiments were chosen and described in order to explain principles and practical application, and to enable others of ordinary skill in the art to understand the disclosure for various embodiments with various modifications as are suited to the particular use contemplated.
Although illustrative embodiments of the invention have been described herein with reference to the accompanying drawings, it is to be understood that the embodiments of the invention are not limited to those precise embodiments, and that various other changes and modifications may be affected therein by one skilled in the art without departing from the scope or spirit of the disclosure.