WO2001033356A1 - Method for evaluating and selecting middleware - Google Patents

Method for evaluating and selecting middleware Download PDF

Info

Publication number
WO2001033356A1
WO2001033356A1 PCT/US2000/041894 US0041894W WO0133356A1 WO 2001033356 A1 WO2001033356 A1 WO 2001033356A1 US 0041894 W US0041894 W US 0041894W WO 0133356 A1 WO0133356 A1 WO 0133356A1
Authority
WO
WIPO (PCT)
Prior art keywords
middleware
product
feature
products
scorecard
Prior art date
Application number
PCT/US2000/041894
Other languages
French (fr)
Inventor
David L. Nichols
Original Assignee
Accenture Llp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Accenture Llp filed Critical Accenture Llp
Priority to AU32682/01A priority Critical patent/AU3268201A/en
Publication of WO2001033356A1 publication Critical patent/WO2001033356A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/10Network architectures or network communication protocols for network security for controlling access to devices or network resources
    • H04L63/101Access control lists [ACL]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/20Software design
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/465Distributed object oriented systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/546Message passing systems or structures, e.g. queues
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/547Remote procedure calls [RPC]; Web services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/34Network arrangements or protocols for supporting network services or applications involving the movement of software or configuration parameters 
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/40Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass for recovering from a failure of a protocol instance or entity, e.g. service redundancy protocols, protocol state redundancy or protocol service redirection
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L2463/00Additional details relating to network architectures or network communication protocols for network security covered by H04L63/00
    • H04L2463/101Additional details relating to network architectures or network communication protocols for network security covered by H04L63/00 applying security measures for digital rights management
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/02Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/04Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks
    • H04L63/0428Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks wherein the data content is protected, e.g. by encrypting or encapsulating the payload
    • H04L63/0442Network architectures or network communication protocols for network security for providing a confidential data exchange among entities communicating through data packet networks wherein the data content is protected, e.g. by encrypting or encapsulating the payload wherein the sending and receiving network entities apply asymmetric encryption, i.e. different keys for encryption and decryption
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • H04L69/322Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
    • H04L69/329Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the application layer [OSI layer 7]

Definitions

  • This invention pertains to software and a method for evaluating software for use in businesses or enterprises.
  • middleware is a set of software services, either custom developed or vendor provided, which enables elements of distributed business or enterprise applications to interoperate. These elements share function, content, and communications across heterogeneous computing environments.
  • Middleware allows for reconciliation of differences and incompatibilities in underlying communications protocols, system architectures, operating systems, databases, and other application services. Another way to say this is that middleware provides an interface between two otherwise non-communicating systems or services.
  • Middleware typically provides an Application Programming Interface (API) which offers a set of architecture services such as platform and service location transparency, transaction management, basic messaging between two points, and guaranteed message delivery.
  • API Application Programming Interface
  • middleware hides many of the underlying technical complexities and difficulties of platforms, databases, and networks.
  • Middleware is the "glue” that binds business applications to technical infrastructure through programming interfaces.
  • One oversimplified, but vivid way of thinking about middleware, is to consider it as a "transfer protocol", or translator between programs, systems or networks of computers.
  • Middleware links architecture components to deliver more comprehensive services to applications.
  • Middleware enables distributed communications in heterogeneous environments, bridges differences and incompatibilities, and provides architecture services.
  • Figure 1 illustrates the relationship of middleware to business applications and low-level technical infrastructure services.
  • Middleware provides several key architectural benefits, including providing enhanced architecture functionality and scalability. Middleware enables portability and interoperability, and provides platform and service location transparency. Middleware simplifies programming interfaces, provides adaptability and flexibility, and enforces architecture & application uniformity. Finally, middleware enables de-coupling of application logic, and not the least of the advantages, middleware isolates developers of software, systems, and networks from technical complexity.
  • Middleware has become so useful and popular that there are now many, many middleware options available to users. The problem, therefore, is not to create middleware, but to determine which middleware may be "right" for a particular application. What is needed is a way to evaluate and rate middleware for a given application. What is needed is a template or protocol for evaluating middleware programs for their ability to perform functions in a way most advantageous and transparent to users.
  • One method of practicing the invention assists a user in obtaining middleware software for a computer application.
  • the method includes a step of gathering information about middleware products and their performance.
  • a user may proceed to evaluate the middleware products, typically by evaluating or rating a plurality of features of the product or products. After rating the products, the user selects a middleware product for the application.
  • a user may gather information about middleware or interface products likely for the application. The user may proceed to evaluate only those products, primarily for the features that are important for the given application, and then select a middleware product.
  • a computer and a computer- generated scorecard is used to rate or evaluate the middleware products available.
  • a computer processor or microprocessor and at least one computer memory is used to generate and store the scorecard.
  • This scorecard may also be in the form of a computer-generated template or macro.
  • a keyboard or computer files may be used to input the ratings or evaluations of the middleware.
  • An output file printer or a CRT monitor may be used to display the scorecard.
  • Such scorecards or scores may tend to make the process more objective and thus easier for a user.
  • the invention may also include a computer system for practicing the invention.
  • Fig. 1 depicts how middleware fits into computer applications.
  • Fig. 2 is a representation of native database access in a database access management (DBAM) application.
  • Fig. 3 represents pathways for another form of DBAM.
  • DBAM database access management
  • Figs. 4a and 4b illustrate database gateway processing in database access middleware.
  • Fig. 5 is a flow chart for message passing.
  • Fig. 6 is a flow chart for message queuing
  • Fig. 7 is a flow chart for a publish and subscribe system.
  • Fig. 8 is a chart for evaluating middleware.
  • Fig. 9 is a representation of a middleware system for an Object Request Broker (ORB).
  • Fig. 10 is a flow chart for a remote procedure call (RPC).
  • RPC remote procedure call
  • Fig. 11 is a flow chart for a transaction processing monitor (TPM).
  • TPM transaction processing monitor
  • Fig. 12 is a scorecard for evaluating middleware technical functions.
  • Fig. 13 is a scorecard for evaluating non-technical middleware functions.
  • the invention is a method and computer system for evaluating software for a given application to determine whether a particular middleware software product is suitable for the application, or if several candidates are available, to rate each candidate middleware to determine which is the best fit for the application.
  • a user determines whether there is a need for a link or application-level application programming interface (API) between two computer products.
  • These computer products may include computer systems, computer networks, operating systems, system architectures, protocols, computer platforms, databases, or other products. If the user determines there is a need for an interface or middleware product, the products available are evaluated, and if one product is suitable for the application, it is selected from among those evaluated.
  • Middleware may be considered an interface between a computer application and the technical structure supporting that application.
  • Fig. 1 depicts a business application 10 that interacts with a technical infrastructure 14 through middleware 12.
  • the technical infrastructure may have an application programmer interface (API) 15, and the middleware 12 may also have an API 13 for ease of use.
  • the middleware enables a user to more readily use the technical application, whether it is a platform application, a database, or a technical protocol, or other technical infrastructure.
  • Information technology industry experts and research organizations commonly refer to five major middleware categories: database access, message oriented, object request broker, remote procedure call, and transaction processing monitor middleware. The next section provides definitions for each category of middleware. Definitions of the Five Major Middleware Categories
  • Database Access Middleware enables a program or process to interact with databases across disparate networks, protocols, and interfaces.
  • database access middleware There are three types of database access middleware, Client-side database APIs, server-side database gateways, and Native database API.
  • Native database API also includes Embedded SQL (Structured Query Language), Stored Procedure Call, and Multidimensional and non-relational.
  • Message Oriented Middleware refers to the process of distributing data and control through the exchange of records known as messages.
  • Programs or processes communicate either asynchronously (connectionless) or synchronously (connection-oriented).
  • This category includes message broker(MB), which differs slightly from traditional MOM, in the use of an intelligent third party to move messages, rather than directly passing them from one party to another.
  • ORB Object Request Broker
  • Object Request Brokers enable program objects and components to access remote objects and components over the network and invoke operations (i.e., functions, methods).
  • ORBs typically provide interoperability between homogeneous or heterogeneous distributed applications; across languages and platforms.
  • RPC Remote Procedure Call middleware enables a program or process to make calls that are executed in another program or process. The process can be on the same computer or on a different computer in the network.
  • the calls or remote functions are made through an Application Programming Interface (API) as if these functions were called and processed locally, using a function/procedure-calling paradigm.
  • API Application Programming Interface
  • RPCs enforce a common message structure.
  • TPM Transaction Processing Monitor
  • Monitors provide synchronous messaging and queuing along with other transaction management services designed to support the efficient processing of high volumes of transactions.
  • Core services include load balancing, rollback/commit, and recovery.
  • TPMs also act as a database connection concentrator since programs and processes connect to the TP
  • Database Access Middleware enables applications to connect with various databases. This category of middleware typically performs one or more of the following three primary functions. DBAM middleware establishes communications links with server (host) databases, mapping connection paths, establishing links, handling protocol conversion, and delivering data to local points. Secondly, DBAM middleware obtains information about the type and structure of the source database and translates the query accordingly. Thirdly, DBAM translates results of the query into the format that the requesting application is expecting.
  • DBAM middleware Just as there are three primary function of DBAM middleware, there are three forms of Database Access Middleware: native, client-side database APIs, and server gateways. Another option, while not directly considered middleware, is database replication, if requirements are strictly for data sharing. Replication is usually database specific and will not be covered here.
  • Fig. 2 illustrates pathways for native database access.
  • Fig. 3 illustrates pathways for client-side database API's, and
  • Figs. 4a and 4b illustrate pathways in database gateways in two different applications or situations.
  • Native database access In native database access, database vendors incorporate proprietary interfaces to their systems in order to lock customers into their products. Interfacing to a database therefore requires that applications make use of middleware which is native to the database. Use of this native database access middleware is not a choice, but is required. Native database access is most commonly, but does not need be, SQL-based. Multidimensional and/or non-relational data can also be accessed through native database access solutions. Native database access middleware performs machine translations
  • FIG. 2 depicts an example of a database program 20 interfacing with a proprietary SQL-net interface 22 between the database and the application 24.
  • An example would be an Oracle database.
  • ODBC Database Connectivity
  • SAG Open-SQL Access Group
  • CLI Call Level Interface
  • ODBC's purpose is to provide a common, client-side API for accessing data in heterogeneous, SQL-based data managers.
  • Database drivers translate ODBC client APIs into the native equivalent on the back-end database platform. It is important to note that ODBC implementations are limited to two-tier architectures.
  • Fig. 3 depicts the ODBC architecture.
  • An application 32 uses the ODBC 34 to send SQL statements to a common client-side API 36 for accessing the database 38, and to retrieve the results from the database.
  • Internal ODBC architecture may include a driver manager and one or more ODBC drivers.
  • a driver manager loads ODBC drivers on the application's behalf.
  • Each driver is a dynamic link library (DLL) that processes ODBC function calls (translating them as necessary to the specific syntax acceptable to the database server), submits SQL requests to the DBMS, and returns results to the application.
  • DLL dynamic link library
  • An emerging trend in client-side database APIs is Java Database Connectivity (JDBC).
  • Database gateway solutions transparently connect a client application to multiple data sources.
  • a database gateway server adds features such as a global data dictionary or catalog for location transparency, heterogeneous distributed SQL (joins and distributed transactions through two-phase commit), and a distributed optimizer.
  • Database gateways are depicted in Figs. 4a and 4b, two configurations being possible with database gateway servers. The first places the gateway between the application and the databases. The second has the application interfacing to a single database and the gateway server connecting the databases together. Regardless of the configuration, the role of the database gateway server is to enable a single application or tool to access multiple, heterogeneous data sources that may be relational and/or non-relational.
  • Native database access products may include, but are not limited to, Gupta SQL Windows, Intersolv SequeLink, Microsoft SQL Server, Oracle Net8 (formerly SQL*Net), Sybase Open Client/Open Server, and IBM Distributed Database Connectivity Services (DDCS).
  • Client-side database API products include, but are not limited to, Microsoft ODBC, Visigenic Software ODBC Driver, Tandem Computer ODBC Server, and Sun JDBC.
  • Gateway products may include, but are not limited to, Sybase MDI Gateway and OmniConnect, IBM EDA/SQL Server and Hub Server, Oracle Open Gateway, and IBM DataJoiner.
  • Replication products may be used to identically reproduce data in another form.
  • Replication products may include, but are not limited to Oracle Advanced Replication Option, Sybase Replication Server, ETI Extract, Kir International OmniReplicator, Platinum Technology InfoPump, and Prism Data Warehouse Manager.
  • the more common database access architecture depicted in Fig. 4a, has no gateways between the data requester (the client) and the data provider (the server).
  • An application 41 has an API interface 42 directly to database 45.
  • the interface may be a native database driver or ODBC middleware.
  • a gateway server 44 then provides an interface between database 43 and database 45.
  • a direct point-to-point connection between the client and the database is established, which can be accomplished using either native database drivers or ODBC middleware.
  • native database middleware can yield better performance than ODBC or three-tier database gateway
  • the less common architecture is the three-tier database gateway depicted in Fig. 4b.
  • An application 41 interfaces through a gateway 44 to one or more APIs, typically on different platforms.
  • the APIs then interface directly with databases 43, 45.
  • a database gateway implies a three-tier architecture where the client, the gateway and the target database(s) are run on different platforms.
  • each request that is sent to the gateway is parsed, analyzed, optimized and ultimately translated to the target dialect understood by the target database.
  • Gateways are one of the more difficult solutions to implement. They are cumbersome to work with in many cases, and can greatly impact performance. Native drivers are the easiest to use, but limit access to multiple data sources. ODBC helps to alleviate that, but requires a user to merge the data. 2.
  • Message Oriented Middleware Message-oriented middleware
  • MOM is a category of middleware whose purpose is to move a message from one program to another program, generally on another computer. MOM differs from other forms of program-to-program middleware, such as RPCs, because MOM communication is often connectionless, i.e., the sending and receiving programs do not interact directly. Applications that communicate with one another in a connectionless manner are sometimes called decoupled if changes to one application do not directly impact the other.
  • MOM lends itself to being less intrusive to application integration than using an RPC.
  • Message oriented middleware products generally fit into three types: message passing, message queuing, and publish & subscribe.
  • Message passing middleware is similar to RPCs in that the preliminary aim is to send messages from one application to another.
  • RPC Remote Procedure calls
  • MOM distributes interprocess communications (IPC) services (e.g., pipes, shared memory, and semaphores) over the network, allowing less structure and more flexibility to the developer.
  • IPC interprocess communications
  • Non- blocked applications can receive responses to messages sent either through an event-driven mechanism (i.e., interrupt or call-back function) or through polling.
  • Fig. 5 shows a sender 52 communicating through a network 54 directly to a receiver 56.
  • Message queuing middleware extends the message passing model to allow messages to be sent to a queue for deferred processing with guaranteed delivery. Queuing systems can act as a resource to a transaction monitor and participate in a two-phase commit session. There is a good deal of effort required to implement message queuing software as compared to straight message passing software.
  • Fig. 6 depicts the situation for message queuing, in which a message from a sender 62 goes into a queue 63 for storing before it is sent to a queue for forwarding 65 to a receiver 66.
  • P&S Publish & Subscribe.
  • P&S middleware
  • P&S provides the functionality to allow applications to publish and subscribe to events. Consumers register an interest in a piece of data by subscribing. The situation for P&S is depicted in Fig. 7.
  • a publisher 72 sends a message or story to a publisher or message broker 74.
  • the subscribers 76 then receive the story in one of several ways. Publishing events may be completely independent of any subscriptions. Communication is in one direction only, and is often one-to-many.
  • P&S software can broadcast messages by pre-configured criteria such as user type, subject, etc. P&S can also guarantee message delivery. Many P&S products require substantial effort to implement. Often this type of P&S functionality is simply built on top of the message queuing capability provided by MOM products.
  • MOM message oriented middleware
  • Publish/Subscribe - Publish/Subscribe messaging like message passing, is best used in concurrently executing systems. It provides very high performance message delivery. Publish/Subscribe is particularly useful in situations where there are a large number of receivers interested in the same information (a 1 :n relationship between suppliers and consumers of information) The publisher is not aware if anyone is receiving the messages it sends. Publish/Subscribe is the only class of MOM that is inherently event driven. The decision on which MOM class to use is ultimately driven by the nature of the data being transferred, the size of the data, the frequency of the data, the latency requirements of the data, and whether the communicating nodes are concurrently executing.
  • MB Message Broker
  • a message broker architecture is an approach for integrating heterogeneous applications.
  • a message broker facilitates program-to-program communication between disparate applications and adds value through message format transformation, message warehousing, flow control, message dictionary, administration and monitoring, protocol adapters, interface adapters, and multiple communication models.
  • Flow Control Tracks and/or organizes multi- step business procedures.
  • Message Dictionary Support for a message dictionary to hold metadata descriptions of message formats.
  • Protocol Adapters - Bridges dissimilar communication protocols for multiple interfaces.
  • Interface Adapters - Sophisticated transformation sometimes including message splitting or combining and algorithmic lookups.
  • MB message broker in production by 2001.
  • the popularity of MB is due its ability to integrate disparate systems over heterogeneous environments. Heterogeneous environments consist of hardware platforms, operating systems, programming languages, object brokers and applications. MB has emerged as the fastest growing kind of middleware, largely because of its versatility. Application designers or integrators can use MB for several implementation styles, including use for disparate environments, changes to accommodate customer expectations, and for transformation of data processing operations that were not designed for modern, high-speed, data communications.
  • MB The most common use of MB is by enterprise organizations that have a mix of heterogeneous systems and applications running on disparate environments. They seek to reduce application integration costs by centralizing the implementation, maintenance and management of required interfaces, thus going from point-to-point ("spaghetti") massaging to a well managed application integration (message broker) environment.
  • Another common use of MB is for re-engineering processes to accommodate customer focused views that require close co-operation between previously incompatible applications. This use may apply both to businesses and also to enterprises not in business, but with communications and computing needs as essential to their operations as any business. This latter may include governmental organizations, non-governmental organizations such as charitable, educational, cultural, civic or other non-profit groups.
  • the utility of the invention is not limited to any particular group or type of group.
  • MB The other common use of MB is for routing, transforming and distributing transactions from a Web server to multiple back office applications, applications which were never conceived with the Internet in mind.
  • Some of Message Broker functionality may be purchased, while other functionality is typically developed to fit a client's environment and requirements. It is recommended that migration to a Message Broker architecture to support the integration of enterprise systems should be implemented gradually.
  • a number product options are available in the MB category. These options include message distribution programs, message warehouse programs, message transformer programs, message dictionary programs, and interface engines. Interface engines may include, but are not limited to,
  • Message distribution programs include the interface engines mentioned, and also include, but are not limited to, ACI Net 24, Deluxe Data Architect, Digital Equipment's DECMessageQue, IBM MQSeries, NEON Software NEONet, S2 Network Express and TIBCO Rendezvous.
  • Message Warehouse programs include, but are not limited to, BEA Message Q, IBM MQSeries, TIBCO Rendezvous, EDI Clearinghouse (Electronic Data
  • Message transformers include, but are not limited to, the interface engines, TIBCO TIB/MessageBroker, Apertus Enterprise Integrator, New Paradigm Copernicus, Sterling Software Gentran, and TSI International Mercator.
  • Message Dictionary programs useful for this purpose include, but are not limited to, Apertus Enterprise Integrator, TSI International Mercator, Early Cloud Message Driven Processor, IBM Flowmark Application Integration Facility, and Momentum Software Visual Flow.
  • Fig. 8 may be used by architects to help determine which features are necessary for a given architecture based on the system requirements. If this does not provide enough information to reach a decision, the architect should weight or rank various features based on their perceived importance. Given well-defined system requirements and a good understanding of MOM, the choice of MOM class should be clear; however, sometimes hybrid solutions may be required.
  • Fig. 8 presents in diagrammatic form a summary of the features 81 typically present in MOM products of the three classes 83 discussed above.
  • the diagram depicts in "Harvey ball" symbolism whether a feature is present as a primary or secondary feature, or not at all.
  • Fig. 8 is itself a quick evaluation of middleware for MOM applications.
  • ORBs Object Request Brokers
  • ORBs are primarily useful for deploying object-oriented, componentized systems that need to operate in a heterogeneous environment. Put another way, ORBs are used to find (business) data in distributed environments. Of course, as applied to a non-business enterprise, the goal of finding information may be the same, but the information sought may be of a different nature.
  • the typical role of an ORB is to enable communication within one application domain with consistent design characteristics.
  • There are two "standards" for implementing distributed component messaging - the Object Management Group's CORBA, an open standard, and Microsoft's DCOM, which although not an open standard, is in use due to Microsoft's dominant position in the marketplace. The two implementations do not readily interoperate.
  • CORBA the Common Object Request Broker Architecture - is an industry standard for ORBs as defined by the Object Management Group (OMG), a consortium of practically all the major software, hardware, and system vendors (IBM, HP, Oracle, & SUN, among others. The two notable exceptions being Microsoft and Intel.)
  • OMG Object Management Group
  • An OMG ORB is expected to support request dispatch, parameter encoding, message delivery, synchronization, activation, exception handling and security mechanisms.
  • Common Facilities are services which are useful in some application domains, but need not be offered by an ORB implementation.
  • Domain Interfaces are standardized interfaces designed with specific tasks in mind for distinct vertical markets or industries.
  • DCOM the Distributed Common Object Model - has become a de facto ORB standard due to Microsoft's dominant market presence.
  • DCOM uses Microsoft's DCE RPC extension to make method calls across a network.
  • DCOM is strictly proprietary to Microsoft platforms, but most major CORBA vendors are beginning to provide bridges that enable communication between their ORBs and DCOM.
  • Fig. 9 illustrates a middleware system for ORB.
  • a client application 92 seeks to communicate with a remote service 96.
  • the client application locates an ORB 94 to activate the service 96, thereafter establishing communication between the client and the server, and allowing direct communication between the client and the service.
  • middleware for ORB include lona Orbix, Microsoft DCOM, Visigenic (from Borland) Visibroker, BEA Object Broker, v. 3.0; and Expersoft PowerBroker.
  • One of the most used applications of ORBs is to wrap legacy applications. Retrofitting an existing application with an ORB-based architecture - where the same ORB runs on all relevant platforms - allows for simple communication: synchronous request/reply between one requester program and one server program.
  • ORBs on mainframes allow mainframe applications to interact as equal participants with other CORBA-based applications. Placing the ORB on a mid-tier system (e.g., NT or Unix) is more flexible, with no impact on the mainframe. This is the more common solution, since few ORBs exist for mainframe systems (one example is lona's Orb on
  • ORB applications An important factor when developing ORB applications is to choose the appropriate level of business component granularity. Large-grained components have greater reuse power, while smaller-grained components have better reuse flexibility. By creating smaller components, functionality is increased but maintenance is made harder in terms of scalability and maintainability. The main issue here is network traffic. "True distributed" object systems using ORBs are unfeasible due to significant network overhead.
  • An OTM is an application platform, like mainframe CICS in function but goes beyond the most ambitious middleware product.
  • an OTM is a hybrid of TP monitor and ORB technologies, combining the efficiency and security of TP monitors with object-oriented management.
  • OTM is a crucial piece of the infrastructure required to develop robust transaction-based applications for the Internet or intranet. It integrates transaction management services from the database and mainframe worlds with object-oriented technology.
  • OTM is highly suited for enterprises where some kind of ORB environment exists and needs to be upgraded to include secure transactional capabilities. OTM is most appropriate for applications that are complex and need to be changed or revised often. OTM provides a component approach, which could provide a way to divide an application into easy to handle modules. Enterprises will benefit from the rich infrastructure of an OTM without having to manage all its technical detail. OTMs are seen as the next step toward seamless consolidation of disparate applications. Application designers or integrators can implement OTM in the three following environments: (1) transaction oriented environment where ORB's flexibility is required; (2) adding secure transactional capabilities to ORB's environments; and (3) replacing and upgrading exiting ORB's environments.
  • RPCs Remote Procedure calls
  • TCP/IP sockets to communicate, RPCs extend the conventional procedure-based programming model to distributed networking in a manner that is similar to standard subroutine calls executing locally.
  • RPC middleware redirects procedure calls to some other processor for execution and returns procedure results to the caller.
  • RPC APIs that facilitate send and receive functionality are relatively simple and contain only a few verbs (e.g., connect, send, receive, disconnect).
  • RPCs are conceptually simple, as shown in Fig. 10.
  • An RPC application 100 includes a client 101 making a request of a (typically remote) server 104, as described above. The server executes the request and replies to the client 101. Both the request and the reply are typically made through architecture layers 102, 105, and a client stub 103 and a server stub 106.
  • ORBs and TPMs are implemented today using RPCs and similar request/reply mechanisms.
  • RPC is sometimes used in a general sense to describe any request/reply (or call-and-return) middleware service that provides basic data-type translation and connection-oriented communication services.
  • RPC refers just to those products that use an interface definition language (IDL) for describing the argument lists for outgoing and incoming parameters.
  • Interface definitions using IDL are the input for compilers that generate client stubs and server stubs.
  • RPCs provide the communications foundation for scalable processing domains that can approximate the power of mainframe computers. This allows inexpensive computers to achieve the same effective processing capability and is a prime motivator for some reengineering and downsizing efforts.
  • building an architecture using RPCs is a significant custom development effort.
  • considerable testing is required to achieve an industrial strength solution, and few tools exist today to facilitate architecture development and testing with RPCs.
  • RPCs are less robust than alternative middleware technologies for supporting mission- critical, client/server applications. It is therefore rare today for architectures to be based solely on RPCs. Only in situations where there was significant custom application development would RPCs be required as the foundation for architecture development. However, many higher level middleware products (e.g., TPM, ORB, and DBAM) use low-level RPC middleware as the foundation for distributed communications across networks. RPCs and similar request/reply services are seldom used as stand-alone architecture solutions; they are often combined with some set of other services. Some products are relatively unbundled. Others are primarily database gateways that incorporate an RPC mechanism as a supplement to their primary mission.
  • middleware e.g., TPM, ORB, and DBAM
  • RPCs or RPC-like mechanisms are typically embedded in transaction processing monitors, such as IBM's CICS, Transarc's Encina, and BEA's Tuxedo. RPCs are also embedded in development and run-time environments, such as Borland/Open Environment Corp.'s (OEC's) Entera,
  • Application packages such as SAP's R/3 Remote Function Calls also may include an RPC or RPC-like mechanism.
  • RPCs add structure by defining inputs and outputs for messaging
  • RPCs are generally too low-level for common implementations. Most prefer to buy rather than build functionality. Products are available from Microsoft, NobleNet, Sunsoft and Open Group DCE.
  • TPM Transaction Processing Monitors
  • the most significant feature of transaction processing monitors is the ability to funnel database requests from a large number of clients. TPMs allow applications to break up complex transactions into smaller units, and then ensure the completion of those transactions. Transaction processing monitors provide a management layer between the client and server to control all transactions that move through the system.
  • a TPM is depicted in Fig. 11. An example of a use for a TPM is to perform an audit.
  • the TPM 110 includes a Resource Manager 112 to interface with a plurality of clients or customers 114.
  • the TPM then uses application logic 116 to break up complex transactions into smaller units.
  • Transaction processing managers or monitors 118 provide a management layer to control all transactions moving through the system.
  • a communication 111 resource manager monitors links between the database 113 and the TPM to ensure efficient communications in the large number of transactions that are occurring.
  • TPMs are best suited for the high volume mission critical applications where heterogeneous two-phase commit - the ability to synchronize updates across two or more databases from different vendors - is needed.
  • a three tier client/server system that employs a TP monitor can manage database requests of more than 1 ,000 users using only a minimal number of database server connections. TPMs perform best if the number of services is kept to a minimum. Similarly, locating processes on the client helps to minimize network traffic.
  • TPMs are much more than two-phase commit. They provide two other distinct types of services essential to building scalable distributed applications. First, they offer robust and efficient communication services between clients and servers and between one server and another. This gives applications the ability to run efficiently over low-speed, high-latency WANs, including the Internet. Second, they offer server-based execution and state management plumbing that enables user-written services to efficiently handle thousands of client requests.
  • TPMs have intelligent routing algorithms which dynamically route transactions to the "best" application server, based on message content of an actual performance information obtained by monitoring the application server. Overloaded or failed application servers are detected, and the workload is automatically routed to a proper server while recovery takes place, significantly improving availability.
  • TPMs offered for mainframe environments include IBM's CICS, TPF and IMS/DC products.
  • Microsoft offers Microsoft Transaction Server (MTS), and other products available for client/server environments include Transaction Server from IBM, TUXEDO from BEA, Transarc's Encina, and NCR Top End.
  • a scorecard for evaluating products has been found useful, and may be used in a computerized or a manual version. Scorecards or scores will desirably utilize a "weight" or relative importance of each feature on which a particular middleware is rated or scored. Each feature may then be evaluated using a score for each feature. The scores are then multiplied by the weights and a total score for a middleware product is achieved. Choosing a vendor and a product that best suits a project's needs can be a difficult decision. It is easier if decision factors are presented clearly.
  • Table 1 lists weights for each feature and a definition corresponding to each "weight.”
  • each vendor's implementation of this feature may be assigned a score, such as a score from 0 to 3.
  • Table 2 lists one method of evaluating individual features.
  • a user is in position to evaluate one or more middleware products.
  • An embodiment of a scorecard or full evaluation sheet is depicted in Fig. 12.
  • a scorecard 120 lists one or more features 121 along the rows of the scorecard. Weights 124 are given in a separate column, one weight to be assigned for each feature as described above.
  • two middleware MOM products 126, 128 are evaluated, and the scorecard has separate columns 122 for the actual score or rating for each product, and weighted score columns 123 for each product to be evaluated.
  • a user then rates each feature for its importance in the application and assigns a weight.
  • Each feature is then evaluated for its vendor's implementation of the feature.
  • the evaluation score for each feature is the multiplied by the weight assigned to that feature, and the result is entered in the column for "weighted score" 123.
  • the weighted scores are summed, and entered in the row entitled “total score” 129.
  • the user now has an evaluation for each middleware product evaluated.
  • Features evaluated may include, but are not limited to, the ones depicted in Fig. 12. While this example featured MOM, other features may be extracted and used in a rating sheet for other types of middleware. The user is not bound to use only these features, even on MOM middleware. If a user perceives other features that are more useful, the user may select and rate those features, in addition to, or in place of, the ones used in Fig.
  • weights or weighting factors may add value to this process. In the interest of economy, or if weighting factors are not known, this factor may be converted to "unity" weighting, or 1.0, for each factor. It is preferred, but not required, that weighting factors be used.
  • a scorecard for middleware may be devised and stored on a computer system for evaluating middleware.
  • a preferred system has a different scorecard adapted for each type of middleware, i.e. one card for DBAM, one for MOM, one for TPM, etc.
  • the scorecard may then be accessed and used to evaluate middleware.
  • engineers or personnel may be assigned to evaluate middleware or to track down ratings of middleware to use in such a system.
  • One aspect of a method for obtaining middleware includes designing the technical architecture necessary for implementing the middleware.
  • middleware In a technical architecture that allows the middleware to function in the way it was intended to function. Compatability and implementation instructions are usually included with middleware products and should be followed unless circumstances allow a user to go outside the bounds prescribed. Many of the technical architectures are discussed in the sections above on specific types of middleware categories. Another aspect of a method for obtaining middleware is to implement a compatible architecture and to install the middleware on a computer system. Each middleware product and each computer system may be different, but the task is the same: install a compatible architecture, install the middleware, and adapt and use the middleware in the computer system. The discussions above for each type of middleware discuss some of the techniques for installation and implementation.
  • a computerized system will clearly assist in accessing, storing and sharing information concerning middleware products.
  • a computer system may be any convenient computer or computer system, including, but not limited to, a stand-alone personal computer, a remote-type 3270 terminal, or a networked personal computer.
  • a scorecard may be devised by any convenient means and input into the computer.
  • Convenient means include word processors and available spreadsheets, such as Microsoft's Excel ® program, or Lotus 1-2-3 spreadsheet or a Visi-Calc spreadsheet.
  • Such a spreadsheet as depicted in Fig. 12 may easily be devised and stored for ready, repeated use. It may even be made into a macro for repeated use in such a manner that the basic spreadsheet is not permanently altered when used.
  • a computerized system will desirably also have at least one memory operably connected to a processor or microprocessor of a computer.
  • a memory may be any computer memory convenient for the application, and may be RAM, ROM, or other types, and may be supplied as a hard drive, a disc drive, or other convenient means.
  • the computer system will desirably have a way to input data into the memory of the computer processor or microprocessor.
  • These input means may include a keyboard, a file, a scanner, a bar code reading device, a microphone, a transducer and digitizer, or other means or combination of means to input data.
  • inputs may be accepted by clicking (as with a mouse) on a graphical user interface.
  • Such graphical user interfaces may include, but are not limited to, radio buttons, pull-down menus, pointers, check boxes, list boxes, drop-down boxes, and the like.
  • the results of the rating may then be displayed to a user by the computer system.
  • Suitable displays may include, but are not limited to, a video output, such as a CRT or flat-panel screen, a printer, a voiced output, a computer file, or other convenient means.
  • middleware product features there are other factors that should be considered when choosing a vendor and product.
  • the product under consideration may be technically exceptional, but if enough of certain non-technical features or items raise issues, another product may be chosen. These features, or lack thereof, can usually be worked around. It is important to understand the impact of these items so that they may be allocated extra time in a planning phase for a given project.
  • One aspect of any middleware project is to plan a course of action for purchasing, installing and implementing the middleware. Factors to include in the plan include, but are not limited to, documentation for the middleware, cost, ease of installation, ease of configuration, administration costs, product support, vendor reputation, client skill base for the product, and client bias for the vendor.
  • Fig. 13 therefore depicts a second scorecard for non-technical considerations in evaluating middleware.
  • One or more considerations or factors 131 are used.
  • Weights 134 are assigned according to the importance of the factors.
  • One or more products 136, 138 are evaluated, with raw score columns 132 and weighted score columns.
  • the weighted scores are totaled and entered in the total score boxes 139.
  • This weighting format may be carried out by hand calculations, or preferably in a computer environment, such as the environment noted above for a computer spreadsheet program.
  • the weights may be entered along with formulae for multiplying them by the ratings or evaluations, along with an automatic adding that returns a numerical value as soon as the inputs, that is, the weights and the ratings, are entered.
  • weights are preferable, it is recognized that no weights or unity weights may also used. These considerations are not exclusive and others may be used, or certain of the considerations depicted may go unused in certain applications and in certain environments.
  • Documentation consideration may include an evaluation of the availability, completeness, or ease of understanding of the documentation. One consideration may be whether the documentation includes working examples. The cost of the middleware and the licensing scheme or schedule may be an important consideration. Ease of installation is desirably considered, in light of whether the purchaser has the skill sets necessary for a particular middleware product. Ease of configuration is a consideration when a user considers the effort required to setup new nodes, channels, networks, queues, etc. Administrative costs, the amount of effort and expense required to maintain the product effectively, should also be considered. Quality and availability of product support, from the middleware vendor or from third parties, should be considered before purchasing. Other considerations may include the reputation of the vendor and the number of installations accomplished.
  • a user considers whether there is a need for middleware in a computer application.
  • the user proceeds to evaluate the middleware products available, using a scorecard such as one shown in Fig. 12, after first selecting weights and criteria or considerations that are relevant or important to the application.
  • the criteria may also include non-technical factors, such as those depicted in Fig. 13. These criteria may also be important, as outlined above, but pertain more to the business, cost, or administrative effort of using a particular middleware product.
  • the invention may also work with a more limited set of considerations, that is, the considerations or factors most important to the application, in the opinion of the user, an information systems department, or a person charged with maintaining a computer system utilizing the middleware. Accordingly, it is the intention of the applicant to protect all variations and modifications within the valid scope of the present invention. It is intended that the invention be defined by the following claims, including all equivalents.

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Computing Systems (AREA)
  • Computer Hardware Design (AREA)
  • Computer And Data Communications (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)
  • Information Transfer Between Computers (AREA)
  • Storage Device Security (AREA)

Abstract

A system and method for evaluating and then selecting middleware for computing systems is revealed. The method uses a computer-generated scorecard (120) for producing weighted evaluations of middleware products. The method comprising the steps of gathering information about middleware products (121), evaluating middleware products (122, 123), and selecting a middleware product for the application. The scorecards may include both technical features and non-technical factors in the evaluations.

Description

METHOD FOR EVALUATING AND SELECTING MIDDLEWARE
REFERENCE TO EARLIER FILED APPLICATION
The present application claims the benefit of U.S. Provisional Application No. 60/163,477, filed November 3, 1999, which is incorporated by reference herein.
FIELD OF THE INVENTION
This invention pertains to software and a method for evaluating software for use in businesses or enterprises.
BACKGROUND OF THE INVENTION
While there are many possible definitions for middleware, one useful definition is that middleware is a set of software services, either custom developed or vendor provided, which enables elements of distributed business or enterprise applications to interoperate. These elements share function, content, and communications across heterogeneous computing environments. Middleware allows for reconciliation of differences and incompatibilities in underlying communications protocols, system architectures, operating systems, databases, and other application services. Another way to say this is that middleware provides an interface between two otherwise non-communicating systems or services. Middleware typically provides an Application Programming Interface (API) which offers a set of architecture services such as platform and service location transparency, transaction management, basic messaging between two points, and guaranteed message delivery. In particular, middleware hides many of the underlying technical complexities and difficulties of platforms, databases, and networks.
Middleware is the "glue" that binds business applications to technical infrastructure through programming interfaces. One oversimplified, but vivid way of thinking about middleware, is to consider it as a "transfer protocol", or translator between programs, systems or networks of computers.
Middleware links architecture components to deliver more comprehensive services to applications. Middleware enables distributed communications in heterogeneous environments, bridges differences and incompatibilities, and provides architecture services. Figure 1 illustrates the relationship of middleware to business applications and low-level technical infrastructure services.
Middleware provides several key architectural benefits, including providing enhanced architecture functionality and scalability. Middleware enables portability and interoperability, and provides platform and service location transparency. Middleware simplifies programming interfaces, provides adaptability and flexibility, and enforces architecture & application uniformity. Finally, middleware enables de-coupling of application logic, and not the least of the advantages, middleware isolates developers of software, systems, and networks from technical complexity.
Middleware has become so useful and popular that there are now many, many middleware options available to users. The problem, therefore, is not to create middleware, but to determine which middleware may be "right" for a particular application. What is needed is a way to evaluate and rate middleware for a given application. What is needed is a template or protocol for evaluating middleware programs for their ability to perform functions in a way most advantageous and transparent to users.
SUMMARY OF THE INVENTION One method of practicing the invention assists a user in obtaining middleware software for a computer application. The method includes a step of gathering information about middleware products and their performance. With the information at hand, a user may proceed to evaluate the middleware products, typically by evaluating or rating a plurality of features of the product or products. After rating the products, the user selects a middleware product for the application. In one method of practicing the invention, a user may gather information about middleware or interface products likely for the application. The user may proceed to evaluate only those products, primarily for the features that are important for the given application, and then select a middleware product.
In another embodiment of the invention, a computer and a computer- generated scorecard is used to rate or evaluate the middleware products available. A computer processor or microprocessor and at least one computer memory is used to generate and store the scorecard. This scorecard may also be in the form of a computer-generated template or macro. A keyboard or computer files may be used to input the ratings or evaluations of the middleware. An output file printer or a CRT monitor may be used to display the scorecard. Such scorecards or scores may tend to make the process more objective and thus easier for a user. Thus, the invention may also include a computer system for practicing the invention.
The invention is further described below, by means of the following figures, which are meant to describe, but not limit, the claimed invention.
BRIEF DESCRIPTION OF THE DRAWINGS
Fig. 1 depicts how middleware fits into computer applications.
Fig. 2 is a representation of native database access in a database access management (DBAM) application. Fig. 3 represents pathways for another form of DBAM.
Figs. 4a and 4b illustrate database gateway processing in database access middleware.
Fig. 5 is a flow chart for message passing.
Fig. 6 is a flow chart for message queuing Fig. 7 is a flow chart for a publish and subscribe system.
Fig. 8 is a chart for evaluating middleware.
Fig. 9 is a representation of a middleware system for an Object Request Broker (ORB). Fig. 10 is a flow chart for a remote procedure call (RPC).
Fig. 11 is a flow chart for a transaction processing monitor (TPM).
Fig. 12 is a scorecard for evaluating middleware technical functions.
Fig. 13 is a scorecard for evaluating non-technical middleware functions.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
The invention is a method and computer system for evaluating software for a given application to determine whether a particular middleware software product is suitable for the application, or if several candidates are available, to rate each candidate middleware to determine which is the best fit for the application. In one embodiment, a user determines whether there is a need for a link or application-level application programming interface (API) between two computer products. These computer products may include computer systems, computer networks, operating systems, system architectures, protocols, computer platforms, databases, or other products. If the user determines there is a need for an interface or middleware product, the products available are evaluated, and if one product is suitable for the application, it is selected from among those evaluated. Before describing the various embodiments of the invention, the reader will benefit from the detailed description of middleware products.
Middleware may be considered an interface between a computer application and the technical structure supporting that application. Fig. 1 depicts a business application 10 that interacts with a technical infrastructure 14 through middleware 12. The technical infrastructure may have an application programmer interface (API) 15, and the middleware 12 may also have an API 13 for ease of use. The middleware enables a user to more readily use the technical application, whether it is a platform application, a database, or a technical protocol, or other technical infrastructure. Information technology industry experts and research organizations commonly refer to five major middleware categories: database access, message oriented, object request broker, remote procedure call, and transaction processing monitor middleware. The next section provides definitions for each category of middleware. Definitions of the Five Major Middleware Categories
Database Access Middleware (DBAM). Database Access Middleware enables a program or process to interact with databases across disparate networks, protocols, and interfaces. There are three types of database access middleware, Client-side database APIs, server-side database gateways, and Native database API. Native database API also includes Embedded SQL (Structured Query Language), Stored Procedure Call, and Multidimensional and non-relational.
Message Oriented Middleware (MOM). Message Oriented Middleware refers to the process of distributing data and control through the exchange of records known as messages. Programs or processes communicate either asynchronously (connectionless) or synchronously (connection-oriented). There are three communication models supported, including message passing, message queuing, and publish & subscribe. This category includes message broker(MB), which differs slightly from traditional MOM, in the use of an intelligent third party to move messages, rather than directly passing them from one party to another.
Object Request Broker (ORB). Object Request Brokers enable program objects and components to access remote objects and components over the network and invoke operations (i.e., functions, methods). ORBs typically provide interoperability between homogeneous or heterogeneous distributed applications; across languages and platforms. Two fundamental types of ORBs exist, COM/DCOM-based (distributed common object model) and CORBA-based (common object request broker architecture). Remote Procedure Call (RPC). Remote Procedure Call middleware enables a program or process to make calls that are executed in another program or process. The process can be on the same computer or on a different computer in the network. The calls or remote functions are made through an Application Programming Interface (API) as if these functions were called and processed locally, using a function/procedure-calling paradigm. RPCs enforce a common message structure. Transaction Processing Monitor (TPM). Transaction Processing
Monitors provide synchronous messaging and queuing along with other transaction management services designed to support the efficient processing of high volumes of transactions. Core services include load balancing, rollback/commit, and recovery. TPMs also act as a database connection concentrator since programs and processes connect to the TP
Monitor and not the DBMS directly.
Descriptions of the Five Major Categories
1. Database Access Middleware (DBAM) enables applications to connect with various databases. This category of middleware typically performs one or more of the following three primary functions. DBAM middleware establishes communications links with server (host) databases, mapping connection paths, establishing links, handling protocol conversion, and delivering data to local points. Secondly, DBAM middleware obtains information about the type and structure of the source database and translates the query accordingly. Thirdly, DBAM translates results of the query into the format that the requesting application is expecting.
Just as there are three primary function of DBAM middleware, there are three forms of Database Access Middleware: native, client-side database APIs, and server gateways. Another option, while not directly considered middleware, is database replication, if requirements are strictly for data sharing. Replication is usually database specific and will not be covered here. Fig. 2 illustrates pathways for native database access. Fig. 3 illustrates pathways for client-side database API's, and Figs. 4a and 4b illustrate pathways in database gateways in two different applications or situations.
In native database access, database vendors incorporate proprietary interfaces to their systems in order to lock customers into their products. Interfacing to a database therefore requires that applications make use of middleware which is native to the database. Use of this native database access middleware is not a choice, but is required. Native database access is most commonly, but does not need be, SQL-based. Multidimensional and/or non-relational data can also be accessed through native database access solutions. Native database access middleware performs machine translations
(e.g., ASCII to/from EBCDIC) and hides network protocols so that the application developer doesn't have to deal with the complexity. Fig. 2 depicts an example of a database program 20 interfacing with a proprietary SQL-net interface 22 between the database and the application 24. An example would be an Oracle database.
An example of a client-side database API is Microsoft's Open
Database Connectivity (ODBC). ODBC has become a de facto standard for database independence and the ability to access multiple data sources from a single application. It is the closest the industry comes to a standard database API. ODBC is based on the X/Open-SQL Access Group (SAG) Call Level Interface (CLI) specification. ODBC's purpose is to provide a common, client-side API for accessing data in heterogeneous, SQL-based data managers. Database drivers translate ODBC client APIs into the native equivalent on the back-end database platform. It is important to note that ODBC implementations are limited to two-tier architectures.
Fig. 3 depicts the ODBC architecture. An application 32 uses the ODBC 34 to send SQL statements to a common client-side API 36 for accessing the database 38, and to retrieve the results from the database. Internal ODBC architecture may include a driver manager and one or more ODBC drivers. A driver manager loads ODBC drivers on the application's behalf. Each driver is a dynamic link library (DLL) that processes ODBC function calls (translating them as necessary to the specific syntax acceptable to the database server), submits SQL requests to the DBMS, and returns results to the application. An emerging trend in client-side database APIs is Java Database Connectivity (JDBC).
Organizations are increasingly looking to database gateways as middleware to solve data interoperability. Companies today store data on a variety of platforms, namely mainframes, workgroup and departmental servers, and desktops. Ideally, companies would like to standardize on one platform and data storage mechanism. However, standardization is hardly a realistic option for most companies, given their decentralized organizational structure and the amount of data currently in legacy systems (DB2, VSAM,
IMS, and other data sources). A better option is to rationalize existing databases behind a standard interface and integration mechanism provided by a database gateway. Database gateway solutions transparently connect a client application to multiple data sources. A database gateway server adds features such as a global data dictionary or catalog for location transparency, heterogeneous distributed SQL (joins and distributed transactions through two-phase commit), and a distributed optimizer. Database gateways are depicted in Figs. 4a and 4b, two configurations being possible with database gateway servers. The first places the gateway between the application and the databases. The second has the application interfacing to a single database and the gateway server connecting the databases together. Regardless of the configuration, the role of the database gateway server is to enable a single application or tool to access multiple, heterogeneous data sources that may be relational and/or non-relational.
Native database access products may include, but are not limited to, Gupta SQL Windows, Intersolv SequeLink, Microsoft SQL Server, Oracle Net8 (formerly SQL*Net), Sybase Open Client/Open Server, and IBM Distributed Database Connectivity Services (DDCS). Client-side database API products include, but are not limited to, Microsoft ODBC, Visigenic Software ODBC Driver, Tandem Computer ODBC Server, and Sun JDBC.
Gateway products may include, but are not limited to, Sybase MDI Gateway and OmniConnect, IBM EDA/SQL Server and Hub Server, Oracle Open Gateway, and IBM DataJoiner. Replication products may be used to identically reproduce data in another form. Replication products may include, but are not limited to Oracle Advanced Replication Option, Sybase Replication Server, ETI Extract, Praxis International OmniReplicator, Platinum Technology InfoPump, and Prism Data Warehouse Manager. The more common database access architecture, depicted in Fig. 4a, has no gateways between the data requester (the client) and the data provider (the server). An application 41 has an API interface 42 directly to database 45. The interface may be a native database driver or ODBC middleware. A gateway server 44 then provides an interface between database 43 and database 45. A direct point-to-point connection between the client and the database is established, which can be accomplished using either native database drivers or ODBC middleware. Generally speaking, native database middleware can yield better performance than ODBC or three-tier database gateways.
The less common architecture is the three-tier database gateway depicted in Fig. 4b. An application 41 interfaces through a gateway 44 to one or more APIs, typically on different platforms. The APIs then interface directly with databases 43, 45. A database gateway implies a three-tier architecture where the client, the gateway and the target database(s) are run on different platforms. Using the gateway architecture, each request that is sent to the gateway is parsed, analyzed, optimized and ultimately translated to the target dialect understood by the target database. Gateways are one of the more difficult solutions to implement. They are cumbersome to work with in many cases, and can greatly impact performance. Native drivers are the easiest to use, but limit access to multiple data sources. ODBC helps to alleviate that, but requires a user to merge the data. 2. Message Oriented Middleware. Message-oriented middleware
(MOM) is a category of middleware whose purpose is to move a message from one program to another program, generally on another computer. MOM differs from other forms of program-to-program middleware, such as RPCs, because MOM communication is often connectionless, i.e., the sending and receiving programs do not interact directly. Applications that communicate with one another in a connectionless manner are sometimes called decoupled if changes to one application do not directly impact the other.
A program sends the message to the MOM, which then takes responsibility for delivering it to the proper receiver(s). Because of the fact that messages occur between applications, it is possible that there is no need to change the applications to take advantage of messaging systems. In general, MOM lends itself to being less intrusive to application integration than using an RPC. Message oriented middleware products generally fit into three types: message passing, message queuing, and publish & subscribe.
Message Passing
Message passing middleware is similar to RPCs in that the preliminary aim is to send messages from one application to another. Remote Procedure calls (RPC), which are basically structured sockets APIs, require that the messaging be synchronous and therefore blocking. Message passing middleware, however, allows for synchronous but also non-blocking asynchronous messaging. MOM distributes interprocess communications (IPC) services (e.g., pipes, shared memory, and semaphores) over the network, allowing less structure and more flexibility to the developer. The important end result is that unlike messaging with RPCs, application messaging using message passing middleware can be conversational. Non- blocked applications can receive responses to messages sent either through an event-driven mechanism (i.e., interrupt or call-back function) or through polling. Message passing is depicted in Fig. 5, which shows a sender 52 communicating through a network 54 directly to a receiver 56.
Message Queuing (Store & Forward). Message queuing middleware extends the message passing model to allow messages to be sent to a queue for deferred processing with guaranteed delivery. Queuing systems can act as a resource to a transaction monitor and participate in a two-phase commit session. There is a good deal of effort required to implement message queuing software as compared to straight message passing software. Fig. 6 depicts the situation for message queuing, in which a message from a sender 62 goes into a queue 63 for storing before it is sent to a queue for forwarding 65 to a receiver 66.
Publish & Subscribe. Publish & subscribe (P&S) middleware is event driven middleware. P&S provides the functionality to allow applications to publish and subscribe to events. Consumers register an interest in a piece of data by subscribing. The situation for P&S is depicted in Fig. 7. A publisher 72 sends a message or story to a publisher or message broker 74. The subscribers 76 then receive the story in one of several ways. Publishing events may be completely independent of any subscriptions. Communication is in one direction only, and is often one-to-many. P&S software can broadcast messages by pre-configured criteria such as user type, subject, etc. P&S can also guarantee message delivery. Many P&S products require substantial effort to implement. Often this type of P&S functionality is simply built on top of the message queuing capability provided by MOM products.
The differences between the various classes of message oriented middleware (MOM) are significant. Below is a general overview of the requirements that lead to each MOM class. Message Passing - Message passing is most appropriate for enabling communications between concurrently executing systems requiring very fast response times and low latency. It is an especially good replacement for batch architectures that require real-time processing. Message passing is the MOM class that provides immediate confirmation that a message has been received. Message Queuing - Message queuing is useful in a wide range of messaging contexts. It provides both high performance (although not quite as high as message passing) and reliability in the form of persistent messages and guaranteed delivery. It is also a good solution for concurrently executing applications if performance requirements allow for a slight time delay. Queuing is the class of MOM that allows for disconnected operation; that is, the ability for applications to communicate without requiring all processes to be active at the same time.
Publish/Subscribe - Publish/Subscribe messaging, like message passing, is best used in concurrently executing systems. It provides very high performance message delivery. Publish/Subscribe is particularly useful in situations where there are a large number of receivers interested in the same information (a 1 :n relationship between suppliers and consumers of information) The publisher is not aware if anyone is receiving the messages it sends. Publish/Subscribe is the only class of MOM that is inherently event driven. The decision on which MOM class to use is ultimately driven by the nature of the data being transferred, the size of the data, the frequency of the data, the latency requirements of the data, and whether the communicating nodes are concurrently executing.
One facet of MOM is Message Broker (MB). MB is an emerging middleware architecture trend that has the potential to improve enterprise- wide integration strategies. The concept is to use an intelligent third party - a broker - to pass messages between multiple disparate information sources and interested consumers. A message broker architecture is an approach for integrating heterogeneous applications. A message broker facilitates program-to-program communication between disparate applications and adds value through message format transformation, message warehousing, flow control, message dictionary, administration and monitoring, protocol adapters, interface adapters, and multiple communication models.
Each of these functions are distinct, and are defined as follows:
Message Format Transformation - Transforms messages from the incoming format to different output formats.
Message Warehousing - Temporary storage of messages to be analyzed and retransmitted at a later time.
Flow Control (Workflow) - Tracks and/or organizes multi- step business procedures. Message Dictionary - Support for a message dictionary to hold metadata descriptions of message formats.
Administration and Monitoring - Manages the broker configuration.
Protocol Adapters - Bridges dissimilar communication protocols for multiple interfaces.
Interface Adapters - Sophisticated transformation, sometimes including message splitting or combining and algorithmic lookups.
Multiple Communication Models - Support for one-way messaging, queuing or publish-and-subscribe communication models in addition to request/reply communications.
It is estimated that more than one-half of large enterprises will have some form of message broker in production by 2001. The popularity of MB is due its ability to integrate disparate systems over heterogeneous environments. Heterogeneous environments consist of hardware platforms, operating systems, programming languages, object brokers and applications. MB has emerged as the fastest growing kind of middleware, largely because of its versatility. Application designers or integrators can use MB for several implementation styles, including use for disparate environments, changes to accommodate customer expectations, and for transformation of data processing operations that were not designed for modern, high-speed, data communications.
The most common use of MB is by enterprise organizations that have a mix of heterogeneous systems and applications running on disparate environments. They seek to reduce application integration costs by centralizing the implementation, maintenance and management of required interfaces, thus going from point-to-point ("spaghetti") massaging to a well managed application integration (message broker) environment. Another common use of MB is for re-engineering processes to accommodate customer focused views that require close co-operation between previously incompatible applications. This use may apply both to businesses and also to enterprises not in business, but with communications and computing needs as essential to their operations as any business. This latter may include governmental organizations, non-governmental organizations such as charitable, educational, cultural, civic or other non-profit groups. The utility of the invention is not limited to any particular group or type of group.
The other common use of MB is for routing, transforming and distributing transactions from a Web server to multiple back office applications, applications which were never conceived with the Internet in mind. Some of Message Broker functionality may be purchased, while other functionality is typically developed to fit a client's environment and requirements. It is recommended that migration to a Message Broker architecture to support the integration of enterprise systems should be implemented gradually. A number product options are available in the MB category. These options include message distribution programs, message warehouse programs, message transformer programs, message dictionary programs, and interface engines. Interface engines may include, but are not limited to,
Century Analysis Transaction Data Manager, Healthcare Communications/Perceptive Cloverleaf, Hublink Integrator, Muscato Engine, and Software Technologies DataGate, and are potentially useful for any of the other purposes mentioned, including acting as a Message Warehouse,
Message Transformer, Message Dictionary, or a Message Distribution
Mechanism. Message distribution programs include the interface engines mentioned, and also include, but are not limited to, ACI Net 24, Deluxe Data Architect, Digital Equipment's DECMessageQue, IBM MQSeries, NEON Software NEONet, S2 Network Express and TIBCO Rendezvous. Message Warehouse programs include, but are not limited to, BEA Message Q, IBM MQSeries, TIBCO Rendezvous, EDI Clearinghouse (Electronic Data
Interchange), and the interface engines mentioned. Message transformers include, but are not limited to, the interface engines, TIBCO TIB/MessageBroker, Apertus Enterprise Integrator, New Paradigm Copernicus, Sterling Software Gentran, and TSI International Mercator. Message Dictionary programs useful for this purpose include, but are not limited to, Apertus Enterprise Integrator, TSI International Mercator, Early Cloud Message Driven Processor, IBM Flowmark Application Integration Facility, and Momentum Software Visual Flow.
The sheer number of programs available suggests that a user may want to evaluate one or more of these software options before purchasing and using. To help understand the strengths and weaknesses of each MOM class, Fig. 8 may be used by architects to help determine which features are necessary for a given architecture based on the system requirements. If this does not provide enough information to reach a decision, the architect should weight or rank various features based on their perceived importance. Given well-defined system requirements and a good understanding of MOM, the choice of MOM class should be clear; however, sometimes hybrid solutions may be required.
Fig. 8 presents in diagrammatic form a summary of the features 81 typically present in MOM products of the three classes 83 discussed above. The diagram depicts in "Harvey ball" symbolism whether a feature is present as a primary or secondary feature, or not at all. Those skilled in the art will recognize that Fig. 8 is itself a quick evaluation of middleware for MOM applications.
3. Object Request Brokers. Object Request Brokers (ORBs) are primarily useful for deploying object-oriented, componentized systems that need to operate in a heterogeneous environment. Put another way, ORBs are used to find (business) data in distributed environments. Of course, as applied to a non-business enterprise, the goal of finding information may be the same, but the information sought may be of a different nature. The typical role of an ORB is to enable communication within one application domain with consistent design characteristics. There are two "standards" for implementing distributed component messaging - the Object Management Group's CORBA, an open standard, and Microsoft's DCOM, which although not an open standard, is in use due to Microsoft's dominant position in the marketplace. The two implementations do not readily interoperate. Messaging between CORBA ORBs and DCOM ORBs requires the use of a gateway solution. CORBA - the Common Object Request Broker Architecture - is an industry standard for ORBs as defined by the Object Management Group (OMG), a consortium of practically all the major software, hardware, and system vendors (IBM, HP, Oracle, & SUN, among others. The two notable exceptions being Microsoft and Intel.) An OMG ORB is expected to support request dispatch, parameter encoding, message delivery, synchronization, activation, exception handling and security mechanisms. Various Object
Services are addressed by different standards (CORBA services), e.g., event notification services, life cycle services, persistence services and concurrency control services. Common Facilities are services which are useful in some application domains, but need not be offered by an ORB implementation.
Examples of such services are User Interface facilities, Information
Management facilities and System Management facilities. Domain Interfaces are standardized interfaces designed with specific tasks in mind for distinct vertical markets or industries.
DCOM - the Distributed Common Object Model - has become a de facto ORB standard due to Microsoft's dominant market presence. DCOM uses Microsoft's DCE RPC extension to make method calls across a network. DCOM is strictly proprietary to Microsoft platforms, but most major CORBA vendors are beginning to provide bridges that enable communication between their ORBs and DCOM.
Fig. 9 illustrates a middleware system for ORB. A client application 92 seeks to communicate with a remote service 96. The client application locates an ORB 94 to activate the service 96, thereafter establishing communication between the client and the server, and allowing direct communication between the client and the service. Examples of middleware for ORB include lona Orbix, Microsoft DCOM, Visigenic (from Borland) Visibroker, BEA Object Broker, v. 3.0; and Expersoft PowerBroker. One of the most used applications of ORBs is to wrap legacy applications. Retrofitting an existing application with an ORB-based architecture - where the same ORB runs on all relevant platforms - allows for simple communication: synchronous request/reply between one requester program and one server program. ORBs on mainframes allow mainframe applications to interact as equal participants with other CORBA-based applications. Placing the ORB on a mid-tier system (e.g., NT or Unix) is more flexible, with no impact on the mainframe. This is the more common solution, since few ORBs exist for mainframe systems (one example is lona's Orb on
MVS). Integration with a Legacy system is therefore usually some sort of
"wrapper" in conjunction with a MOM product.
An important factor when developing ORB applications is to choose the appropriate level of business component granularity. Large-grained components have greater reuse power, while smaller-grained components have better reuse flexibility. By creating smaller components, functionality is increased but maintenance is made harder in terms of scalability and maintainability. The main issue here is network traffic. "True distributed" object systems using ORBs are unfeasible due to significant network overhead.
A newer "class," as they might be called, of Object Request Brokers, is Object Transaction Monitors. An OTM is an application platform, like mainframe CICS in function but goes beyond the most ambitious middleware product. Conceptually, an OTM is a hybrid of TP monitor and ORB technologies, combining the efficiency and security of TP monitors with object-oriented management. At the time of writing, there is no one product on the market that currently qualifies to be a true OTM product. However, a number of products on the market that may be useful include, but are not limited to, IBM TS, Microsoft TS, Oracle NCA, Sun's Object Transaction
Monitor, and similar products from BEA, Sybase, Expersoft, lona, ICL, SNI, Visigenic, ISIS and UniKix.
Traditional transaction monitors manage the complex tasks of synchronizing the information contained in computer databases. Transactions can include everything from a bank deposit to a customer service inquiry. The distributed Internet environment poses new challenges to older transaction systems that are best solved through the flexibility and power of object- oriented technology. OTM is a crucial piece of the infrastructure required to develop robust transaction-based applications for the Internet or intranet. It integrates transaction management services from the database and mainframe worlds with object-oriented technology.
OTM is highly suited for enterprises where some kind of ORB environment exists and needs to be upgraded to include secure transactional capabilities. OTM is most appropriate for applications that are complex and need to be changed or revised often. OTM provides a component approach, which could provide a way to divide an application into easy to handle modules. Enterprises will benefit from the rich infrastructure of an OTM without having to manage all its technical detail. OTMs are seen as the next step toward seamless consolidation of disparate applications. Application designers or integrators can implement OTM in the three following environments: (1) transaction oriented environment where ORB's flexibility is required; (2) adding secure transactional capabilities to ORB's environments; and (3) replacing and upgrading exiting ORB's environments.
4. Remote Procedure Calls. Remote procedure calls (RPCs), one of the better known types of middleware, have been available in UNIX networking since the mid-1980's. Developed by Apollo Computer (now owned by Hewlett-Packard), Sun Microsystems, the Open Group's DCE, and others, RPCs shield application developers from network complexities, providing a foundation for interoperability within and between homogeneous and heterogeneous platforms. Using TCP/IP sockets to communicate, RPCs extend the conventional procedure-based programming model to distributed networking in a manner that is similar to standard subroutine calls executing locally.
RPC middleware redirects procedure calls to some other processor for execution and returns procedure results to the caller. RPC APIs that facilitate send and receive functionality are relatively simple and contain only a few verbs (e.g., connect, send, receive, disconnect). RPCs are conceptually simple, as shown in Fig. 10. An RPC application 100 includes a client 101 making a request of a (typically remote) server 104, as described above. The server executes the request and replies to the client 101. Both the request and the reply are typically made through architecture layers 102, 105, and a client stub 103 and a server stub 106.
In general, custom extensions to the architecture layer are required to incorporate services such as error handling, security, and directory. Many multi-tier applications (e.g., SAP) as well as high level middleware such as
ORBs and TPMs are implemented today using RPCs and similar request/reply mechanisms. "RPC" is sometimes used in a general sense to describe any request/reply (or call-and-return) middleware service that provides basic data-type translation and connection-oriented communication services. In other contexts, "RPC" refers just to those products that use an interface definition language (IDL) for describing the argument lists for outgoing and incoming parameters. Interface definitions using IDL are the input for compilers that generate client stubs and server stubs. RPCs provide the communications foundation for scalable processing domains that can approximate the power of mainframe computers. This allows inexpensive computers to achieve the same effective processing capability and is a prime motivator for some reengineering and downsizing efforts. However, building an architecture using RPCs is a significant custom development effort. In addition, considerable testing is required to achieve an industrial strength solution, and few tools exist today to facilitate architecture development and testing with RPCs.
A proven technology but lacking in service offerings, RPCs are less robust than alternative middleware technologies for supporting mission- critical, client/server applications. It is therefore rare today for architectures to be based solely on RPCs. Only in situations where there was significant custom application development would RPCs be required as the foundation for architecture development. However, many higher level middleware products (e.g., TPM, ORB, and DBAM) use low-level RPC middleware as the foundation for distributed communications across networks. RPCs and similar request/reply services are seldom used as stand-alone architecture solutions; they are often combined with some set of other services. Some products are relatively unbundled. Others are primarily database gateways that incorporate an RPC mechanism as a supplement to their primary mission.
RPCs or RPC-like mechanisms are typically embedded in transaction processing monitors, such as IBM's CICS, Transarc's Encina, and BEA's Tuxedo. RPCs are also embedded in development and run-time environments, such as Borland/Open Environment Corp.'s (OEC's) Entera,
Seer's High Productivity Systems (HPS), and Software AG's Entire.
Application packages, such as SAP's R/3 Remote Function Calls also may include an RPC or RPC-like mechanism. Although advanced when compared to coding down to the sockets layer (RPCs add structure by defining inputs and outputs for messaging) RPCs are generally too low-level for common implementations. Most prefer to buy rather than build functionality. Products are available from Microsoft, NobleNet, Sunsoft and Open Group DCE.
5. Transaction Processing Monitors (TPM). The most significant feature of transaction processing monitors is the ability to funnel database requests from a large number of clients. TPMs allow applications to break up complex transactions into smaller units, and then ensure the completion of those transactions. Transaction processing monitors provide a management layer between the client and server to control all transactions that move through the system. A TPM is depicted in Fig. 11. An example of a use for a TPM is to perform an audit. The TPM 110 includes a Resource Manager 112 to interface with a plurality of clients or customers 114. The TPM then uses application logic 116 to break up complex transactions into smaller units. Transaction processing managers or monitors 118 provide a management layer to control all transactions moving through the system. A communication 111 resource manager monitors links between the database 113 and the TPM to ensure efficient communications in the large number of transactions that are occurring.
TPMs are best suited for the high volume mission critical applications where heterogeneous two-phase commit - the ability to synchronize updates across two or more databases from different vendors - is needed. A three tier client/server system that employs a TP monitor can manage database requests of more than 1 ,000 users using only a minimal number of database server connections. TPMs perform best if the number of services is kept to a minimum. Similarly, locating processes on the client helps to minimize network traffic.
TPMs are much more than two-phase commit. They provide two other distinct types of services essential to building scalable distributed applications. First, they offer robust and efficient communication services between clients and servers and between one server and another. This gives applications the ability to run efficiently over low-speed, high-latency WANs, including the Internet. Second, they offer server-based execution and state management plumbing that enables user-written services to efficiently handle thousands of client requests.
Furthermore, most TPMs have intelligent routing algorithms which dynamically route transactions to the "best" application server, based on message content of an actual performance information obtained by monitoring the application server. Overloaded or failed application servers are detected, and the workload is automatically routed to a proper server while recovery takes place, significantly improving availability. TPMs offered for mainframe environments include IBM's CICS, TPF and IMS/DC products. Microsoft offers Microsoft Transaction Server (MTS), and other products available for client/server environments include Transaction Server from IBM, TUXEDO from BEA, Transarc's Encina, and NCR Top End.
Scoring
While the above list of applications and middleware is extensive, it is not necessarily exhaustive, and all middleware is within the scope of the present invention. Having now listed possible middleware options, a user proceeds to evaluate one or more of the available middleware products for a given application. A scorecard for evaluating products has been found useful, and may be used in a computerized or a manual version. Scorecards or scores will desirably utilize a "weight" or relative importance of each feature on which a particular middleware is rated or scored. Each feature may then be evaluated using a score for each feature. The scores are then multiplied by the weights and a total score for a middleware product is achieved. Choosing a vendor and a product that best suits a project's needs can be a difficult decision. It is easier if decision factors are presented clearly.
This section describes the use of product scorecards to facilitate the presentation of information. This will allow an architect to visually weigh products against a desired system to determine which product is the best choice. For a given project, some product features are never noticed, some are paramount to the design of the system, while most other features fall somewhere between these extremes. To acknowledge this, each product feature is assigned a weight reflecting its importance to the particular project.
Table 1 below lists weights for each feature and a definition corresponding to each "weight."
Table 1.
Figure imgf000024_0001
Once each feature has an associated weight, each vendor's implementation of this feature may be assigned a score, such as a score from 0 to 3. Table 2 lists one method of evaluating individual features.
Table 2
Figure imgf000024_0002
In the example of Table 3, the use of the rating system is illustrated for a security feature of three different TPMs. 01/33356
23 Table 3
Figure imgf000025_0001
Once a weighting system is in place, and a scoring system as described above has been propounded, a user is in position to evaluate one or more middleware products. An embodiment of a scorecard or full evaluation sheet is depicted in Fig. 12. In this example, a scorecard 120 lists one or more features 121 along the rows of the scorecard. Weights 124 are given in a separate column, one weight to be assigned for each feature as described above. In this example two middleware MOM products 126, 128 are evaluated, and the scorecard has separate columns 122 for the actual score or rating for each product, and weighted score columns 123 for each product to be evaluated. In practice, a user then rates each feature for its importance in the application and assigns a weight. Each feature is then evaluated for its vendor's implementation of the feature. The evaluation score for each feature is the multiplied by the weight assigned to that feature, and the result is entered in the column for "weighted score" 123. The weighted scores are summed, and entered in the row entitled "total score" 129. The user now has an evaluation for each middleware product evaluated. Features evaluated may include, but are not limited to, the ones depicted in Fig. 12. While this example featured MOM, other features may be extracted and used in a rating sheet for other types of middleware. The user is not bound to use only these features, even on MOM middleware. If a user perceives other features that are more useful, the user may select and rate those features, in addition to, or in place of, the ones used in Fig. 12. Of course, it will be recognized that "weights" or weighting factors may add value to this process. In the interest of economy, or if weighting factors are not known, this factor may be converted to "unity" weighting, or 1.0, for each factor. It is preferred, but not required, that weighting factors be used.
In one embodiment, a scorecard for middleware may be devised and stored on a computer system for evaluating middleware. A preferred system has a different scorecard adapted for each type of middleware, i.e. one card for DBAM, one for MOM, one for TPM, etc. Especially in a large organization, or one that faces middleware questions often, such a system will desirably save time and effort on the part of software engineers and project managers. The scorecard may then be accessed and used to evaluate middleware. In another embodiment, engineers or personnel may be assigned to evaluate middleware or to track down ratings of middleware to use in such a system. One aspect of a method for obtaining middleware includes designing the technical architecture necessary for implementing the middleware. Thus, the designer must implement the middleware in a technical architecture that allows the middleware to function in the way it was intended to function. Compatability and implementation instructions are usually included with middleware products and should be followed unless circumstances allow a user to go outside the bounds prescribed. Many of the technical architectures are discussed in the sections above on specific types of middleware categories. Another aspect of a method for obtaining middleware is to implement a compatible architecture and to install the middleware on a computer system. Each middleware product and each computer system may be different, but the task is the same: install a compatible architecture, install the middleware, and adapt and use the middleware in the computer system. The discussions above for each type of middleware discuss some of the techniques for installation and implementation.
A computerized system will clearly assist in accessing, storing and sharing information concerning middleware products. Such a computer system may be any convenient computer or computer system, including, but not limited to, a stand-alone personal computer, a remote-type 3270 terminal, or a networked personal computer. A scorecard may be devised by any convenient means and input into the computer. Convenient means include word processors and available spreadsheets, such as Microsoft's Excel® program, or Lotus 1-2-3 spreadsheet or a Visi-Calc spreadsheet. Such a spreadsheet as depicted in Fig. 12 may easily be devised and stored for ready, repeated use. It may even be made into a macro for repeated use in such a manner that the basic spreadsheet is not permanently altered when used.
A computerized system according to the invention will desirably also have at least one memory operably connected to a processor or microprocessor of a computer. Such a memory may be any computer memory convenient for the application, and may be RAM, ROM, or other types, and may be supplied as a hard drive, a disc drive, or other convenient means. The computer system will desirably have a way to input data into the memory of the computer processor or microprocessor. These input means may include a keyboard, a file, a scanner, a bar code reading device, a microphone, a transducer and digitizer, or other means or combination of means to input data. Alternatively, inputs may be accepted by clicking (as with a mouse) on a graphical user interface. Such graphical user interfaces may include, but are not limited to, radio buttons, pull-down menus, pointers, check boxes, list boxes, drop-down boxes, and the like. The results of the rating may then be displayed to a user by the computer system. Suitable displays may include, but are not limited to, a video output, such as a CRT or flat-panel screen, a printer, a voiced output, a computer file, or other convenient means.
In addition to middleware product features, there are other factors that should be considered when choosing a vendor and product. The product under consideration may be technically exceptional, but if enough of certain non-technical features or items raise issues, another product may be chosen. These features, or lack thereof, can usually be worked around. It is important to understand the impact of these items so that they may be allocated extra time in a planning phase for a given project. One aspect of any middleware project is to plan a course of action for purchasing, installing and implementing the middleware. Factors to include in the plan include, but are not limited to, documentation for the middleware, cost, ease of installation, ease of configuration, administration costs, product support, vendor reputation, client skill base for the product, and client bias for the vendor.
These considerations, while not necessarily merely technical in nature, should also weigh into the purchasing decision.
Fig. 13 therefore depicts a second scorecard for non-technical considerations in evaluating middleware. One or more considerations or factors 131 are used. Weights 134 are assigned according to the importance of the factors. One or more products 136, 138 are evaluated, with raw score columns 132 and weighted score columns. At the conclusion of the ratings, the weighted scores are totaled and entered in the total score boxes 139. This weighting format may be carried out by hand calculations, or preferably in a computer environment, such as the environment noted above for a computer spreadsheet program. The weights may be entered along with formulae for multiplying them by the ratings or evaluations, along with an automatic adding that returns a numerical value as soon as the inputs, that is, the weights and the ratings, are entered.
While weights are preferable, it is recognized that no weights or unity weights may also used. These considerations are not exclusive and others may be used, or certain of the considerations depicted may go unused in certain applications and in certain environments. Documentation consideration may include an evaluation of the availability, completeness, or ease of understanding of the documentation. One consideration may be whether the documentation includes working examples. The cost of the middleware and the licensing scheme or schedule may be an important consideration. Ease of installation is desirably considered, in light of whether the purchaser has the skill sets necessary for a particular middleware product. Ease of configuration is a consideration when a user considers the effort required to setup new nodes, channels, networks, queues, etc. Administrative costs, the amount of effort and expense required to maintain the product effectively, should also be considered. Quality and availability of product support, from the middleware vendor or from third parties, should be considered before purchasing. Other considerations may include the reputation of the vendor and the number of installations accomplished.
Existing in-house experience with the product should be considered as part of the buyer's skill base for the product. Finally, any bias toward the vendor, such as a preference for a certain platform or product, should at least be recognized. In one embodiment of the invention, a user considers whether there is a need for middleware in a computer application. The user proceeds to evaluate the middleware products available, using a scorecard such as one shown in Fig. 12, after first selecting weights and criteria or considerations that are relevant or important to the application. The criteria may also include non-technical factors, such as those depicted in Fig. 13. These criteria may also be important, as outlined above, but pertain more to the business, cost, or administrative effort of using a particular middleware product.
While this invention has been shown and described in connection with the preferred embodiments, it is apparent that certain changes and modifications, in addition to those mentioned above may be made from the basic features of this invention. Many types of organizations besides businesses may benefit from the use of this invention, e.g., any organization wishing to use or evaluate middleware. These may include governmental organizations, non-governmental organizations such as charitable, educational, cultural, civic or other non-profit groups. The utility of the invention is not limited to any particular group or type of group. In addition, there are many different types of relevant factors to consider in evaluating middleware. Computer or hand scoring may be utilized in practicing the invention. The invention is not limited to the examples given above. While it is preferable to evaluate middleware from a variety of viewpoints, and from a variety of calculations, the invention may also work with a more limited set of considerations, that is, the considerations or factors most important to the application, in the opinion of the user, an information systems department, or a person charged with maintaining a computer system utilizing the middleware. Accordingly, it is the intention of the applicant to protect all variations and modifications within the valid scope of the present invention. It is intended that the invention be defined by the following claims, including all equivalents.

Claims

I Claim:
1. A method for obtaining a middleware product for an application, comprising: gathering information about middleware products; evaluating middleware products; and selecting a middleware product for the application.
2. The method of Claim 1 , further comprising planning a course of action to implement the application.
3. The method of Claim 2, further comprising designing an architecture to implement the application.
4. The method of Claim 3, further comprising implementing said architecture and installing the selected middleware product on a computer system.
5. The method of Claim 1 , further comprising identifying middleware products that are available and selecting at least one middleware product to be evaluated.
6. The method of Claim 1 , wherein evaluating middleware products includes using a scorecard or template to evaluate at least one middleware product.
7. The method of Claim 1 , wherein evaluating middleware products includes using a scorecard or template on a computer to evaluate at least one middleware product.
8. The method of Claim 6, further comprising calculating a numerical score and displaying it on the scorecard or template, wherein the numerical score represents the evaluation of said middleware product.
9. The method of Claim 6, wherein the numerical score is a sum of weighted ratings, wherein each rating corresponds to a feature of a middleware product.
10. The method of Claim 9, wherein the weighted ratings are produced by multiplying the rating of a middleware product feature by a weight, wherein said weight represents a subjective emphasis assigned to a product feature relative to other product features.
11. The method of Claim 10, wherein said weight is selected from the group consisting of 0, 1 , 2 and 3, and wherein 0 means the feature is not related to this project, 1 means the feature may be utilized in the future, 2 means the feature may be used minimally, and 3 means that the software design is based on this feature.
12. The method of Claim 1 , wherein the middleware evaluated is database access middleware, message oriented middleware, remote procedure call middleware, object request broker middleware, or transaction processing monitor middleware.
13. The method of Claim 1 , wherein the step of evaluating includes rating at least one technical feature of the middleware, and inputting said rating on a scorecard.
14. The method of Claim 1 , wherein the step of evaluating includes rating at least one non-technical feature for the middleware, and inputting said rating on a scorecard.
15. The method of Claim 8, wherein the middleware with the highest numerical score is selected.
16. A computer system for evaluating middleware products, comprising: a computer processor; at least one memory operably connected to said processor, said memory useful for storing data concerning evaluating middleware products; and a scorecard for evaluating middleware products, said scorecard stored in said memory; display means, operably coupled to said processor; and input means, operably coupled to said processor, wherein a user may input data into the system through said input means, and the scorecard is displayed on said display means to evaluate middleware products.
17. The system of Claim 16, wherein the scorecard includes at least one rating on a technical feature on at least one of the middleware products.
18. The system of Claim 16, wherein the scorecard includes at least one rating on a non-technical feature of at least one of the middleware products.
19. The system of Claim 16, wherein the computer calculates a weighted rating for at least one feature of a middleware product.
20. The system of Claim 19, wherein the weighted ratings comprise weights selected from the group consisting of 0, 1 , 2, and 3, and wherein 0 means the feature is not related to this project, 1 means the feature may be utilized in the future, 2 means the feature may be used minimally, and 3 means that the software design is based on this feature.
21. The system of Claim 16, wherein the middleware product is database access middleware, and the technical features include at least one of access form, replication, communication styles, operations, environment and architecture.
22. The system of Claim 16, where the middleware product is message-oriented middleware, and the technical features include at least one of communication styles, receipt invocation, message properties, operations, environment and architecture.
23. The system of Claim 16, where the middleware product is remote procedure call middleware, and the technical features include at least one of communication styles, extension availability and ease of use, receipt invocation, message properties, operations, environment and architecture.
24. The system of Claim 16, where the middleware product is object request broker middleware, and the technical features include at least one of a standard for implementing distributed component messaging, communication styles, receipt invocation, message properties, operations, environment and architecture.
25. The system of Claim 16, where the middleware product is transaction processing monitoring middleware, and the technical features include at least one of routing volume, communication styles, routing algorithms, message properties, operations, environment and architecture.
26. The system of Claim 16, where the non-technical factors include at least one of documentation, cost, ease of installation, ease of configuration, administration costs, product support, vendor reputation, client skill base for the middleware product, and client bias for a vendor.
PCT/US2000/041894 1999-11-03 2000-11-03 Method for evaluating and selecting middleware WO2001033356A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU32682/01A AU3268201A (en) 1999-11-03 2000-11-03 Method for evaluating and selecting middleware

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US16347799P 1999-11-03 1999-11-03
US60/163,477 1999-11-03

Publications (1)

Publication Number Publication Date
WO2001033356A1 true WO2001033356A1 (en) 2001-05-10

Family

ID=22590178

Family Applications (3)

Application Number Title Priority Date Filing Date
PCT/US2000/030492 WO2001033339A1 (en) 1999-11-03 2000-11-03 Framework for integrating existing and new information technology applications and systems
PCT/US2000/041894 WO2001033356A1 (en) 1999-11-03 2000-11-03 Method for evaluating and selecting middleware
PCT/US2000/030420 WO2001033359A1 (en) 1999-11-03 2000-11-03 Netcentric computer security framework

Family Applications Before (1)

Application Number Title Priority Date Filing Date
PCT/US2000/030492 WO2001033339A1 (en) 1999-11-03 2000-11-03 Framework for integrating existing and new information technology applications and systems

Family Applications After (1)

Application Number Title Priority Date Filing Date
PCT/US2000/030420 WO2001033359A1 (en) 1999-11-03 2000-11-03 Netcentric computer security framework

Country Status (3)

Country Link
AU (3) AU3268201A (en)
CA (1) CA2389369C (en)
WO (3) WO2001033339A1 (en)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8620777B2 (en) 2001-11-19 2013-12-31 Hewlett-Packard Development Company, L.P. Methods, software modules and software application for logging transaction-tax-related transactions
WO2015152882A1 (en) * 2014-03-31 2015-10-08 Hewlett-Packard Development Company, L.P. Candidate services for an application
CN108009258A (en) * 2017-12-10 2018-05-08 江苏恒创软件有限公司 It is a kind of can Configuration Online data collection and analysis platform
US20180359201A1 (en) 2017-06-09 2018-12-13 Equinix, Inc. Near real-time messaging service for data center infrastructure monitoring data
FR3070213A1 (en) * 2017-08-21 2019-02-22 Amadeus S.A.S. MULTI-LAYER CONCEPT CALCULATOR OF RESPONSE TIME
US10289525B2 (en) 2017-08-21 2019-05-14 Amadeus S.A.S. Multi-layer design response time calculator
US10819556B1 (en) 2017-10-16 2020-10-27 Equinix, Inc. Data center agent for data center infrastructure monitoring data access and translation
CN116630034A (en) * 2023-07-21 2023-08-22 杭银消费金融股份有限公司 Wind control data processing system and method

Families Citing this family (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7565326B2 (en) 2000-05-25 2009-07-21 Randle William M Dialect independent multi-dimensional integrator using a normalized language platform and secure controlled access
US7418429B1 (en) * 2000-10-20 2008-08-26 Accenture Pte. Ltd. Method and system for facilitating a trusted on-line transaction between insurance businesses and networked consumers
EP1267545B1 (en) 2001-06-14 2008-08-20 International Business Machines Corporation Intrusion detection in data processing system
US7590859B2 (en) 2001-08-24 2009-09-15 Secure Computing Corporation System and method for accomplishing two-factor user authentication using the internet
TWI235580B (en) * 2002-05-03 2005-07-01 Ke-Cheng Fang Network security system and method for recording and resisting hacker
EP1806902B1 (en) * 2006-01-10 2008-06-25 Alcatel Lucent Method and login server for providing a user with a centralised login procedure
US9715325B1 (en) 2012-06-21 2017-07-25 Open Text Corporation Activity stream based interaction
US9178770B2 (en) * 2013-12-23 2015-11-03 International Business Machines Corporation Auto incorporation of new components into a hierarchical network
US20220263653A1 (en) * 2019-12-06 2022-08-18 Ismail Jibrin System, method, and device for vitality verification using a biometric one-time passcode
US11729187B2 (en) * 2020-02-24 2023-08-15 Microsoft Technology Licensing, Llc Encrypted overlay network for physical attack resiliency

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5333304A (en) * 1991-05-03 1994-07-26 International Business Machines Corporation Method and apparatus for software application evaluation utilizing compiler applications
US5574828A (en) * 1994-04-28 1996-11-12 Tmrc Expert system for generating guideline-based information tools
US5745880A (en) * 1994-10-03 1998-04-28 The Sabre Group, Inc. System to predict optimum computer platform
US5761674A (en) * 1991-05-17 1998-06-02 Shimizu Construction Co., Ltd. Integrated construction project information management system
US5771385A (en) * 1996-03-29 1998-06-23 Sun Microsystems, Inc. Setting and getting system debug flags by name at runtime
US5956513A (en) * 1997-08-07 1999-09-21 Mci Communications Corporation System and method for automated software build control
US6199193B1 (en) * 1997-03-18 2001-03-06 Fujitsu Limited Method and system for software development and software design evaluation server

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5560008A (en) * 1989-05-15 1996-09-24 International Business Machines Corporation Remote authentication and authorization in a distributed data processing system
US5321610A (en) * 1991-09-23 1994-06-14 The Cobre Group, Inc. Integrated product for implementing application software and process of developing integrated product for implementing application software
US5524047A (en) * 1993-09-15 1996-06-04 Cirrus Logic, Inc. Method and apparatus for emulating telephonic communications with a modem and headset
US6006333A (en) * 1996-03-13 1999-12-21 Sun Microsystems, Inc. Password helper using a client-side master password which automatically presents the appropriate server-side password to a particular remote server
US5748890A (en) * 1996-12-23 1998-05-05 U S West, Inc. Method and system for authenticating and auditing access by a user to non-natively secured applications
US5923756A (en) * 1997-02-12 1999-07-13 Gte Laboratories Incorporated Method for providing secure remote command execution over an insecure computer network
US5991794A (en) * 1997-07-15 1999-11-23 Microsoft Corporation Component integration system for an application program
US6076168A (en) * 1997-10-03 2000-06-13 International Business Machines Corporation Simplified method of configuring internet protocol security tunnels
US6092196A (en) * 1997-11-25 2000-07-18 Nortel Networks Limited HTTP distributed remote user authentication system

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5333304A (en) * 1991-05-03 1994-07-26 International Business Machines Corporation Method and apparatus for software application evaluation utilizing compiler applications
US5761674A (en) * 1991-05-17 1998-06-02 Shimizu Construction Co., Ltd. Integrated construction project information management system
US5574828A (en) * 1994-04-28 1996-11-12 Tmrc Expert system for generating guideline-based information tools
US5745880A (en) * 1994-10-03 1998-04-28 The Sabre Group, Inc. System to predict optimum computer platform
US5771385A (en) * 1996-03-29 1998-06-23 Sun Microsystems, Inc. Setting and getting system debug flags by name at runtime
US6199193B1 (en) * 1997-03-18 2001-03-06 Fujitsu Limited Method and system for software development and software design evaluation server
US5956513A (en) * 1997-08-07 1999-09-21 Mci Communications Corporation System and method for automated software build control

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8620777B2 (en) 2001-11-19 2013-12-31 Hewlett-Packard Development Company, L.P. Methods, software modules and software application for logging transaction-tax-related transactions
WO2015152882A1 (en) * 2014-03-31 2015-10-08 Hewlett-Packard Development Company, L.P. Candidate services for an application
US20180359201A1 (en) 2017-06-09 2018-12-13 Equinix, Inc. Near real-time messaging service for data center infrastructure monitoring data
WO2018227136A1 (en) * 2017-06-09 2018-12-13 Equinix, Inc. Near real-time messaging service for data center infrastructure monitoring data
AU2018280266B2 (en) * 2017-06-09 2020-09-10 Equinix, Inc. Near real-time messaging service for data center infrastructure monitoring data
US10904173B2 (en) 2017-06-09 2021-01-26 Equinix, Inc. Near real-time messaging service for data center infrastructure monitoring data
FR3070213A1 (en) * 2017-08-21 2019-02-22 Amadeus S.A.S. MULTI-LAYER CONCEPT CALCULATOR OF RESPONSE TIME
US10289525B2 (en) 2017-08-21 2019-05-14 Amadeus S.A.S. Multi-layer design response time calculator
US10819556B1 (en) 2017-10-16 2020-10-27 Equinix, Inc. Data center agent for data center infrastructure monitoring data access and translation
CN108009258A (en) * 2017-12-10 2018-05-08 江苏恒创软件有限公司 It is a kind of can Configuration Online data collection and analysis platform
CN116630034A (en) * 2023-07-21 2023-08-22 杭银消费金融股份有限公司 Wind control data processing system and method
CN116630034B (en) * 2023-07-21 2023-11-07 杭银消费金融股份有限公司 Wind control data processing system and method

Also Published As

Publication number Publication date
CA2389369C (en) 2012-06-05
CA2389369A1 (en) 2001-05-10
AU2248901A (en) 2001-05-14
WO2001033339A1 (en) 2001-05-10
WO2001033359A1 (en) 2001-05-10
AU2574001A (en) 2001-05-14
AU3268201A (en) 2001-05-14

Similar Documents

Publication Publication Date Title
US6775680B2 (en) High level assembler metamodel
US5586312A (en) Method and apparatus for using an independent transaction processing application as a service routine
WO2001033356A1 (en) Method for evaluating and selecting middleware
US7415715B2 (en) Transaction execution system interface and enterprise system architecture thereof
US6222533B1 (en) System and process having a universal adapter framework and providing a global user interface and global messaging bus
EP1438672B1 (en) Method, apparatus and system for a mobile web client
US7111077B1 (en) Method and apparatus for passing service requests and data from web based workstations directly to online transaction processing (OLTP) server systems
US20040111698A1 (en) System and method for design, development, and deployment of distributed applications that share data from heterogeneous and autonomous sources over the Web
US20170364549A1 (en) Systems and methods for an enterprise data integration and troubleshooting tool
US20040111464A1 (en) Type Descriptor Language (TDLanguage) metamodel
US20020069157A1 (en) Exchange fusion
EP1016989A2 (en) Extensible distributed enterprise application integration system and methods of operating same
US20070162421A1 (en) Real-Time Messaging System for Bridging RDBMSs and Message Buses
US6993585B1 (en) Method and system for handling transaction requests from workstations to OLTP enterprise server systems utilizing a common gateway
Bishop et al. A survey of middleware
WO2002065277A2 (en) Method and system for incorporating legacy applications into a distributed data processing environment
US6948002B2 (en) Method and system for a computer system to support various communication devices
Saleh et al. The distributed object computing paradigm: concepts and applications
US20060136489A1 (en) Mapping a semantic model of business collaboration to a web services meta model
US7328207B2 (en) Extensions for query persistence across requests with dynamic update for writeback
CN100464303C (en) Method of implementing distribution type operation logical calculation in structure software system
Lu et al. A distributed EDI model
Du et al. Enterprise application integration: An overview
CN109933313B (en) General interface integration method of SAP Netweaver platform and J2EE system
US8099501B1 (en) Adapter architecture

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY BZ CA CH CN CR CU CZ DE DK DM DZ EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE TR BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

122 Ep: pct application non-entry in european phase