Knowledge to prepare
Key words:
- IBPM: Stands for Intelligent Business Process Management
- SOA: Service-oriented Architecture (SOA) is a component model that connects different functional units of an application, called services, through well-defined interfaces and contracts between those services. The interface is defined in a neutral manner and should be independent of the hardware platform, operating system, and programming language that implements the service. This allows services built in a wide variety of systems to interact in a uniform and generic way.
- CEP: Complex event processing (CEP) processes different events that occur at the same time to determine the actions corresponding to these events. Events in an event channel can have different event types and can occur over a long period of time. Events can be associated by content, time, or location. As a result, CEP is often used to detect anomalies, risks, and even business opportunities, with the aim of taking advantage of more current information than traditional reporting solutions and ultimately gaining the upper hand over the competition.
- EDA: An event-driven framework (EDA) defines a methodology for designing and implementing an application system in which events can be transmitted between loosely coupled components and services. An event-driven system typically consists of event consumers and event producers. Event consumers subscribe to event managers, and event producers publish events to event managers. When the event manager receives an event from the event producer, the event manager forwards the event to the corresponding event consumer. If the event consumer is not available, the event manager keeps the event and forwards it to the event consumer again after a certain interval. This method of event delivery in message-based systems is called store and forward.
- ESP: In event stream processing (ESP), in addition to “related” events, “normal” events (such as all general instructions or RFID events) are also published to the event channel. This puts higher demands on event handling and provides more evaluation options.
- SEP: In simple event handling (SEP), only “related” events are put into the event channel for processing. For example, “Cars in the XY category are sold out” or “winter tire inventory is tight.” This is very similar to message-based systems. The processing logic evaluates the event type and content, and then reacts accordingly.
- MDM:MDM provides common components (or services) to ensure consistency in data maintenance and distribution.
- FP
- FRP 10.RP 11.ESB:Gartner coined the term “Enterprise service Bus” in 2002, and analyst Roy Schulte further introduced the term to describe a class of software products on the market at the time. Ten years later, there is still no consensus on what EBS is or what it should offer. There are many different definitions, depending on the manufacturer and source. Among other things, the definition of ESB includes: “an integration architectural style that enables communication between providers and service users through a common communication bus consisting of a variety of point-to-point connections” and “the infrastructure that an enterprise uses to integrate services in an application environment.” “An architectural pattern that uses service orientation to support interoperability between heterogeneous environments.”
- Faas
- serverless
A, EDA
1.1 EDA definition
Gartner introduced a new term Event Driven Architecture (EDA) in 2003 to describe an event-based paradigm. EDA is a way of designing and implementing applications and systems in which messages triggered by events can be passed between separate, uncoupled components and services that are unaware of each other. EDA in these applications greatly improves the ability of a business or government to respond to different, seemingly unrelated events. By providing the ability to instantly filter, aggregate, and correlate events, EDA can quickly detect events and determine their type, helping organizations respond to and process them quickly and appropriately. Usually events can be published/subscribed.
1.2 Overview of event-driven Architecture
An event Driven framework (EDA) defines a methodology for designing and implementing an application system in which events can be transmitted between loosely coupled components and services. An event-driven system typically consists of event consumers and event producers. Event consumers subscribe to event managers, and event producers publish events to event managers. When the event manager receives an event from the event producer, the event manager forwards the event to the corresponding event consumer. If the event consumer is not available, the event manager keeps the event and forwards it to the event consumer again after a certain interval. This method of event delivery in message-based systems is called store and forward.
Building applications and systems that include event-driven architecture makes them more responsive, because event-driven systems are better suited to unpredictable and asynchronous environments.
Event-driven architecture in concrete implementation refers to an application composed of a series of related components, and the components through the event mechanism to complete certain business functions. Since the components in an EDA system focus only on processing input messages and publishing output messages, As a result, EDA systems can more efficiently process concurrent processing of events that are pipelined and linked by multiple software modules.
1.3 characteristics of EDA
In EDA system, each component responds to the event in an asynchronous way, and can be parallel in nature, so it has great advantages in e-government application of government departments. It has the following characteristics:
◆ Concurrent execution ◆ Event trigger/data trigger/time rule trigger ◆ Real-time/incremental response ◆ distributed event system processingCopy the code
The above features can well meet the needs of government departments, such as inter-departmental emergency linkage system or joint supervision and collaborative service applications.
From the current situation, EDA system is only a system to deal with simple events, the processing of complex events need to be further studied. However, EDA can still be an effective complement to SOA systems, making up for some of the shortcomings of SOA systems, such as lack of real-time responsiveness.
1.4 Event-driven architecture advantages
The advantages provided by event-driven design and development are as follows:
◆ EDA improves responsiveness to changing business needs, minimizes impact on existing business applications, and often eliminates the need for new packaged applications. With a unique coarse grained service model, controllable business changes can be quickly identified based on business goals and implemented directly, quickly, and effectively to achieve business agility and integrity.
◆ It is easier to develop and maintain large-scale distributed applications and unpredictable or asynchronous services;
Can easily and cheaply integrate, reintegrate, and reconfigure new and existing applications and services.
Promote reuse of remote components and services with a more sensitive, bug-free development environment.
The advantages of EDA from the time dimension:
◆ Short-term benefits: easier customization, because the design is better responsive to dynamic processing;
◆ Long-term benefits: The state of the system and organization becomes more accurate, and the response to real-time changes is close to synchronous.
1.5 Relationship between EDA and SOA:
SOA and EDA are equal and complementary. So, I don’t agree with those students who are trying to spread SOA that EDA is only a subset of SOA. A broader event-driven architecture concept that goes beyond event-driven SOA should include real-time information flow and analysis, as well as complex event processing.
While EDA considers events to be the most important component of a system, it’s best to pay attention to the components or services and the ‘channels’ between them.”
Unlike the Request/Response system, which requires the requester to explicitly send the Request information, the event-driven architecture provides a mechanism to dynamically respond to events. In an EDA system, event producers publish events and event consumers receive events.
Business systems can benefit greatly from SOA and EDA because the EDA system can trigger event consumers when events occur and SOA services can be quickly accessed and queried from the same consumers. The system requires the highest level of responsiveness. The system must be able to quickly decide what action to take when an event is triggered. At the end of the event, the event should be published and consumed, and the event should cross all boundaries of the SOA, both architectural and physical.
The system must have the highest responsiveness, the system must be able to quickly decide what action to take when an event is triggered. At the end of the event, the event should be published and consumed, and the event should cross all boundaries of the SOA, both architectural and physical.
1.6 THE ESB connects EDA and SOA
An Enterprise Service Bus (ESB) connects disparate platforms and environments, acting as an intermediary that allows different application processes to communicate. Services deployed to an enterprise service bus can be triggered by consumers or events. It supports both synchronous and asynchronous modes, facilitating interactions between one or more participants. Thus an ESB can provide all the functionality of the SOA and EDA paradigms. “The ESB is the glue of the enterprise application infrastructure by providing key functions such as message transmission and format transformation, bridging the communication between service requesters and service providers.” Said Huang Jianyong, senior technology manager of Oracle Greater China.
An enterprise service bus connects and mediates all communications and interactions between heterogeneous nodes that can be dispersed in a service-oriented architecture (synchronous one-to-one approach) and an event-driven architecture (asynchronous many-to-many approach). An ESB is by far the most effective way to address integration challenges, a technical solution that provides maximum business flexibility and efficient connectivity between different applications.
EDA is used in many ESB (Enterprise Service Bus) products, such as the FiornaoESB middleware product, which supports synchronous, asynchronous, and request-response events. Event handling and transport use different technologies such as JMS, HTTP, E-mail, and XML-based RPC. For example, the “government online supervision system” realizes notification and supervision of problems such as violation, violation of law, administration beyond authority and administration beyond time limit through real-time collection of the monitored object (system) data, event triggering and event filtering through EDA technology.
1.7 EDA application Direction
Event-driven architecture (EDA) is a common architectural form of distributed applications. Typically, distributed applications are designed to be modular, encapsulated, and shared event service components. These services can be created through applications, adapters, and non-invasive proxy operations.
Due to the characteristics of EDA, the financial trade, energy trade, telecommunications, and fraud detection industries have been using event driven architecture (EDA) technology. Recently in the e-government construction of our government
Using the advantages of EDA distributed processing architecture, a sharing and exchange platform is built to realize cross-department, cross-platform and cross-application system sharing and exchange of government information resources, and to provide support and guarantee for the government emergency system and inter-commission, office and bureau business cooperation.
EDA
Martin Fowler
Ii. Responsive Programming and Responsive System (EP&&ERP)
One of the signs of reactive technology’s current success is that “reactive” has become a buzzword and is associated with different things and people — often accompanied by words like “streaming,” “lightweight,” and “real-time.”
2.1 FRP
- FRP definition
2.2 Reactive Programming
Not to be confused with functional responsive programming, it is a subset of asynchronous programming and a paradigm in which the availability of new information drives logic forward, Rather than having a thread-of-execution drive the control flow.
Responsive programming is generally event-driven, in contrast to responsive systems which are message-driven
The basic benefits of responsive programming are: improved computing resource utilization of multi-core and multi-CPU hardware; According to Amdar’s Law and Gunther’s Universal Scalability Law footnote 3, performance is improved by reducing serialization points.
Another benefit is developer productivity. The traditional programming paradigm tries to provide a simple, straightforward and sustainable way to handle asynchronous non-blocking computing and I/O. In reactive programming, most of these challenges are solved because there is usually no explicit collaboration between active components.
The real shining point of responsive programming is the creation of components and the combination of workflows. In order to get the most out of asynchronous execution, it is important to incorporate back-pressure to avoid overuse or, more precisely, unlimited consumption of resources.
2.4 Event Driven && Message driven
Responsive programming — which focuses on computing over a chain of data flows over short periods of time — is thus event-driven, while responsive systems — which focus on the resilience and resilience achieved through the communication and collaboration of distributed systems — are message-driven footnote 4 (or messaging).
The difference between a message-driven system with a long-lived addressable component and an event-driven data flow-driven model is that messages have fixed directions, whereas events do not. A message has a clear direction, whereas an event is just a message waiting to be observed. In addition, messaging-like messaging works better for async because the sending and receiving of messages are separated from the sender and receiver.
A message is a piece of data being sent to a specific destination. An event is a signal from a component that has reached a given state. In a message-driven system, addressable receivers wait for a message to arrive and then respond to it, otherwise remain dormant. In an event-driven system, the listener of the notification is bound to the message source so that it is called when the message is emitted. This means that an event-driven system focuses on addressable event sources while a message-driven system focuses on addressable receivers.
2.5 Responsive system
The cornerstone of a responsive system is message-passing, which creates a temporary boundary between two components, allowing them to be separated in time — for concurrency — and space — for distributed distribution and mobility. This separation is necessary for the complete isolation of the two components and the elasticity foundation.
2.6 Responsive system && Responsive programming
Responsive programming is a good technique for managing internal logic and Dataflow transformation as a way to optimize code clarity, performance, and resource utilization in native components. Responsive systems is a set of architectural principles designed to emphasize distributed information exchange and provide us with a tool for dealing with the resilience and resilience of distributed systems.
Reactive programming is a very useful implementation technique that can be used in a responsive architecture. But remember that this helps manage only one part: data flow management for asynchronous, non-blocking execution — usually within a single node or service. When you have multiple nodes, You need to start thinking seriously about things like data consistency, cross-node communication, coordination, versioning, orchestration, and error management failures Management, separation of concerns and responsibilities, and so on — i.e., system architecture.
Third, the CEP
3.1 Key Concepts
An event is something that happens in a business, including business activities, process state, network or IT conditions, or anything else. Many events can be processed as soon as they can be identified, usually accompanied by the sending of alerts. CEP is used when a single event cannot be handled reliably and must be analyzed in context. In almost all scenarios, CEP analysis requires events to be correlated in real time and in a format with accurate timestamps.
CEP applications fall into two broad categories: event correlation and root cause analysis. In general, event associations are used to identify conditions that are triggered not by a single event, but by a combination of events.
For example, “If you sneeze and have a fever, you have a cold.” Root cause analysis is used to explain the underlying causes of a series of events — usually errors — to ensure that remediation does not only address symptoms, but actually addresses the problem.
All Ceps should be in real time, or at the same time as events, but, of course, there are a lot of things that can happen at the same time. The more complex the relationship that CEP deals with, the more difficult it is to guarantee real-time performance.
3.2 Start with event-driven Programming
If you’ve ever written a GUI program, you’re familiar with event handling. In fact, event-driven programming has become a design pattern. Most GUI libraries follow this pattern.
Simply put, the event-driven pattern consists of three actors: an event producer, an event distributor, and an event handler.
-
The Events Generator determines whether Events need to be generated. For example, each component on the GUI is an event producer that can generate mouse events or keyboard events based on user actions.
-
The Events Dispatcher collects all Events sent out by event producers, puts them into the Events Queue, and distributes Events to registered event handlers according to the type of Events. Event dispatchers are typically implemented by GUI frameworks.
-
The Events Handler, written by the consumer of the GUI framework, processes the Events as they are received.
The core value of event-driven programming is that the flow of execution is not predefined, but determined by the user of the program. This will greatly enhance the interactivity of the program.
It’s like the difference between a DVD and an RPG: the story is set, and you can only start, pause, fast-forward, backtrack, and so on with limited interaction; The latter can influence the outcome of the story by determining the actions of the protagonist.
3.3 Event-driven Business
The world of code cannot be a complete mirror image of the real world, but it must be some abstraction of the real world that simplifies the analysis and processing of problems in the world of code. At the same time, this kind of abstraction can also be reverse mapped to the real world, providing us with ideas to solve real problems.
The external environment of modern enterprise is in drastic change, “agile enterprise” has become the way of survival, and event-driven business is a basic requirement of agile enterprise.
Event-driven Business is a kind of Business management that makes decisions in a continuous Business process, that is, it triggers related tasks according to a series of events occurring at different time points and schedules available resources to execute the tasks. If event-driven programming can bring more flexible interactivity and power to software, event-driven businesses in the enterprise can greatly improve business efficiency and flexibility.
Event-driven business relies on relatively mature information construction. While generating continuous data flow, each business application system generates some business events according to the defined conditions. These business events are analyzed and processed according to the policies to trigger new business events or business processes, namely, the business event-driven is realized.
As can be seen from the above description, event-driven business requires the ability to quickly (millisecond level), uninterrupted processing of continuous, massive data, with flexible rules or policy Settings, so as to quickly identify, capture, and respond to real-time business data. Traditional enterprise IT architectures typically employ:
Processing Business operations in Business applications follow fixed Business processes to Process cross-system transactions, and these processes rarely change. Storing and analyzing massive amounts of data based on data warehouse is an IT architecture that falls far short of the requirements of event-driven Business.
Event-driven business can be applied to many business areas. Any business that needs to process continuous data quickly and need to be able to make flexible policies can adopt event-driven business model. Such as the securities industry common risk analysis and early warning (pre-event and in-process risk control), investment decision (programmed trading), broker performance calculation, etc.
3.2.1 Several layers of business event processing
In fact, in the traditional IT architecture, we have already implemented the processing of business events. For example, in traditional business application systems, we usually store business data in a database, and manually discover and process business events through the operation interface of the application system.
This way of processing has two disadvantages, one is slow, and the other is that it is difficult to deal with complex situations only by human brain. So there are two technical directions:
Message queuing (MQ) The solution to slow speed was to replace people with machines. To deliver messages between multiple systems, the technology of message queuing (MQ) was developed. Business intelligence (BI) dealt with complexity by integrating data through data warehouses, But the two directions are orthogonal: MQ is not suited to dealing with complexity, while BI is primarily suited to analyzing structured historical data, not “now” situations.
3.4 CEP: You can have your cake and eat it
The emergence of CEP (Complex Event Processing) solves the problems in the above two aspects, and has been well solved in terms of real-time and complexity.
3.4.1 Processing data flows
Whether it is a separate application system or a data warehouse, data is stored in a database/data warehouse first, and then processed or queried. Similarly to MQ, CEP treats data as a data stream. Analyze and process continuous data in the process of rapid movement. This method does not require a large load of data, and can be done entirely in memory, which can produce results quickly.
3.4.2 Processing complexity
Business events can be complex, producing a steady stream of different types of events in a variety of different data flows. These business events require complex calculations such as filtering, correlation, aggregation, and so on, taking into account that they are also time series of events. Ultimately, a meaningful event is generated or a business process is triggered. At the same time, the rules for these calculations may change frequently.
This type of problem is usually implemented through rules-based inference machines, or rule engines.
To sum up, CEP should logically include:
- Event generators generate events through application systems, file systems, databases, the Internet, humans, and sensors
- Event handler pattern matching, validation and improvement, routing, transformation, and choreography
- Event consumers are similar to event generators and can be application systems, file systems, databases, Internet, human interfaces, etc
3.5 The three basic models of CEP and their features, and the limitations of CEP
The simplest scenario for CEP is trigger or threshold activation processing. In this model, an event either directly causes some operation to occur, or an operation is performed when the event reaches a certain threshold. CEP can introduce event processing, such as online transaction processing, into the stream of events from source to destination because of the small latency generated. While trigger or threshold CEP can be implemented with a single type of event, it is also possible to use multiple different events with different weights to provide a deeper understanding of the condition.
The second model is the context model, which assumes that an event or set of events only makes sense in a particular context, and therefore needs to maintain that context. This can be done by pattern matching, meaning finding a particular set of events that satisfy a pattern, or by processing the event with a state event when it changes an explicit context or state, and then understanding the event in context. The latter scenario is widely used for network management, where context examples might include initialization, activation, or error.
For more complex CEPS, you can use a cascading analysis model, where the event flow includes one or more types of events processed using a CEP model. Instead of taking actions directly to handle them, they generate additional events or event contexts, which are then injected into other phases of the CEP until the final action can be decided.
To sum up, the points that need attention are:
- Trigger or threshold activation processing
- Context model
- Cascading analysis model
Four, iBPM
IBPM stands for Intelligent Business Process Management. Gartner believes that IBPMs enhance complex event processing (CEP), intelligent robots and cloud services based on BPM, and excel in case management and process coordination capabilities.
Jim Sinur of Gartner first introduced the concept of an iBPM. In fact, when business Process Management systems (BPMS) converged with other smart tools, iBPM was born. These smart tools include machine learning, cloud services, mobile social networking, Complex Event processing (CEP), Iot integration, and Business activity monitoring (BAM).
It is important for practitioners of business process management (BPM) to tie event techniques to actions and correlate analysis results to application integration and useful business activities.
4.1 the characteristics of
IBPM has the following features:
- Smarter automation
More intelligent routing, process robots automatically complete the process work;
- Smarter mobile work
Cloud services that support process work from anywhere;
- More intelligent real-time analysis capabilities
Complex event processing (CEP) capability;
4.2 Differences between iBPM and BPM
BPM is a set of tools for modeling and executing business processes in a standardized way, and iBPM is an intelligent enhancement to BPM. From process discovery, design, modeling, execution, monitoring, and analysis to optimize all stages of the process lifecycle, the integration of artificial intelligence, complex event processing, cloud services, and mobile technologies.
4.3 iBPM characteristics
According to Pega System, intelligence (I) in iBPM is reflected in the following aspects:
- Dynamic Case Management:
Ibpms support traditional preprogrammed and structured BPM processes, as well as the creation of dynamic process cases associated with knowledge workers. These dynamic process cases reflect a new work model that incorporates social, collaborative, and responsive work, including exception handling. Dynamic cases can consist of tasks at multiple levels and can respond to or trigger transactions.
- Social iBPM:
Ibpms incorporate social tools at all stages of the process life cycle. Most importantly, IBPMs provide scenarios where social networks can be used in collaboration with rules.
-
Mobile IBPMs: IBPMs allow organizations to seamlessly start and complete end-to-end automated process work from mobile devices. The immediacy of process state, process work, and collaboration through mobile processes makes entirely new mobile work possible.
-
Cloud iBPM:
Enterprise applications can be securely built through the iBPM platform in the cloud, known as THE iBPM platform as a Service (PaaS). When the final BPM solution is built and deployed, ibPMs become services that can be executed or run on the cloud: IBPMs software as a Service (SaaS);
- Business rules in iBPM:
Business rules implement business decision logic and business policies, and these rules drive iBPM solutions. There are many categories and types of business rules, such as decision trees, decision tables, constraints, and expressions. The point of business rules is to make the business logic as close to the business as possible without worrying about execution time, execution method, or execution order. Business rules are declarative, and you can use predictive modeling techniques to detect business patterns, and then invoke or manipulate the discovered rules in an iBPM scenario;
- IBPM for real-time decision analysis and adaptive:
One of the most important trends in the industry is the emergence of data science, particularly big data analytics. Predictive analytics can bring tangible benefits to organizations by unraveling the patterns hidden in vast amounts of digital information. IBPM makes certain decisions feasible through prediction and adaptive (self-learning) analysis. In iBPM, the sources and types of data that are mined in the executable model are diverse, including social networks, transaction data, and data warehouses. IBPM uses predictive and adaptive data analysis models to provide more intelligent execution solutions in various dynamic case interactions.
BPM solutions are dynamic, social, mobile, rules-driven, and adaptive. These solutions can constantly analyze, learn, and adapt to external events, as well as the behavior of tripartite members and participants. Ibpms provide platforms, solutions, best practices, methods, and management practices for adaptive enterprises.
IBPM’s research and technology make the “adaptive enterprise” stand out in the business environment. Through intelligent business process management, adaptive enterprises constantly make their policies and business processes of business objectives completely transparent, which makes the visibility of business process management higher and stronger control. In the business environment of the future, adaptive enterprises become more flexible and proactive in responding to change. After all, the only constant in business is change!
Five, the MDM
5.1 MDM Functions
The role of MDM is how the organization processes the master data that the company needs to implement its business processes.
Master Data Management – Master data Management (MDM) is a management activity designed to ensure the quality of master data. The goal is to ensure that master data objects are applicable to all value-added processes in the company. MDM includes all the necessary operational and control processes that contain quality assurance definitions and ensure that master data objects are maintained and managed. In addition, MDM provides IT components to map this process. Thus, MDM plays a supporting role and helps add value in two implicit ways. Firstly, data quality management continuously improves the data quality of master data, thus enhancing the value of information; The second is the applicability of the master data object to all core processes, thereby increasing the added value through optimized core processes.
Master Data Objects – Master data objects are formal, basic business objects that are used in value-added processes within the company. The master data object describes the structure (blueprint) and the quality requirements (such as validation, allowable values in the structure). They interact with the user, often understanding the reference data (the list of values) as the actual master data for the company. A typical example is a standardized list of values, such as ISO country/region codes and ISO currency codes. Master data uses these lists as the basis for grouping, layering, and sorting. The master data is not the only reference list in this article, but they are the formal basic business objects.
5.2 MDM System Architecture
As a business transformation, MDM pursues the goal of implementing master data management across the company. To achieve this at reasonable operating costs, IT must support the process. This applies to the manual support process of MDM itself on the one hand and the automated process of data processing and distribution on the other.
To do this, it is necessary to establish a clear system architecture that includes system interdependencies. The system architecture of MDM describes the current situation and the planned target architecture. The following results are significant for MDM development planning:
The IT master plan for THE MDM growth plan, with an emphasis on the infrastructure
Master Data Planning with data model and data storage The process planning design area that Outlines the operational processes that affect MDM development planning and the IT application systems needed to support MDM includes the application architecture that contains the necessary MDM-specific systems, and the design area for IT Component support, master data logistics integration architecture and basic system architecture. Application systems and candidate MDM are reviewed to ensure that they provide appropriate functionality and are evaluated against appropriate criteria. Applications and integration components are based on infrastructure platforms that are independent of the infrastructure architecture. Information architecture has special significance for MDM. In addition to the flow of information (the flow of value and goods) across the company, the information architecture describes master data objects, associations, and their properties.Copy the code
Sixth, the ESB
6.1 define
An ESB is a middleware solution that uses a service-oriented model to promote and support interoperability between heterogeneous environments. No specification defines exactly what an ESB is or what capabilities it should provide. While the ESB is primarily associated with concepts like “tuning” and “integration,” it is also appropriate as a platform to provide services in a manner similar to that of an application server. An ESB represents the integration of product categories called “integration” and “application servers.”
6.2 Key Features
A key feature of an ESB is service virtualization. The ESB blueprint presented in this article provides an orderly sequence of functions that form the basis for evaluating ESB products.
6.3 points
The Enterprise service bus should be viewed as an architectural style or pattern, not a product. Esbs are not defined or regulated, and therefore there are no standards. An ESB helps achieve loose coupling between systems. Services on an ESB are stateless. Long-running processes are not part of the ESB but are supported in BPM systems using languages such as BPEL and BPMN. Caution should be exercised when “misusing” an ESB to perform batch processing, as this can have a negative impact on performance
For more details
7. Relationship description
7.1. ESP && CSP && CEP
What is the difference between ESP and CSP? ESP is stream processing where an event stream is a sequence of events in chronological order, such as a stock ticker. CEP works on “clouds” called “event clouds”. An event cloud is the result of multiple event generation activities from different parts of an IT system. The event cloud may contain multiple streams. Thus, a stream is a special instance of a cloud.
Using chronological order within a stream has its own advantages: processing is fast because only a few events need to be stored in the buffer. However, dependencies are very important in the cloud: What dependencies are happening? Or, more often than not, what events may not have happened?
Obviously, event flow processing focuses on high-speed processing, whereas CEP focuses on extracting information from the event cloud. In practice, as the distinction between ESP and CEP becomes blurred, the stronger CEP dominates.
7.2. The SOA && EDA
SOA identifiers are the loose coupling of services, 1:1 communication initiated by clients between providers and consumers, and synchronous response behavior. The identifiers for EDA are separate interactions, N: M communication, event-driven operations, and asynchronous operations. We don’t think it’s necessary to identify one end or the other. SOA provides a very solid foundation for EDA, and applications can adopt both styles. Components should invoke services using SOA in the following cases:
Knowing exactly which service is to be invoked The service will be invoked only once Expect a reply about service completion Expect a reply A component should publish an event using EDA if:Copy the code
In some cases, informing all the relevant receivers that don't know about the event the relevant receivers that don't know how the receiver is going to react to the event that different receivers are going to react to the same event that involves one-way communication from the sender to the receiver, rightCopy the code
In this respect, “2 + 2 > 4”, because the combination of the two architectural styles is greater than the sum of its parts. SOA uses a “request-response” communication pattern (possibly asynchronous, with a long interval between request and response) when executing predefined processes and logic. In contrast, ED applications use the typical “publisher/subscriber” pattern, which in some cases can handle a large number of events, with the aim of creating fewer new “actionable” events. SOA and EDA complement each other: Together they can create high business value applications that are delivered on demand
7.2.1 Multi-event flights
Regular air travellers are all too familiar with the unpleasant question “Where is my luggage?” At the check-in counter, passengers are separated from their luggage. At the end of the flight, passengers need to go through a series of procedures to retrieve their luggage, including:
Check-in counter Security baggage handling Cabin door operation Flight operation Airport Operations Control (BAM) dashboard Customer serviceCopy the code
The best provisional result is that the plane takes off on time with passengers and luggage on board. However, as many of us know, there can be many events that can complicate things. Luggage can be lost between check-in and boarding. Passengers may miss their flights because of queues at security checkpoints. Luggage may contain prohibited items and will need to be searched. Flights could be cancelled and passengers diverted. Passengers may decide to change their flight after checking in. Other complications may also occur.
In this case, SOA, EDA, or a combination of both
Before making a decision, consider that the scenario described is not a single “check-in service” or process. It’s a series of services/processes that interact. Interactions are complex and depend on multiple boundary conditions, so this is a typical “feel and respond” scenario, or EDA technology for starting SOA services when necessary. Trying to unify such scenarios in an executable process is bound to lead to chaos.
2. Security check: Passengers enter/leave the security check area. 3. Baggage handling: scan the luggage at the security check station, load the luggage into the container. Door operation: door opening, boarding, boarding and closing. Flight operation: gate, container loading, departure and departure 6. Customer service: check luggage for new flightCopy the code
7.3. The SOA and MDM
An important benefit of SOA is the loose coupling of IT components. This facilitates component reuse and makes it easier and more flexible for components to support new capabilities or processes.
MDM should be based on service-oriented concepts and provide common components (or services) to achieve consistency in data maintenance and master data retrieval. Here again, the SOA architecture concept coincides with MDM. This argument supports two different ideas:
MDM Business Services - Reusable business logic for maintaining and validating master data MDM Information Services - Reusable information used in business processesCopy the code
7.4. ESB && EDA && SOA
The ESB connects EDA and SOA
An Enterprise Service Bus (ESB) connects disparate platforms and environments, acting as an intermediary that allows different application processes to communicate. Services deployed to an enterprise service bus can be triggered by consumers or events. It supports both synchronous and asynchronous modes, facilitating interactions between one or more participants. Thus an ESB can provide all the functionality of the SOA and EDA paradigms. “The ESB is the glue of the enterprise application infrastructure by providing key functions such as message transmission and format transformation, bridging the communication between service requesters and service providers.” Said Huang Jianyong, senior technology manager of Oracle Greater China.
An enterprise service bus connects and mediates all communications and interactions between heterogeneous nodes that can be dispersed in a service-oriented architecture (synchronous one-to-one approach) and an event-driven architecture (asynchronous many-to-many approach). An ESB is by far the most effective way to address integration challenges, a technical solution that provides maximum business flexibility and efficient connectivity between different applications.
EDA is used in many ESB (Enterprise Service Bus) products, such as the FiornaoESB middleware product, which supports synchronous, asynchronous, and request-response events. Event handling and transport use different technologies such as JMS, HTTP, E-mail, and XML-based RPC. For example, the “government online supervision system” realizes notification and supervision of problems such as violation, violation of law, administration beyond authority and administration beyond time limit through real-time collection of the monitored object (system) data, event triggering and event filtering through EDA technology.
7.5.iBPM && BPM && CEP
BPM is a set of tools for modeling and executing business processes in a standardized way, and iBPM is an intelligent enhancement to BPM. From process discovery, design, modeling, execution, monitoring, and analysis to optimize all stages of the process lifecycle, the integration of artificial intelligence, complex event processing, cloud services, and mobile technologies.
It is important for practitioners of business process management (BPM) to tie event techniques to actions and correlate analysis results to application integration and useful business activities.
8.Serverless
Serverless refers to a developer’s implementation of server-side logic running in a stateless computing container, which is triggered by events, managed entirely by third parties, and whose business-level state is recorded by the databases and storage resources used by the developer.
8.1 Advantages of the Serverless Architecture
- Reduce operating costs:
Serverless is a very simple outsourcing solution. It lets you delegate management of servers, databases, applications and even logic to a service provider that you would otherwise have to maintain yourself. Because the number of users of this service would be so large, economies of scale would arise. There are two aspects of cost reduction, namely the cost of infrastructure and the cost of people (operation/development).
- Reduce development costs:
IaaS and PaaS exist on the premise that server and operating system management can be commoditized. The result of Serverless as just another service is that the entire application component is commoditized.
- Extended capability:
One of the obvious advantages of the Serverless architecture is that “scale-out is fully automated, resilient, and managed by the service provider.” The biggest benefit from basic infrastructure is that you only pay for the computing power you need.
- Easier to manage:
The Serverless architecture is significantly simpler than the other architectures. Fewer components means less administrative overhead for you.
- “Green” computing:
According to Forbes magazine, the typical server in a commercial and enterprise data center delivers only 5% to 15% of average maximum processing power output. This is undoubtedly a huge waste of resources. With the advent of the Serverless architecture, it is possible for service providers to provide our computing power to maximize real-time requirements. This will allow us to use our computing resources more efficiently.
9. FAAS
Functions as a Service. FaaS is a form of serverless computing. Currently, the most widely used is THE Lambada of AWS.
Now, when people talk about Serverless, the first thing that comes to mind is FaaS. FaaS is essentially an event-driven, message-triggered service. FaaS vendors typically integrate a variety of synchronous and asynchronous event sources and subscribe to these event sources to trigger functions to run in bursts or on a regular basis.
Unlike traditional server-side software, which is deployed to a virtual machine or container with an operating system, and generally needs to stay in the operating system for a long time to run, FaaS is to directly deploy the program on the platform. When an event comes, the execution is triggered, and the execution can be removed.
9.1 Serverless && FaaS
Function can be understood as a block of code functions. It is not clear how many functions this block contains, but there is a clear indicator: the cold start time should be on the order of milliseconds. Because the nature of FaaS is to enable fast startup of programs to truly run on demand, scale on demand, and be highly available. Function with the scheduling system, you can fully achieve the developer to the service running instances without feeling, true Serverless.
Serverless is more extensive than FaaS. FaaS mainly addresses how user defined code logic can be used to do Serverless. It is also called Serverless Compute, and it is also a type of event-driven architecture.
9.2 FaaS from the perspective of cloud development
The first phase of cloud mainly solves the problems of operation and supply of hardware resources (network, computing, storage), namely IaaS cloud, which can be understood as the sharing economy based on hardware resources. IaaS cloud delivery is primarily resource oriented, and interfaces and consoles are also resource oriented, minimizing application migration costs by emulating physical room environments. At the current stage of cloud development, there are two requirements:
Really on demand
In the past, on-demand computing in the cloud was only for virtual machines, with billing based on time and elastic scaling, and could not really achieve on-demand computing. Computing and memory resources were planned in advance, and had no clear relationship with the number of concurrent requests of services. Even if there was no one request in a period of time, resources were still occupied. FaaS, on the other hand, allows you to charge per request, without having to pay for waiting, resulting in more efficient resource utilization.
For application
Essentially, what users expect from the cloud is the environment in which applications are run, and it is best to let users only care about business logic and not care about technical logic (such as monitoring, performance, elasticity, high availability, log tracking, etc.). This is the background to the concept of Cloud Native Applications.
Cloud native applications are applications that transfer some functions to the cloud to achieve resilience, high availability, fault recovery, and lower R&D and o&M costs
But FaaS came up with a plan. The application only needs to submit the Function containing its own business logic to the cloud, and the cloud will do the rest of the work. In this way, the cloud takes over the business logic modules directly, and then other technical functions are provided directly by the cloud, without requiring developers to introduce standardized frameworks into their applications.
Appendix:
CEP
Warehouse:
Reference:
-
FRP definition
-
Event-driven architecture
-
Responsive declaration
-
The Reactive Manifesto
-
EDA&&SOA
-
CEP
-
Google_cloud_platform_CEP
-
iBPM
-
oracle
-
bpmjournal
Company
- tibco
- Gartner
DISS
- eda-versus-cep-and-soa
- cep-eda-and-soa