By Ken Meng

Today’s more successful companies have learned that to maximize operational efficiency and customer experience, they must integrate business and technology initiatives closely. Operational events or changes in the business situation are the focus of many organizations today, and these changes can bring practical and useful information to the leaders of the enterprise. The purpose of architectural design is to gain insights from customer contacts, transactions, operations, etc. The two complement each other. Traditional technologies, such as batch ETL (extract, Transform, load) for recording, collecting, and processing such events, have historically had limitations on how quickly an enterprise can gain insights from them.

Event-driven architecture (EDA) is on the rise, and as a Serverless application concept, it has a profound impact on cloud native architecture. When we talk about a specific architecture, the first thing to consider is whether its development is technologically advanced. Starting from the FAMILIAR MVC architecture and SOA architecture, let’s talk about the history and development trend in the field of message events.

Trends in the messaging event space

As early as 2018, Gartner’s evaluation report listed event-driven Model as one of the top 10 strategic technology trends, Event Driven Architecture (EDA) will become the mainstream of microservices in the future, and made the following assertions:

  • By 2022, event notification software models will be the solution for over 60% of new digital businesses;
  • By 2022, more than 50% of business organizations will participate in an event-driven ecosystem of digital business services;

George Santayana, in The Life of Reason, suggested that Those who fail to learn History are Doomed to repeat it. Let’s look at history to see why architecture has evolved to be event-driven.

Architecture itself is not superior or inferior, it is a set of technical decisions that determine all functional development (framework, coding specification, documentation, process… .). Here’s why certain frameworks were introduced and what problems they solve in software development.

  • Singleton architecture: In a single-node service, all modules of a singleton application are encapsulated in a single process and run, communicating through the same stack calls. In this mode, it is very easy to lead to unclear structure and relationship, and it is difficult to change and reconstruct the system. It’s like an opaque, sticky, fragile, stiff Big Ball of Mud!
  • Layered architecture: In classic layered architecture, layers are used in a fairly discreet manner. That is, a layer can only know the data of the layer below it. In subsequent practical applications, it is more likely that one layer can access any layer below it. Layered architecture solves the problem of logical separation of individual architectures, each layer can be replaced by equivalent, layer differentiation is more standardized, and a layer can be used by several different/higher level layers. Of course, there are obvious drawbacks to layers. Layers don’t encapsulate everything. For example, a field added to the UI may need to be added to the DB, and extra layers can seriously hurt system performance.
  • MVC Architecture: The reason for MVC architecture is very simple. As the complexity of business systems increases, the so-called “full stack engineer” is no longer suitable for most scenarios. In order to reduce the integration complexity of front-end and back-end, MVC architecture was promoted. The Model represents the business logic, the View represents the View layer, such as a widget of the front-end UI, and the Controller provides coordination between the View and the Model, such as converting a user action to business logic. There are many extensions, such as model-view-presenter, model-view-viewModel, resource-method-representation, The Action – Domain – Responder.
  • EBI architecture: Entity, interface, Interactor. The EBI architecture treats system boundaries as complete connections, not just views, controllers, or interfaces. EBI’s entity represents the actual entity that holds the data and ends the related behavior, much like ali Cloud’s POP API. EBI is primarily a back-end concept, which is complementary to MVC.
  • Onion architecture: The Onion architecture is a low coupling, high cohesion architecture model. All applications are built around a separate object model, with interfaces defined in the inner layer and implemented in the outer layer. Coupling is centered, and all code can be compiled and run independently of the infrastructure.
  • SOA architecture: SOA stands for Service Orientated Architure. Each function is provided by a separate service, which defines a clear callable interface and choreographed calls between services to complete a complete business. In fact, this architecture is the most mature and most commonly used architectural pattern in the current architecture.

What is EDA architecture

After we’ve covered all the architectural trends so far, we’ll go back and look at what EDA architecture is.

EDA event-driven Architecture is a system Architecture model whose core capability lies in the ability to detect system “events” or important business moments (such as transaction nodes, site visits, etc.) and take necessary actions on corresponding events in real time or near real time. This pattern replaces the traditional “request/ Response” model, where a service must wait for a reply before moving on to the next task. Event-driven architecture processes are run by events.

The figure above is a good explanation of the EDA architecture model, but it is not clear enough. So, here we compare and contrast with individual architectures to see how they differ.

In the diagram above, we can see the difference between it and traditional architecture. In a traditional architecture, after the order creation operation occurs, a series of operations are actually done through a system. The event-driven concept translates all operations into an “event” concept, and the downstream captures an “event” to determine which systems are called to perform what operations.

In summary, event-driven encapsulates significant business moments as “events” and routes the events to downstream systems via an EventBus.

We’ve seen the whole process of EDA architecture, but we haven’t figured out what this so-called “EventBUS” really is.

The diagram above shows the event-driven core logic architecture. Is it very much like a traditional MQ? Don’t worry, I’ll get to the complicated parts of the architecture next. With EventBus out of the way, let’s go back to “events.” The important part of the introduction is actually converting operations to some kind of event for distribution. So how do we define an event here?

Simply put, an event is a significant change in state that is triggered when the user takes a specific action. Take cars sold in 4S shops as an example:

  • When a customer buys a car and its status changes from “For Sale” to “Sold” is an event.
  • After a successful transaction, the amount deducted from the account is an event.
  • After clicking reservation test drive, adding reservation information to the specified user is an event.

Each event may trigger one or more options in response.

In 2018, the Cloud Native CNCF Foundation hosted the open source CloudEvents project, which aims to describe events in a unified and standardized format to enhance interoperability between different services, platforms and systems. Under the project definition, the common event specification looks like this:

Events are composed of Json bodies that describe events through different fields.

EDA architecture landing practice thinking

To begin with, let’s look at a classic EDA architecture model:

This is a very classic EDA order architecture, which mainly uses EventBridge and FC function calculation (if you are not familiar with FaaS you can think of FC node as a POD node of ECS or K8s) to drive the various business collaboration through events.

So the EventBridge actually has three important capabilities:

  1. For Event Capturing: Ability to collect events
  2. For Routing: Ability to distribute event routes downstream by event content
  3. For Event Processing: The ability to desensitize or initially filter events

In general, these three capabilities are difficult to implement. For example: Event Capturing may require familiarity with Dell Boomi, Snaplogic, MuleSoft, Dataflow, Apache Apex, etc. Routing may be via RocketMQ, RabbitMQ, ActiveMQ, Apache Kafka, Event Processing, Apache Storm, Apache Flink. So the logic architecture mentioned above is actually ideal, and to achieve the completion of EDA event-driven also need to include these core capabilities.

In fact, from the framework just we can also pry some information, EDA architecture actually looks not so simple, that it has any advantages and disadvantages? Here I will simply list the advantages of EDA architecture in practice:

  • Loosely-coupled: Event-driven architectures are highly loosely-coupled and highly distributed architectural models in which the creator (source) of an event only knows what happened, not how it was handled, and how many interested parties subscribed to the event.
  • Asynchronous execution: The EDA architecture is the most suitable execution tool for asynchronous scenarios, where we can keep the required events in the queue until the state is normal for execution.
  • Scalability: Event-driven architecture can quickly partition services through routing and filtering capabilities, providing easier scaling and routing distribution.
  • Agility: Event-driven architectures can provide more agile and efficient deployment solutions by distributing events anywhere.

Of course, the disadvantages are obvious:

  • Complex architecture: complex event-driven architecture, multiple routing nodes, complex system formation and multiple functional requirements.
  • Route distribution difficulty: Event routing and distribution are difficult. Flexible event routing relies on powerful real-time computing capabilities and has high requirements on the overall distribution system.
  • Untraceable: Event tracking is a guarantee for the entire EDA architecture, where event processing status is often difficult to track and requires a lot of custom development.
  • Poor reliability: Event driven due to the need for multi-system integration, reliability is often poor and delivery is not guaranteed.

How does Ali Cloud EventBridge solve the dilemma in EDA scenarios

In response to these problems in EDA scenarios, ali cloud launched EventBridge, a serverless event bus service. Its mission is to serve as the hub of CloudEvents, connecting cloud products and applications with standardized CloudEvents 1.0 protocol, providing centralized event governance and driving capabilities. Help users easily build loosely coupled, distributed event-driven architectures; In addition, there are a large number of SaaS verticals in the cloud market outside AliYun. EventBridge will help customers create a complete, event-driven, efficient and controllable cloud experience with its outstanding integration and being integrated across products, organizations and clouds. And provide targeted solutions to EDA dilemma.

Complex architecture: provides common Source, Buses, Rules and Targets module management capabilities, and supports both EventBus and EventStream modes. Significantly reduce the difficulty of event-driven architecture.

Route distribution: EventBridge is driven by event rules, supports eight event modes and quadruple converters to meet all the requirements for route distribution.

Untraceable: Exclusive event tracking capabilities, event analysis/query capabilities. Improve the overall event link for users.

Poor reliability: DLQ/ retry mechanism is supported to greatly ensure the event failure and delay caused by the user’s downstream system.

On top of that, EventBridge supports 82 Aliyun products and 847 event types.

Aliyun EventBridge more scenarios

  1. Classic EDA event-driven: The most important capability of EventBridge is to build EDA (Event-driven Architectures) event-driven Architectures by connecting applications, cloud services and Serverless services, driving applications to applications, and applications to the cloud.

  1. Streaming ETL scenario: EventBridge another core ability is the responsibility for streaming data pipeline, provide the basis of filtering and transformation ability, in the different between a data warehouse, data processing procedure, data analysis and processing system of data synchronization between/cross-regional backup scenarios, such as the connection of different systems with different services.

  1. Unified Event notification service: EventBridge provides a variety of cloud product event sources and event lifecycle management tools. You can directly monitor the data generated by cloud products through the bus and report it to downstream services such as monitoring and notification.

The current event bus free public test, click the link below, immediately experience! www.aliyun.com/product/ali…

Join the nail group (group number: 31481771), timely understand the latest product trends!