This invention relates generally to lifecycle management and more specifically to SOA shared service lifecycle management.
In the past, software architectures have attempted to deal with increasing levels of software complexity. As the level of complexity continues to increase, traditional architectures are reaching the limit of their ability to deal with various problems. At the same time, traditional needs of information technology (IT) organizations persist. IT organizations need to respond quickly to new requirements of the business, while continuing to reduce the cost of IT to the business by absorbing and integrating new business partners, new business sets, etc.
Current IT lifecycle processes are configured to managing self-contained and siloed solutions. However, as businesses transition to service oriented architectures (SOA), traditional IT governance methods are inadequate at managing SOA shared services during their entire lifecycle. SOA is not a self-contained and siloed solution; rather it's a decomposition of solutions into a set of shared services. It is these SOA shared services that require a new lifecycle management system which takes into consideration multiple new processes that are not available or part of existing IT governance systems.
In one embodiment, there is a method for designing a service specific service oriented architecture (SOA) shared services solution. In this embodiment, the method comprises: receiving a set of service requirements for a set of SOA shared services that are developed as part of a potential SOA shared services project; refining the set of service requirements for the set of SOA shared services; and designing a service specific SOA shared services solution based on the refining.
In a second embodiment, there is a system for designing a service specific service oriented architecture (SOA) shared services solution. In this embodiment, the system comprises at least one processing unit, and memory operably associated with the at least one processing unit. There is a service solution tool, including a refinement component configured to receive a set of service requirements for a set of SOA shared services that are developed as part of a potential SOA shared services project, and refine the set of service requirements for the set of SOA shared services. A design component is configured to design a service specific SOA shared services solution based on the refined set of service requirements for the set of service requirements for the set of SOA shared services.
In a third embodiment, there is a computer-readable medium storing computer instructions, which when executed, enables a computer system to design a service specific service oriented architecture (SOA) shared services solution, the computer instructions comprising: receiving a set of service requirements for a set of SOA shared services that are developed as part of a potential SOA shared services project; refining the set of service requirements for the set of SOA shared services; and designing a service specific SOA shared services solution based on the refining.
In a fourth embodiment, there is a method for deploying a service solution tool for use in a computer system that provides for design of a service specific service oriented architecture (SOA) shared services solution. In this embodiment, a computer infrastructure is provided and is operable to: receive a set of service requirements for a set of SOA shared services that are developed as part of a potential SOA shared services project; refine the set of service requirements for the set of SOA shared services; and design a service specific SOA shared services solution based on the refined set of service requirements for the set of SOA shared services.
The drawings are not necessarily to scale. The drawings are merely schematic representations, not intended to portray specific parameters of the invention. The drawings are intended to depict only typical embodiments of the invention, and therefore should not be considered as limiting the scope of the invention. In the drawings, like numbering represents like elements.
Embodiments of this invention are directed to designing a service specific service oriented architecture (SOA) shared services solution. In these embodiments, a service solution tool provides this capability. Specifically, the service solution tool comprises a refinement component configured to receive a set of service requirements for a set of SOA shared services that are developed as part of a potential SOA shared services project, and refine the set of service requirements for the set of SOA shared services. The service solution tool further comprises a design component configured to design a service specific SOA shared services solution based on the refined set of service requirements for the set of SOA shared services.
Computer system 104 is intended to represent any type of computer system that may be implemented in deploying/realizing the teachings recited herein. In this particular example, computer system 104 represents an illustrative system for designing a service specific SOA shared services solution. It should be understood that any other computer(s) implemented under the present invention may have different components/software, but will perform similar functions. As shown, computer system 104 includes a processing unit 106, memory 108 for storing a service solution tool 153, a bus 110, and device interfaces 112.
Processing unit 106 collects and routes signals representing outputs from external devices 115 (e.g., a keyboard, a pointing device, a display, a graphical user interface, etc.) to service solution tool 153. The signals can be transmitted over a LAN and/or a WAN (e.g., T1, T3, 56 kb, X.25), broadband connections (ISDN, Frame Relay, ATM), wireless links (802.11, Bluetooth, etc.), and so on. In some embodiments, the signals may be encrypted using, for example, trusted key-pair encryption. Different external devices may transmit information using different communication pathways, such as Ethernet or wireless networks, direct serial or parallel connections, USB, Firewire®, Bluetooth®, or other proprietary interfaces. (Firewire is a registered trademark of Apple Computer, Inc. Bluetooth is a registered trademark of Bluetooth Special Interest Group (SIG)).
In general, processing unit 106 executes computer program code, such as program code for operating service solution tool 153, which is stored in memory 108 and/or storage system 116. While executing computer program code, processing unit 106 can read and/or write data to/from memory 108, storage system 116, and a services registry 117. Services registry 117 stores a plurality of SOA services and associated metadata, as well as rules against which the metadata is compared to locate, store, and update SOA shared services. Storage systems 116, 117 can include VCRs, DVRs, RAID arrays, USB hard drives, optical disk recorders, flash storage devices, or any other similar storage device.
Implementation 100 and service solution tool 153 operate within a broader SOA services lifecycle management process (SLMP) 130, shown in
SOA SLMP 130 of the present invention consists of the following distinct processes and associated methodologies:
It can be appreciated that each of the above processes is a complete methodology that can be implemented independently since they define key stakeholders, affected processes, and touch-points throughout the organization. Each of the above listed SOA processes are non-limiting examples of the functionality and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each process (I-VIII) may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s) of SOA SLMP 130, as shown in
In another embodiment, refinement component 155 refines a service architecture for the set of SOA shared services based on the refined integration criteria for each of the service requirements for each of the set of SOA shared services. In this embodiment, information integration patterns for the service specific SOA shared services solution are compared against the refined integration criteria for each of the set of service requirements for compliance. Refinement component 155 is configured to analyze the set of SOA shared services for compliance with service enablement group 156 (SEG) architecture governance standards. It will be appreciated that SEG 156 described herein may represent a committee or group of individuals within an organization, or may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the elaboration of the potential SOA shared services solution.
In another embodiment, a plurality of non-SEG governing bodies (e.g., Enterprise Architecture Team, Executive Councils, Governance Center of Excellence, Governance Board, Compliance Review Boards, Special Interest Groups (e.g., for Security, Performance)) may review the service specific SOA shared services solution for adherence to their respective standards for security, capacity, etc. Specifically, refinement component 155 is configured to analyze each of the set of service requirements for each of the set of SOA shared services for compliance with non-SEG standards. This allows non-SEG governance bodies to apply compliance standards to the SOA shared services. For example, SOA shared services may have shared design points with service consumers and providers requiring collaborative design sessions between a project delivery team and resources from other teams involved in the potential SOA shared services project. In this case, the non-SEG governance bodies apply compliance processes for the shared design points against the SOA shared services.
Next, a design solution is established based on a review of the service requirements and the service architecture for the set of SOA shared services. Specifically, service solution tool 153 comprises a design component 160 configured to design a service specific SOA shared services solution based on the refined set of service requirements for the set of SOA shared services. For example, design component 160 is configured to define the input and output message formats that will be used by the SOA shared service, define message protocols for each SOA shared service, and define message flow requirements (e.g., message format mediation, protocol mediation, message filter rules, message enrichment rules, etc.). The service specific SOA shared services solution represents the rules, processes and detailed construction requirements necessary to proceed to the service construction phase of SOA SLMP 130 (
In some cases, it is beneficial to evaluate the service specific SOA shared services solution by testing a prototype solution. To accomplish this, service solution tool 153 comprises a testing component 165 configured to develop a prototype of the service specific SOA shared services solution, and evaluate the prototype of the service specific SOA shared services solution. Testing component 165 may build any number of prototypes to demonstrate and subsequently evaluate the defined message flow requirements of the solution. In one embodiment, testing component 165 is configured to establish a service specific development and testing infrastructure to develop and evaluate the service specific SOA shared services solution. In this embodiment, testing component 165 may develop integration test cases that validate the service specific SOA shared services solution for business functionality. For example, testing component 165 may determine whether the service specific SOA shared services solution meets the business requirements as defined in the BSRD, as well as the necessary technical requirements in terms of data integrity, performance, etc. Test cases, along with the required test scripts, may be defined to evaluate the integration points required to integrate various entities associated with a SOA shared service (e.g., consumer and provider applications).
Next, the service specific SOA shared services solution is reviewed for potential approval. Service solution tool 153 comprises an evaluation component 170 configured to evaluate the service specific SOA shared services solution, including any prototypes or test cases developed to observe the effectiveness of the solution. Evaluation component 170 then initiates construction of the service specific SOA shared services solution based on the evaluation. In one embodiment, the service specific SOA shared services solution is evaluated based on subsystem and component specifications. This involves collaborative design sessions between various entities involved in the project, communication and validation of service testing approaches, and complete service and component system mapping of dependencies (including business and information architectures). Further, evaluation component 170 confirms the alignment of the specified SOA service with business goals, and validates specified ownership, service, information, flow, standards, best practices, templates and compliance. Based on this evaluation, services registry 117 is notified that the service specific SOA shared services solution has been reviewed and approved for construction.
Referring now to
SOA SLMP flow 180 then proceeds to design the service specific SOA shared services solution based on the refined service requirements for the SOA shared services. As shown at SE-7, SE-8, and SE-9, respectively, definitions are established for the input and output message formats that will be used by the service, the message protocols for each service, and the message flow requirements. These definitions are then input to the Shared Services Design Document and the process proceeds to SE-10, where prototypes are built. The prototype, which is based on the service specific SOA shared services solution, is developed and then evaluated.
Next, as shown in
As shown,
It will be appreciated that SOA SLMP flow 180 of
Further, it can be appreciated that the methodologies disclosed herein can be used within a computer system to provide the design of a SOA shared services solution, as shown in
The exemplary computer system 104 may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, people, components, logic, data structures, and so on that perform particular tasks or implements particular abstract data types. Exemplary computer system 104 may be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.
Furthermore, an implementation of exemplary computer system 104 may be stored on or transmitted across some form of computer readable media. Computer readable media can be any available media that can be accessed by a computer. By way of example, and not limitation, computer readable media may comprise “computer storage media” and “communications media.”
“Computer storage media” include volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules, or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by a computer.
“Communication media” typically embodies computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as carrier wave or other transport mechanism. Communication media also includes any information delivery media.
The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared, and other wireless media. Combinations of any of the above are also included within the scope of computer readable media.
It is apparent that there has been provided with this invention an approach for elaborating the design of a SOA shared services solution. While the invention has been particularly shown and described in conjunction with a preferred embodiment thereof, it will be appreciated that variations and modifications will occur to those skilled in the art. Therefore, it is to be understood that the appended claims are intended to cover all such modifications and changes that fall within the true spirit of the invention.
The present application is related in some aspects to commonly owned and co-pending application entitled “Identification of a Service Oriented Architecture Shared Services Project”, assigned attorney docket no. END920080252US1, which was filed on Nov. 24, 2008, and was assigned application Ser. No. 12/277,280, commonly owned and co-pending application entitled “Evaluating a Service Oriented Architecture Shared Services Project”, assigned attorney docket no. END920080288US1, which was filed on Feb. 19, 2009, and was assigned application Ser. No. 12/388,533, commonly owned and co-pending application entitled “Selecting a Service Oriented Architecture Shared Service”, assigned attorney docket no. END920080289US1, which was filed on Feb. 24, 2009, and was assigned application Ser. No. 12/391,426, commonly owned and co-pending application entitled “Constructing a Service Oriented Architecture Shared Service”, assigned attorney docket no. END920080291US1, which was filed on (to be provided), and was assigned application Ser. No. (to be provided), commonly owned and co-pending application entitled “Transitioning to Management of a Service Oriented Architecture Shared Service”, assigned attorney docket no. END920080292US1, which was filed on (to be provided), and was assigned application Ser. No. (to be provided), commonly owned co-pending application entitled “Management of a Service Oriented Architecture Shared Service”, assigned attorney docket no. END920080293US1, which was filed on (to be provided), and was assigned application Ser. No. (to be provided), commonly owned and co-pending application entitled “Managing Service Oriented Architecture (SOA) Shared Service Escalation”, assigned attorney docket no. END920080294US1, which was filed on Feb. 24, 2009, and was assigned application Ser. No. 12/391,362, the entire contents of which are herein incorporated by reference.