Aspects of the present disclosure relate to platforms for integrating heterogeneous technologies and/or applications into business services.
Many businesses today operate using a variety of older heterogeneous technologies, business applications, and other technological business resources, collectively known as “legacy systems,” to perform different business transactions. For example, legacy systems may be used for consumer transactions, payroll systems, and business data management. In order to meet the changing needs of a business, legacy systems are gradually modified and extended over many years, and often become fundamental to the performance and success of the business.
It is often the case that such legacy systems cannot be efficiently replaced, due to their complexity, size, fragmented nature, and interconnections with other systems. However, as the modern economy becomes more technologically complex and business requirements and opportunities change, many businesses require cross-enterprise collaborations among existing legacy systems and other business technologies, applications, and resources, as well as integration with new external technologies and systems, such as business-to-consumer and/or business-to-business applications. Often, an organization inherits various systems from corporate acquisitions and acquires systems that become unsupported over time. Integrating these systems into existing infrastructure and maintaining these systems may involve redundant functionality and data, and eliminating those redundancies can be difficult and expensive. Conventionally, integrating, reducing and eliminating redundancies, and/or extending existing business technologies and applications, or integrating existing business technologies and applications with newer external systems is difficult because of inconsistent interfaces, fragmented, differently formatted, and/or redundant data sources, and inflexible architectures.
It is with these problems in mind, among others, that various aspects of the present disclosure were conceived.
One aspect of the present disclosure involves an enterprise information technology platform. The system includes at least one processor and a memory in operable communication with the at least one processor. The system includes a services platform, executing on the at least one processor. The services platform includes a plurality of API services, wherein each API service of the plurality of API services accesses one or more business assets to implement a business capability. The services platform also includes a data services infrastructure to receive business data from at least one data source, the business data used to enable the API services. The services platform includes at least one orchestrated business process service to consolidate at least two of the plurality of API services to enable a complex business capability. The services platform further includes a management communications infrastructure to: coordinate communication between the plurality of API services to enable selection of the at least two API services and communicate the business data from the data services infrastructure for the at least two API services to the at least one orchestrated business process service.
In another aspect, a method for providing access to a plurality of API services, wherein each wherein each API service of the plurality of API services accesses a business asset to implement a business capability is disclosed. The method includes establishing communication between the plurality of API services and a data services infrastructure. The method also includes receiving business data from at least one data source, the business data used for enabling the at least one API service of the plurality of API services. The method further includes generating at least one orchestrated business process service to perform a complex business capability, wherein the at least one orchestrated business process consolidates at least two of the plurality of API services. The method includes communicating the business data for the at least two API services to the at least one orchestrated business process service.
In yet another aspect, a computer-readable medium encoded with a services platform comprising one or more applications and infrastructures executable by a processor is disclosed. The services platform includes an API services application comprising a plurality of API services wherein each API service of the plurality of API services accesses one or more business assets to implement a business capability. The services platform further includes a data services infrastructure to receive business data from a plurality of data sources, the business data used to enable the plurality of API services. The services platform also includes a orchestrated business process service application to generate at least one orchestrated business process service to consolidate at least two of the plurality of API services to enable a complex business capability. The services platform includes a management communications infrastructure to: coordinate communication between the plurality of API services to enable selection of the at least two API services and communicate the business data from the data services infrastructure for the at least two API services to the at least one orchestrated business process service.
Aspects of the present disclosure may be better understood and its numerous objects, features, and advantages, made apparent to those skilled in the art by referencing the accompanying drawings. It should be understood that these drawings depict only typical embodiments of the present disclosure and, therefore, are not to be considered limiting in scope.
Aspects of the present disclosure extend to methods, systems, and computer program products for providing a set of business capabilities to end users, such as customers, partners, and/or information technology (“IT”) developers. A services platform provides one or more application programming interface services (“API services”) to such users. Each API service accesses and/or integrates different business application functionalities and business data that extend across a business enterprise to implement a shared reusable business capability. The API services may be combined into orchestrated business process services, which may be used to enable complex business capabilities. End users, such as IT developers, may access and use the API services and orchestrated business process services to create new business applications and/or extend existing business applications. Aspects of the present disclosure may facilitate creating functional interconnections between existing legacy systems, between legacy systems and new systems, and between other business systems, reducing redundant data and systems among the various business systems, and sharing common data among the various business systems.
An outside-in architecture is an inherently top-down architecture that emphasizes decomposition to the functional level and is service oriented rather than application oriented. Outside-in architectures push services far down into an outside-in architecture stack (as close to the technology that offers the business service as possible), removing the need to use middleware that may be redundant.
A web-oriented architecture is a software architecture style that extends architectures, such as service oriented architectures, to web based applications. Web-oriented architectures are interface-level architectural styles that focus on the means by which services and service capabilities are exposed to consumers. For example, web-oriented architectures may be used to create web mashups, which are applications that use and combines data, presentation, or functionality from two or more sources to create new services. While the service-oriented architecture and the outside-in architecture are discussed herein, it is contemplated that other service-based and web-based architectures may also be used in the implementation of the services platform 104.
According to one aspect, the services platform 104 may combine business functionalities and business data from various business assets into one or more individual API services. Each API service may be a standardized interface that is implemented independent of the underlying business functionality and/or business data. Separating the business functionalities and business data from the interface for a given API service reduces dependencies between the various business assets so that changes to one business asset do not adversely impact or influence other business assets. Additionally, the separation allows the underlying business asset functions and business data to change without changing how an end user interacts with the interface to access such functions and data. End users, such as IT developers may use the standard interface of each API service to develop new business applications and integrate and/or extend existing business applications without knowing each API services' underlying implementations.
Aspects of each standard interface may include a data infoset (e.g. XML or JSON) which provides business data and contextual data in a programming friendly form, a limited set of programming operations with uniform semantics (e.g., GET or PUT) to create programming consistency across a large API services inventory, a uniform addressing scheme for locating (e.g., service category/service name/interface) and accessing individual services in the API service inventory, a uniform exception reporting scheme for dealing with faults in the API service inventory, use of standard networking protocols (e.g., HTTP) for connecting API service consumers to API service providers in a distributed API services system.
The specific underlying combination of business functionalities and business data for each API service provided by the services platform 104 implements corresponding specific business capability. A business capability is a collection of functionalities and related technologies that perform a specific business function for the purpose of achieving a business outcome or task. More particularly, a business capability defines what a business does (e.g. ship product, pay employees, check credit) and how that function is viewed externally (visible outcomes) in contrast to how the business performs the activities (business process) to provide the function and achieve the outcomes. For example, a “customer” API service may combine access to a proprietary customer database and the functionality of a customer relations management application to provide the business capability of customer management through a standard interface. The “customer” API service may be reused in multiple high-level business applications to provide the customer management business capability. If the customer API service did not combine the functionality of the customer relations management application and the proprietary customer database, would have to integrate access for every high-level business application necessary.
In order to implement and/or enable a business capability, each API service may access one or more business assets, such as business applications, servers, databases, and or other business technologies for a business enterprise. For example, the API services provided by the services platform 104 may access business applications in an application platform 106. Business applications include computer programs, software, instructions, etc., that may be used to perform and/or execute business transactions for a business. For example, a point of sales system managing customer sales for a retail business constitutes a business application. In another aspect, the application platform 106 may include the set of business assets currently existing within a business enterprise. According to one aspect, the application platform 106 may include non-service enabled business assets and/or service enabled business assets. A service enabled asset is a technology resource of the application platform that has been engineered to provide access to the business capabilities of the application through a proprietary API service that is specific to that one asset (e.g. web services for Oracle Siebel 8.1). In contrast, a non-service enabled asset provides no engineered access to the business capabilities through a proprietary API service and requires directly accessing the asset's database and/or using adapters provided by third party vendors to gain use of the business capabilities of the application. Both the service enabled business assets and the non-service enabled business assets may be used by the services platform 104 to provide API services. The API services access business functionalities and related business data from the non-service enabled business assets and/or service enabled assets of the application platform 106.
Additionally, each API service may access or receive business data from a business enterprise. Business data refers to any type of data created, generated, stored, modified, and/or captured during a business transaction, or any data related to a business operation. For example, business data may include customer order invoices, customer contact information, employee contact information, product inventory data, product management data, etc. Business data may also include any data existing on, or in, a business application, database, server and/or other type of business asset.
The business data accessed by each API service may be used to enable the business capability provided by an API service. Data from files on file systems, data in relational database management systems (RDBMS) or unstructured data in the form of documents are a few examples of the technical mechanisms that facilitate the collection of business data for a particular business. The data in these various repositories and/or stores provide the sources for creation of the data infosets of an API service interface.
According to one example, the API services may access business data found in a data management platform 108. The data management platform 108 represents a flexible and extensible data management environment that delivers business data to the API services. The data management platform 108 may automate the distribution of business data such as: historical business data, customer and sales business data, network inventory business data, work flow business data, and/or any other type of business data to the respective API service of the services platform 104. According to another aspect, the business data may be received and/or retrieved from another processing device such as a computer, server, mobile device, and/or any other type of processing device.
The services may be provided by the services platform 104 to one or more end users, such as customers, business partners, and/or IT developers. For example, the API services provided by the service platform 104 may be accessible to an IT developer through a delivery and consumption channel 110. The delivery and consumption channel 110 may be a computer, a processing device, a communication device, or the like, such as a personal computer, a server computer, a tablet computer, a mobile processing device, a mobile communication device, and/or the like. The delivery and consumption channel 110 may also be a portal (e.g. a web portal), fat client, software application, composite software application, situational mashup application, dashboard, business intelligence tool, and/or an E-Commerce infrastructure comprising a customer portal and external application programming interface.
An IT developer may use the delivery and consumption channel 110 to develop new business applications, extend the functionality of existing business applications, and/or integrate existing business technologies using the API services offered by the services platform 104. For example, an IT developer interested in developing new functionality for a legacy customer service system may access a web portal (the delivery and consumption channel) to access the “customer” API service API of the services platform 104. The IT developer may then implement additional functionality for the legacy customer service system using the customer API service.
The services system 102 may include a computer readable media (“CRM”) 203 storing executable instructions to implement the services platform 104. The CRM 203 may include computer storage media, communication media, and/or another available media medium that can be accessed by the processor 202. For example, CRM 203 comprises computer storage media and communication media. By way of example and not limitation, computer storage media includes memory, volatile media, nonvolatile media, removable media, and/or non-removable media implemented in a method or technology for storage of information, such as computer readable instructions, data structures, program modules, or other data. Communication media includes computer readable instructions, data structures, program modules, or other data and include an information delivery media or system.
The services platform 104 executes a variety of software components, infrastructures, sub platforms, and/or applications that communicate to provide API services to end users. A software component is a software package, web service, application, or module that encapsulates a set of related functions or data. Software infrastructures include computer software, applications (e.g. operating systems, middleware, virtual machines, etc.), instructions, modules and/or code that interface applications with low-level hardware devices and/or other software applications; provide communication mechanisms for cooperation among the devices and applications; and manage resources between the devices and/or applications. Although the services platform 104 is depicted as executing multiple applications, software components, and/or software infrastructures, it is contemplated that all of the applications, software components, and software infrastructures of the services platform 104 may be combined in various ways.
In one embodiment, the services platform 104 includes an API services application (“ASA”) 204, a managed communications infrastructure (“MCI”) 206, a data services infrastructure (“DSI”) 208, an orchestrated business process services application (“OBPSA”) 210, a utility services infrastructure (“USI”) 212, a data integration and acquisition services application (“DIASA”) 214, and a decision management services application (“DMSA”) 215 that are implemented in computer executable instructions and/or modules stored in the CRM 203 and may be executed by the processor 202 as part of the services platform 104. Generally, program modules and/or instructions include routines, programs, objects, components, data structures, etc., that perform particular tasks or implement particular abstract data types.
The ASA 204 provides one or more API services to end users. As described herein, an API service accesses different business asset functionalities and business data to implement a core, reusable, business capability. The API services may be delivered by the services platform 104 to one or more end users such as through the delivery and consumption channel 110.
The MCI 206 enables and coordinates communication among the various components and infrastructures in the services platform 104. For example, the MCI 206 may coordinate communication between the ASA 204, the DSI 208, the OBPSA 210, the USI 212, and the DIASA 214. According to one aspect, the MCI 206 includes a set of technologies that enable distributed components of the service platform 102 to connect, communicate and share data. The individual modules of the MCI are designed and tuned to deliver different performance and quality of service (QOS) semantics for certain business usage scenarios. For example, a store and forward transactional message layer module 704, discussed with reference to
The DSI 208 unifies and extends existing information architectures of a business enterprise to make business data more accessible and usable. The DSI 208 exposes business data in a unified view, so that end users can use a single source when using the business data to enable API services. The DSI 208 provides a technical mechanism to bring together two or more sources of similar business data and expose those multiple sources in a single access point, such as a delivery and consumption channel, to a data service consumer and/or user. The fragmented and distributed nature of data in businesses today makes it costly and time consuming to compile business data in a single geographic location or technical repository. Accordingly, the DSI 208 makes the data more accessible by virtualizing the location and sources and providing a single point of access for data consumers, applications, developers, etc. For example, the DSI 208 may make business data accessible in real-time. As another example, the DSI 208 may provide a single virtual point of access to business data.
The OBPSA 210 combines one or more of the API services provided by the ASA 204 into a business process service that may be used to perform complex business capabilities. Generally, service orchestration describes the automated arrangement, coordination, and management of services offered by a service-oriented architecture. Individual services are and their corresponding capabilities are combined together to automate the performance of complex business capabilities. For example, the orchestrated business process services component may combine individual API services from the ASA 204 including: an “invoice” API service, an “order” API service, and a “customer” API service into an orchestrated business service that may be used to automatically perform the complex business transaction of processing customer product returns.
The USI 212 provides secure access to the API services provided by the ASA 204. Additionally, the USI 212 may provide the means to capture metrics for API service invocations and enable alert mechanisms based off of the API service invocation content. For example, capturing metrics may entail the tracking of the number of service calls from a customer portal per day for an Order Status API service and the average response time for that service to aid in understanding usage and performance for use in capacity planning and proactive performance tuning. As another example, an alerting mechanism may entail the setting of a performance service level (SLA) of the Order Status API service to provide a response to a service consumer within 5 seconds or less and proactively alerting operations managers if invocation response time begins to exceed the 5 second SLA so corrective actions can be put in motion to minimize impact to the customer experience. Finally, the USI 212 may provide auditing services for monitoring the use of API services.
The services platform 104 may also include a DIASA 214. The DIASA 214 provides a data extraction, transformation and loading (ETL) service and a data change event special purpose service for the services platform 104 to enable the processing and movement of distributed sources of business data from the distributed sources into the data management platform 108 for subsequent usage in decision support and historical trend analysis activities.
The services platform 104 may include a DSMA 215. According to one aspect, the DMSA 215 externalizes volatile business policies and rules from applications and services, such as API services, so that the rules that make up a decision are decoupled from the logic that requires the decision be made.
As described above, in one embodiment, the services platform 104 may execute the ASA 204, the MCI 206, the DSI 208, the OBPSA 210, the USI 212, the DIASA 214, and the DMSA 215 to provide API services to end users.
Each API service may be executed inside of a service container. For example, a service may be implemented using the java programming language and implemented in tcServer™, JBoss™, and/or Weblogic™ service containers. As another example, a service may be implemented in C# and executed in a Microsoft IIS™ container. Other service and service container combinations may also be used. In another implementation, the service containers may be monitored. For example, the services may be monitored using Quest Foglight™. Quest Foglight provides agents that monitor various services to provide runtime governance and service performance metrics. According to one aspect, the service containers may embody the runtime environment for an API service. Containers may contain built-in monitoring of deployed API services (e.g. Java Management Extensions—JMX) or third party agents (e.g. Quest Foglight) may be deployed to a container using the standard mechanisms for the runtime container and configured to instrument the processing of an API service call. The instrumentation of the monitoring may then be accessed by web dashboards or output to an Enterprise Monitoring System (EMS) for broader IT operations visibility.
For example, the DSI 208 may include a receiving module 502 and a processing module 504. The receiving module 502 receives business data from one or more disparate business assets, from the application platform 106 and/or the data management platform 108. The business data may be unreconciled, which means the data comes from at least two different business assets with discrepancies, or fragments. For example, assume a business B has two employee databases: a SQL Server™ managed employee database and an Oracle DMBS™ managed employee database. A developer does a query in the SQL Server database for an employee named John Doe, in an attempt to receive information regarding John's salary and current department. The SQL Server database returns business data indicating that John Doe is currently being paid $100,000, but has no data regarding the department in which John works. The developer does a separate query in the Oracle DMBS database for John Doe. The Oracle DMBS database returns business data indicating that John Doe works in the accounting department, but has no data regarding John's salary. Thus, the data regarding the employee John Doe is fragmented and/or incomplete between the two databases, or one database has information different than the other database.
The processing module 504 reconciles the unreconciled business data received by the receiving module 502 into a single point of access, and exposes the business data in a unified information view. Subsequently, developers may access the business data through the single point of access to enable the API Services (provide the appropriate data to the API Services to allow the API Services to perform their intended functions) offered by the API services application 204. Referring to the John Doe example above, the DSI 208 unifies the business data regarding John's salary from the SQL Server database and the business data regarding John's department from the Oracle DMBS database into one complete data record for access.
Thus the modules of the DSI 208 combine data from data sources such as the application platform 106, the data management platform 108, or both to provide unified access to fragmented or multi-source data sets. Combining such data frees up the IT developers from having to know the location and the technical implementation of the data sources (i.e. the source could be Excel spreadsheet, RDBMS, XML datafile) and gives the developers a single point of access and single technical access mechanism (e.g. JDBC/SQL or web service) to get at distributed and/or fragmented business data. Thus, the DSI 208 is the technical mechanism by which data is unified and allows the data in the sources to remain unchanged as implemented by the source technical resource. Agility is achieved by not having to change or modify different data sources; rather, DSI 208 infrastructure of the services platform 104 reconciles such data.
The DIASA 214 provides a data extraction, transformation and loading (ETL), and a data change event special purpose service for the services platform 104, to enable the processing and movement of distributed sources of data, on or off premise, from the distributed sources into another data source such as the data management platform 108.
The API service mediation layer 702 provides a centralized Policy Enforcement Point (PEP) for service communications. For example, the API service mediation layer module 702 may control message traffic according to a defined set of policies, such as authentication, authorization and auditing; sensitive data obfuscation, masking and/or filtering; dynamic service location and routing; version management and mapping; and threat detection and content scanning. According to one aspect, the API service mediation layer 702 may implement these policies within the layer itself, or it may implement calls to external infrastructure services.
The PEP is implemented via a centralized proxy technology mechanism. All API service invocations from consumers are made to a single host (e.g. api.level3.com) and these invocations are mediated by the proxy technology where, based on the uniform addressing scheme of the API service, the PEP can apply ‘N’ number of policies to the invocation (e.g. authenticate, authorize, route to provider, throttle call etc. . . . ). Policies are declaratively set up in the PEP based on the API services that are mediated and can be modified/changed at runtime to dynamically change how the PEP deals with subsequent API service invocations. Additional local policy enforcement can be implemented by the API services themselves or with a PEP that is deployed locally to the Service Container hosting the API service.
The store and forward transactional message layer MCI 704 provides standard based messaging transport between the various components of the services platform 104. For example, the store and forward transactional message layer MCI 704 may provide additional Quality of Service (QOS) capabilities like reliable delivery and once and only once delivery of messages between the various components of the services platform 104 and is used to enable Event Driven Architecture (EDA) patterns. According to one aspect, the store and forward transactional message layer may be implemented based on TIBCO Enterprise Messaging Service (EMS)™. Alternate store and forward mechanisms like MQSeries from IBM™ can be used for this layer. To achieve standard messaging, The MCI 704 may be implemented via the Java Message Service (JMS) which provides the standard semantics for messaging and provides reliable store and forward delivery of messages for service consumers who may operate temporarily in a disconnected state and upon reconnect retrieve and process their API service invocations.
The high performance publish and subscribe message layer module MCI 706 provides a high performance message transport between a publisher and multiple subscribers. A message publisher produces business data and context (topic/subject) messages that use the high performance publish and subscribe message layer module MCI 706 to communicate the business data and context based messages to interested listeners. A subscriber is defined as a listener of business data and context messages that uses the high performance publish and subscribe message layer module MCI 706 to receive messages of interest. Subscribers use context filters (topic/subject) to limit the scope of messages that they receive and process. The high performance publish and subscribe message layer module MCI 706 provides rapid delivery to large numbers of subscribers and is used in business scenarios that require quick and broad dissemination of interesting business events.
The managed file transfer message layer module MCI 708 provides a robust and secure mechanism for batch file transfer and batch file processing workflow. The managed file transfer message layer module MCI 708 is used to transfer large blocks or files of data between components in the services platform 104 and makes it possible to reliably start, process, and re-start if necessary communications to ensure block or file information exchange is successfully completed. According to one aspect, managed file transfer message layer module MCI 708 can be implemented by the File Transfer Protocol (FTP). Alternate mechanisms may include the Secure Copy Protocol (SCP) or 3rd party implementations like Axway™.
The activity service monitoring module 804 captures metrics for API service invocations provided by the ASA 204 and enables alerting mechanisms based off of the API service invocation and/or its messages content. For example, an alerting mechanism may entail the setting of a performance service level (SLA) on the Order Status API service to provide a response within 5 seconds or less and the activity monitoring service module measures the latency of each service invocation and has programmed policies to proactively alert operations managers if invocation response time begins to exceed the 5 second SLA.
The audit service module 806 may be called by the service mediation layer 702 of the MCI 206 to monitor traffic and access control of the ASA 204 and provide metrics, such as overall API service use. Monitoring of the API services is achieved by tracking and instrumenting the service invocations. Requests for service and the responses from services, including successes and failures, are intercepted by the AMM 806 and ASM 808 and policies are applied at the point of interception to count and/or capture the invocation transactional data for in-band runtime action (e.g. SLA alerting) or for later out-of-band metrics aggregation and reporting to be used in decision support and management of the service platform. Audit logs and transaction logs can then be used with standard tools to introspect the operations of the entire service network.
For example, assume and API service called “order fulfillment process service” provides the business capability of routing orders to a VIP processing group to fulfill orders for VIP customers. In such a service, the rules for routing orders to the VIP processing group may change regularly when new VIP customer's are added, or when dollar amounts change indicating the amount of money a customer must spend to be considered VIP. Instead of codifying the rules in the fulfillment business process service, which would have to be continually changed if and/or when the rules change, the rules are externalized in a decision management service which takes the order data as input and outputs a “VIP” or “Not VIP” ruling that the fulfillment business process service uses to send the order to the correct fulfillment group.
The description above includes example systems, methods, techniques, instruction sequences, and/or computer program products that embody techniques of the present disclosure. However, it is understood that the described disclosure may be practiced without these specific details.
In the present disclosure, the methods disclosed may be implemented as sets of instructions or software readable by a device. Further, it is understood that the specific order or hierarchy of steps in the methods disclosed are instances of example approaches. Based upon design preferences, it is understood that the specific order or hierarchy of steps in the method can be rearranged while remaining within the disclosed subject matter. The accompanying method claims present elements of the various steps in a sample order, and are not necessarily meant to be limited to the specific order or hierarchy presented.
The described disclosure may be provided as a computer program product, or software, that may include a machine-readable medium having stored thereon instructions, which may be used to program a computer system (or other electronic devices) to perform a process according to the present disclosure. A machine-readable medium includes any mechanism for storing information in a form (e.g., software, processing application) readable by a machine (e.g., a computer). The machine-readable medium may include, but is not limited to, magnetic storage medium (e.g., floppy diskette), optical storage medium (e.g., CD-ROM); magneto-optical storage medium, read only memory (ROM); random access memory (RAM); erasable programmable memory (e.g., EPROM and EEPROM); flash memory; or other types of medium suitable for storing electronic instructions.
It is believed that the present disclosure and many of its attendant advantages will be understood by the foregoing description, and it will be apparent that various changes may be made in the form, construction and arrangement of the components without departing from the disclosed subject matter or without sacrificing all of its material advantages. The form described is merely explanatory, and it is the intention of the following claims to encompass and include such changes.
While the present disclosure has been described with reference to various embodiments, it will be understood that these embodiments are illustrative and that the scope of the disclosure is not limited to them. Many variations, modifications, additions, and improvements are possible. More generally, embodiments in accordance with the present disclosure have been described in the context of particular implementations. Functionality may be separated or combined in blocks differently in various embodiments of the disclosure or described with different terminology. These and other variations, modifications, additions, and improvements may fall within the scope of the disclosure as defined in the claims that follow.