The present invention generally describes the governance and management of the evolution of shared services in service-oriented architecture.
It is known for organizations to use service-oriented architecture (SOA) methods, systems and governance models to develop and deploy shareable and reusable services which need to evolve over time. SOA governance generally encompasses an entire organization involved in a transformation and requires participation by multiple stakeholders in definition and realization. However, existing information technology (IT) and SOA governance methods have inadequacies and do not drive effective change and service adoption across an enterprise, generally ignoring business domain aspects of SOA governance and management.
Methods provide a service-oriented architecture governance model. Each of a plurality of governance dimension attributes of a service-oriented architecture are calibrated and mapped to each of a plurality of governance evolution element attributes. A maturity and capability assessment is performed for the service-oriented architecture as a function of the mapping, and a maturity-based and capability-based governance model is generated for the service-oriented architecture as a function of the maturity and capability assessment. In one aspect methods comprise providing a programmable device configured to perform at least one of the calibrating, the mapping, the performing the maturity and capability assessment and the generating the maturity-based and capability-based governance model.
Service methods are also provided comprising deploying applications for providing a service-oriented architecture governance model according to the method steps described above, for example by a service provider who offers to implement, deploy, and/or perform functions for others. Still further, articles of manufacture comprising a computer usable medium having a computer readable program in said medium are provided. Such program code comprises instructions which, when executed on a computer system, cause the computer system to perform one or more method and/or process elements described above for providing a service-oriented architecture governance model. Moreover, systems, articles and programmable devices are also provided, configured for performing one or more method and/or process elements of the current invention for providing a service-oriented architecture governance model, for example as described above.
These and other features of the methods, systems and devices according to the present application will be more readily understood from the following detailed description of the various aspects of the embodiments taken in conjunction with the accompanying drawings in which:
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.
For convenience, the Detailed Description of the Invention has the following sections:
I. General Description; and
II. Computerized Implementation.
Examples of SOA aspects and governance processes according to the present invention may be found in the following commonly-owned and co-pending U.S. patent applications or issued U.S. patents, the disclosures of which are expressly incorporated herein by reference: “Identifying a Service Oriented Architecture Shared Services Project”, attorney docket no. END920080252US1, filed on (to be provided), and assigned application serial no. (to be provided); “Evaluating a Service Oriented Architecture Shared Services Project”, attorney docket no. END920080288US1, filed on (to be provided), and assigned application serial no. (to be provided); “Service Oriented Architecture Shared Service Inception”, attorney docket no. END920080289US1, filed on (to be provided), and assigned application serial no. (to be provided); “Service Oriented Architecture Shared Services Elaboration”, attorney docket no. END920080290US1, filed on (to be provided), and assigned application serial no. (to be provided); “Service Oriented Architecture Shared Services Construction”, attorney docket no. END920080291US1, filed on (to be provided), and assigned application serial no. (to be provided); “Transitioning to Management of a Service Oriented Architecture Shared Service”, attorney docket no. END920080292US1, filed on (to be provided), and assigned application serial no. (to be provided); “Service Oriented Architecture Shared Service Management”, attorney docket no. END920080293US1, filed on (to be provided), and assigned application serial no. (to be provided); “Service Oriented Architecture Shared Service Escalation”, attorney docket no. END920080294US1, filed on (to be provided), and was assigned application serial no. (to be provided); “SOA Policy Versioning”, attorney docket no. END920080316US1-IEN106616, filed on (to be provided), and assigned application serial no. (to be provided); “FRAMEWORK FOR VARIATION ORIENTED ANALYSIS FOR SERVICE-ORIENTED ARCHITECTURE”, attorney docket no. END920080317US1-IEN106617, filed on (to be provided), and assigned application serial no. (to be provided); “TECHNICAL FEASIBILITY EXPLORATION FOR SERVICE-ORIENTED ARCHITECTURE ENVIRONMENTS”, attorney docket no. END920080318US1-IEN106618, filed on (to be provided), and assigned application serial no. (to be provided); “SOA Lifecycle Governance and Management”, attorney docket no. END920080319US1-IEN106619, filed on (to be provided), and assigned application serial no. (to be provided); “ENABLING SOA GOVERNANCE USING A SERVICE LIFECYCLE APPROACH”, attorney docket no. END920080320US1-IEN106620, filed on (to be provided), and assigned application serial no. (to be provided); “CALIBRATION FRAMEWORK FOR EFFORT ESTIMATION”, attorney docket no. END920080321US1-IEN106621, filed on (to be provided), and assigned application serial no. (to be provided); “SERVICE PORTFOLIO APPROACH FOR SOA GOVERNANCE”, attorney docket no. END920080386US1-IEN106642, filed on (to be provided), and assigned application serial no. (to be provided); “SERVICE EVOLUTION APPROACH IN SOA”, attorney docket no. END920080387US1-IEN106643, filed on (to be provided), and assigned application serial no. (to be provided); “PRIORITIZATION ENABLEMENT FOR SOA GOVERNANCE”, attorney docket no. END920080389US1-IEN106645, filed on (to be provided), and assigned application serial no. (to be provided); and “SOA POLICY ENGINE FRAMEWORK”, attorney docket no. END920080390US1-IEN106646, filed on (to be provided), and assigned application serial no. (to be provided).
SOA governance may be understood to encompass an entire organization involved in a transformation and should require participation by multiple stakeholders in definition and realization. A well-defined governance framework and underlying model helps to drive effective change across an enterprise, and may be a key to success irrespective of an entry point chosen by an enterprise for an SOA transformation. Additionally, an effective SOA governance model may be realized by establishing a governance body comprising domain owners and stakeholders with delegated responsibility for decision making.
Prior art IT and SOA governance methods generally fail to drive effective change and service adoption across an enterprise through ignoring the business domain aspects of SOA governance and management. For example,
Inadequacies of the prior art also include: lacking consideration of governance maturity and adoption capability of an enterprise in context, focusing instead on maturity of governance processes; lacking an evolution model that helps define SOA governance building blocks that may align with an SOA adoption roadmap within an organization; lacking a simple analytical approach to assess current needs and define gaps for future SOA governance capabilities based on a holistic model for SOA; requiring extensive knowledge of overall subject domains and an organization's environment to understand, assess and recommend governance needs; continuing to be primarily focused on the IT governance domains and not business aspects elevated by SOA; and defining a governance model on a framework that addresses governance and management capabilities at post-IT strategy stages of a lifecycle.
The mapping framework 102 also comprises six major governance evolution elements 104, 106, 108, 110, 112, 114 of an SOA enterprise, each of which comprises a defined set of attributes. Referring again to
Illustrative but not exhaustive examples of the mapped attributes of the People Skills and Organization Capabilities governance evolution element 104 include: an organization's tolerance for change in moving to a service-oriented enterprise; business services portfolio management capabilities and techniques; business services communication planning, execution and management; business services stakeholder management planning and execution; business services and SOA skills development; and business domain and IT staff planning to infuse a business services culture.
Illustrative but not exhaustive examples of the mapped attributes of the Business Innovation (Products and Services Strategy) governance evolution element 106 include: management of product and services (business) portfolio; a product and services portfolio driving a collaborative nature across business units; business governance processes alignment with changing products and services strategy; business taxonomy alignment with products and services; business process alignment and management in the context of changing products and services portfolio; and alignment of an IT strategic plan based on strategic business initiatives.
Illustrative but not exhaustive examples of the mapped attributes of the Business and IT Accelerators governance evolution element 108 include: identifying and planning service oriented opportunities as part of business case and business program development; business projects prioritization based on service oriented aspects; an organization's ability and need to foster collaborative business components; business Services criteria, scorecards, monitoring and measurement capabilities; processes and mechanisms determining a technology investment path; and soundness of a business strategy to drive architecture design and IT investment planning.
Illustrative but not exhaustive examples of the mapped attributes of the Business Performance Management governance evolution element 110 include: the proliferation of collaboration across an enterprise through business services; an ability to view business processes across collaborative business units; mechanisms and flexibility of current infrastructure to infuse business activity-level monitoring; the maturity of products and a services portfolio to define metrics for business performance monitoring and measurement; and the knowledge of business process models across or within business units.
Illustrative but not exhaustive examples of the mapped attributes of the Technology Adoption governance evolution element 112 include: an organization's ability to adopt a competitive and technical marketplace and incorporate same into IT investment planning; a level of external market and competitive forces on the business services portfolio which influences the planning and execution of technology investments; an availability of appropriate business and economic context to drive technology integration, migration or consolidation decisions; the existence of established, mature and comprehensive architectural approaches with ability to address future business plans; and a linkage between the magnitude of issues in a current technical environment, potential solutions and a value proposition (e.g. business case) of addressing challenges.
Illustrative but not exhaustive examples of the mapped attributes of the SOA Technology Infrastructure Management governance evolution element 106 include: the maturity and readiness of current/planned operations and technical infrastructure to support growth in products and services; the allocation of system staff to the maintenance of existing systems versus future development or architectural evolution; capabilities to monitor and report both business and IT-level metrics of business processes; the maturity of current application and information architectures aligning with a service-oriented view of business processes; the complexity and intensity of an ability to provision and manage the usage of a service-oriented enterprise; and a business services consumer-to-provider skew and infrastructure capabilities to support growing business needs (e.g. provisioning, monitoring, deploying, etc.).
Illustrative but not exhaustive examples of the mapped processes of the SOA Governance Framework 140 SOA Business and IT alignment aspect 150 include: Enterprise Program Portfolio 142 & Business Services Portfolio 144 alignment; business services discovery; program & services prioritization; business case & planning; business process collaborations; business services identification; business & IT change management; and business services policy strategy & definition processes, and other processes may be apparent to one skilled in the art.
Illustrative but not exhaustive examples of the mapped processes of the SOA Governance Framework 140 SOA Ownership & Decision Rights dimension 152 include: business services ownership, business services funding, domain classification & taxonomies, business services ownership change management, business services stakeholder management and business services policy ownership & stakeholder assignment processes, and other processes may be apparent to one skilled in the art.
Illustrative but not exhaustive examples of the mapped processes of the SOA Governance Framework 140 SOA Asset Lifecycle Enablement and Management dimension 154 include service discovery & publishing, asset discovery & publishing, asset lifecycle change management, business services asset reuse management, business services & SOA standards, business services asset reuse programs, asset repositories & registries and business services policy registry processes, and other processes may be apparent to one skilled in the art.
Illustrative but not exhaustive examples of the mapped processes of the SOA Governance Framework 140 SOA Service Operational Management and Monitoring 156 processes include business services utilization & metering, business services performance monitoring, operational service change management, services provisioning, business services metrics measurement, services testing and certification, business services version management and business services policy enforcement & monitoring compliance processes, and other processes may be apparent to one skilled in the art.
An Attribute Description 163 header identifies content requested or retrieved (i.e. by a stakeholder, user or a programmable device) to populate the associated field 164. A best governance alignment choice 165 identifies categorization of the present attribute as within one of the four major SOA Governance Framework 140 dimensions (SOA Business and IT Alignment dimension 150, SOA Ownership & Decision Rights dimension 152, SOA Asset Lifecycle Enablement and Management dimension 154 or SOA Operational Management and Monitoring dimension 156), indicated by selection/population of one the answer bubble/fields 166.
Governance capability determined by the assessed attribute to the appropriate SOA Lifecycle stage(s) 167 is allocated and assigned pursuant to selection/population of one of the associated answer bubble/fields 168. Assigning the assessed attribute to one or more SOA Governance Focus components 174 helps determine the right mix of governance enablement approach, as provided by the associated answer bubble/fields 175. And lastly, determination of SOA Governance Evolution states 169 (as described by the description fields 171) for both current and desired states 170 is provided: in the present example the current state indicated at 172 as state number 2, with the desired state indicated at 173 to be state number 4.
In one aspect, the Template 160 thus integrates maturity assessment with the end-to-end SOA lifecycle view, and provides an ability to define an SOA Governance model based on all governance focus points that will address any organizational culture and style. Templates 160 according to the present invention are generally pre-defined, but also modifiable to accommodate attributes evolution and provide normative guidance, thus exhibiting self-learning and adaptable capabilities with respect to predefined values of attributes as a function of their evolution stages. The Template 160 thus provides a prescriptive process that arrives at individual assessments and aggregates results to arrive at mapping to the governance model.
Mappings may be default mappings, which may be customized according to an organization's cultural preferences, to a prevailing environment around the six governance evolution elements 104, 106, 108, 110, 112, 114, and to an overall maturity of the SOA Governance 140 evolution path. Organizations may also calibrate and customize pre-defined values and mappings to best suit their organization. For example, if organizations adopting the evolution governance framework 120 (
A power source 205 is configured to provide operative power to the device 200; examples include battery units 205 and power inputs configured to receive alternating or direct current electrical power, and other appropriate power units 205 will be apparent to one skilled in the art. A communication port or network link/node means (“com port”) 207 is also provided and configured to enable data and other communications as may be appropriate, for example as discussed above.
Referring now to
As shown, the computer system 304 includes a central processing unit (CPU) 312, a memory 316, a bus 320, and input/output (I/O) interfaces 324. Further, the computer system 304 is shown in communication with external I/O devices/resources 328 and storage systems 332. In general, the processing unit 312 executes computer program code, such as the code to implement various components of the process and systems, and devices as illustrated in
While executing computer program code, the processing unit 312 can read and/or write data to/from the memory 316, the storage system 332 (e.g. the and/or the I/O interfaces 324. The bus 320 provides a communication link between each of the components in computer system 304. The external devices 328 can comprise any devices (e.g., keyboards, pointing devices, displays, etc.) that enable a user to interact with computer system 304 and/or any devices (e.g., network card, modem, etc.) that enable computer system 304 to communicate with one or more other computing devices.
The computer infrastructure 308 is only illustrative of various types of computer infrastructures for implementing the invention. For example, in one embodiment, computer infrastructure 308 comprises two or more computing devices (e.g., a server cluster) that communicate over a network to perform the various process steps of the invention. Moreover, computer system 304 is only representative of various possible computer systems that can include numerous combinations of hardware.
To this extent, in other embodiments, the computer system 304 can comprise any specific purpose-computing article of manufacture comprising hardware and/or computer program code for performing specific functions, any computing article of manufacture that comprises a combination of specific purpose and general-purpose hardware/software, or the like. In each case, the program code and hardware can be created using standard programming and engineering techniques, respectively. Moreover, the processing unit 312 may comprise a single processing unit, or be distributed across one or more processing units in one or more locations, e.g., on a client and server. Similarly, the memory 316 and/or the storage system 332 can comprise any combination of various types of data storage and/or transmission media that reside at one or more physical locations.
Further, I/O interfaces 324 can comprise any system for exchanging information with one or more of the external device 328. Still further, it is understood that one or more additional components (e.g., system software, math co-processing unit, etc.) not shown in
The storage system 332 can be any type of system (e.g., a database) capable of providing storage for information under the present invention. To this extent, the storage system 332 could include one or more storage devices, such as a magnetic disk drive or an optical disk drive. In another embodiment, the storage system 332 includes data distributed across, for example, a local area network (LAN), wide area network (WAN) or a storage area network (SAN) (not shown). In addition, although not shown, additional components, such as cache memory, communication systems, system software, etc., may be incorporated into computer system 304.
While shown and described herein as a method and a system, it is understood that the invention further provides various alternative embodiments. For example, in one embodiment, the invention provides a computer-readable/useable medium that includes computer program code to enable a computer infrastructure to implement methods, systems and devices according to the present application, for example as illustrated in
It is understood that the terms “computer-readable medium” or “computer useable medium” comprise one or more of any type of physical embodiment of the program code. In particular, the computer-readable/useable medium can comprise program code embodied on one or more portable storage articles of manufacture (e.g., a compact disc, a magnetic disk, a tape, etc.), on one or more data storage portions of a computing device, such as the memory 316 and/or the storage system 332 (e.g., a fixed disk, a read-only memory, a random access memory, a cache memory, etc.), and/or as a data signal (e.g., a propagated signal) traveling over a network (e.g., during a wired/wireless electronic distribution of the program code).
Still yet, computer infrastructure 308 is intended to demonstrate that some or all of the components of implementation according to the present application could be deployed, managed, serviced, etc. by a service provider who offers to implement, deploy, and/or perform the functions of the present invention for others, for example by licensing methods and browser or application server technology to an internet service provider (ISP) or a cellular telephone provider. In one embodiment, the invention may comprise a business method that performs the process steps of the invention on a subscription, advertising, and/or fee basis. Thus, a service provider can create, maintain, support, etc., a computer infrastructure, such as the computer infrastructure 308 that performs the process steps of the present application for one or more customers, and in return the service provider can receive payment from the customer(s) under a subscription and/or fee agreement and/or the service provider can receive payment from the sale of advertising content to one or more third parties.
In still another embodiment, the invention provides a computer-implemented method for enabling the processes, methods and devices according to the present application. In this case, a computer infrastructure, such as computer infrastructure 308, can be provided and one or more systems for performing the process steps of the invention can be obtained (e.g., created, purchased, used, modified, etc.) and deployed to the computer infrastructure. To this extent, the deployment of a system can comprise one or more of: (1) installing program code on a computing device, such as computer system 304, from a computer-readable medium; (2) adding one or more computing devices to the computer infrastructure; and (3) incorporating and/or modifying one or more existing systems of the computer infrastructure to enable the computer infrastructure to perform the process steps of the invention.
As used herein, it is understood that the terms “program code” and “computer program code” are synonymous and mean any expression, in any language, code or notation, of a set of instructions intended to cause a computing device having an information processing capability to perform a particular function either directly or after either or both of the following: (a) conversion to another language, code or notation; and/or (b) reproduction in a different material form. To this extent, program code can be embodied as one or more of: an application/software program, component software/a library of functions, an operating system, a basic I/O system/driver for a particular computing and/or I/O device, and the like. 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.
Certain examples and elements described in the present specification, including in the claims and as illustrated in the Figures, may be distinguished or otherwise identified from others by unique adjectives (e.g. a “first” element distinguished from another “second” or “third” of a plurality of elements, a “primary” distinguished from a “secondary,” one or “another” item, etc.) Such identifying adjectives are generally used to reduce confusion or uncertainty, and are not to be construed to limit the claims to any specific illustrated element or embodiment, or to imply any precedence, ordering or ranking of any claim elements, limitations or process steps.
The foregoing description of various aspects of the invention has been presented for purposes of illustration and description. It is not intended to be exhaustive or to limit the invention to the precise form disclosed, and obviously, many modifications and variations are possible. Such modifications and variations that may be apparent to a person skilled in the art are intended to be included within the scope of the invention as defined by the accompanying claims.