SUMMARY

  • 能做什么
  • DEMO
  • 原理图
  • 应用场景

能做什么

A2DFramework的事件机制是基于发布订阅模式改进得来的一套API,中间件部分实现了msmq、redis、Supersocket可替换。能够实现较彻底的模块事件传递过程中的解耦,支持分布式环境。由于订阅端采用了消息队列作为转发层,因此也能支持事件量很大的场景。

DEMO

Demo工程下载地址(可右键保存):

发布订阅Demo.rar

一、建立各个工程,并且加入A2DFramework.EventService的引用

二、给各个工程加入A2D基本代码,如下:

A2DFramework.Starter.Init();
A2DFramework.QueueService.Starter.Init();
A2DFramework.EventService.Starter.Init();

三、加入A2D.config文件以及相应的配置(事件机制用到了队列框架)

<?xml version="1.0" encoding="utf-8" ?>
<A2D>
<QueueSetting QueueType="MSMQ"><!--Redis-->
<MSMQ><!-- 根据QueueType类型,此节点可省略 -->
<AutoDeleteNetworkFile>true</AutoDeleteNetworkFile>
<QueueConnectionStringFormat>server1\private$\A2D_订阅者2_{0}</QueueConnectionStringFormat>
<NetworkLocation>msmq</NetworkLocation>
<MaxQueueBodyLength>3670016</MaxQueueBodyLength>
</MSMQ>
<Redis><!-- 根据QueueType类型,此节点可省略 -->
<ReadWriteServerIps>192.168.1.1</ReadWriteServerIps>
<ReadOnlyServerIps>192.168.1.1</ReadOnlyServerIps>
<MaxReadPoolSize>1000</MaxReadPoolSize>
<MaxWritePoolSize>1000</MaxWritePoolSize>
<QueueNameFormat>A2D_{0}1</QueueNameFormat>
</Redis>
</QueueSetting>
<ShareFileSetting>
<NetworkShareRoot>\\server1\share\msmq</NetworkShareRoot>
</ShareFileSetting>
<EventSetting EventBusType="Redis"><!--SuperSocket/Redis/Local-->
<SuperSocket><!-- 可选 -->
<Identifier>app server name 3</Identifier><!--客户端的名称,需要发往event server-->
<Address>192.168.4.191</Address>
<Port>2012</Port>
<RetryConnectInterval>1000</RetryConnectInterval>
</SuperSocket>
<Redis><!-- 可选 -->
<Identifier>app server name 1</Identifier>
<ReadWriteServerIps>192.168.4.191</ReadWriteServerIps>
<ReadOnlyServerIps>192.168.4.191</ReadOnlyServerIps>
<MaxReadPoolSize>1000</MaxReadPoolSize>
<MaxWritePoolSize>1000</MaxWritePoolSize>
</Redis>
<Local><!-- 可选 --> </Local>
<EventMapping><!-- Event节点可以有多个 -->
<Event Event="Events.OrderCreated" EventFullType="Events.OrderCreated, Events">订阅者2.OrderCreatedEventHandlerProcessor, 订阅者2</Event>
<!--

Event属性:事件Type全路径

EventFullType属性:事件Type全路径+dll名

节点value:关联的事件处理函数类+dll名

-->

      </EventMapping>
</EventSetting>
</A2D>

四、定义事件(可自定义)

public class OrderCreated : IEvent   //A2DFramework.EventService.IEvent
{
/// <summary>
/// 新订单ID
/// </summary>
public Guid NewOrderID { get; set; } /// <summary>
/// 下单时间
/// </summary>
public DateTime OrderTime { get; set; }
}

五、在订阅者中定义事件处理函数:

public class OrderCreatedEventHandlerProcessor : IProcessReceivedEventProcessorHandler<OrderCreated>
{
public void Process(OrderCreated evt)
{
Console.WriteLine("订阅者1 接收到了OrderCreated事件,NewOrderID: " + evt.NewOrderID);
}
}

六、运行效果图:

原理图

应用场景

  • 将重载荷通过事件分发到专门处理的服务器来处理,比如生成pdf、生成报表数据等
  • 能保持前端轻,响应速度快

  • 模块解耦、面向模块编程

发布订阅 - 基于A2DFramework的事件机制实现的更多相关文章

  1. 基于A2DFramework的事件机制实现

    随笔- 102  文章- 3  评论- 476  发布订阅 - 基于A2DFramework的事件机制实现   SUMMARY 能做什么 DEMO 原理图 应用场景 能做什么 A2DFramework ...

  2. 《JavaScript设计模式与开发实践》笔记第八章 发布-订阅模式

    第八章 发布-订阅模式 发布-订阅模式描述 发布-订阅模式又叫观察者模式,它定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都将得到通知. 发布-订阅模式可以广泛应用于 ...

  3. Atitit.事件机制 与 消息机制的联系与区别

    Atitit.事件机制 与 消息机制的联系与区别 1. 消息/事件机制是几乎所有开发语言都有的机制,在某些语言称之为消息(Event),有些地方称之为(Message).1 2. 发布/订阅模式1 3 ...

  4. nopCommerce 3.9 大波浪系列 之 事件机制(生产者、消费者)

    一.nop事件机制简介 应用场景:客户支付成功后,需要发送短信.邮件告知客户订单支付成功(短信.邮件由不同模块实现) 实现方法: 1.定义支付成功OrderPaidEvent事件. 2.定义短信,邮箱 ...

  5. spring的事件机制实战

    理论 在分布式场景下,实现同步转异步的方式有三种方式: 1.异步线程池执行:比如借助@Asyn注解,放到spring自带的线程池中去执行: 2.放到消息队列中,在消费者的代码中异步的消费,执行相关的逻 ...

  6. javascript中的发布订阅模式与观察者模式

    这里了解一下JavaScript中的发布订阅模式和观察者模式,观察者模式是24种基础设计模式之一. 设计模式的背景 设计模式并非是软件开发的专业术语,实际上设计模式最早诞生于建筑学. 设计模式的定义是 ...

  7. Redis 发布订阅,小功能大用处,真没那么废材!

    今天小黑哥来跟大家介绍一下 Redis 发布/订阅功能. 也许有的小伙伴对这个功能比较陌生,不太清楚这个功能是干什么的,没关系小黑哥先来举个例子. 假设我们有这么一个业务场景,在网站下单支付以后,需要 ...

  8. 【React】354- 一文吃透 React 事件机制原理

    大纲 主要分为4大块儿,主要是结合源码对 react事件机制的原理 进行分析,希望可以让你对 react事件机制有更清晰的认识和理解. 当然肯定会存在一些表述不清或者理解不够标准的地方,还请各位大神. ...

  9. SpringBoot事件监听机制及观察者模式/发布订阅模式

    目录 本篇要点 什么是观察者模式? 发布订阅模式是什么? Spring事件监听机制概述 SpringBoot事件监听 定义注册事件 注解方式 @EventListener定义监听器 实现Applica ...

随机推荐

  1. require.js 使用博客

    没时间写博客,又觉得这篇很不错,或许以后能用到,只能copy与点赞: Javascript模块化编程(三):require.js的用法   作者: 阮一峰 日期: 2012年11月 7日 这个系列的第 ...

  2. 在CentOS安装cobbler自动化部署软件

    #!/bin/bash##cobbler server addressip=192.168.119.133#DHCP server net and address fanweinet=192.168. ...

  3. git -- 如何撤销本地工作目录的修改

    git checkout -- 文件名(包含路径) 撤销本地全部修改 git checkout .

  4. Spring MVC 指导文档解读(一)

    22.1 指导文档章节 In the Web MVC framework, each DispatcherServlet has its own WebApplicationContext, whic ...

  5. 「2013-9-5」Configure WingIDE for better display of East Asian Glyphs

    很久没写软件配置相关的博客了.这次对于 WingIDE 在 Windows 下的字体配置,折腾了好一阵子,略曲折,也反映了「不清楚原理和背景的情况下,盲人摸象的效率低下是必然」这条放之四海而皆准的赤果 ...

  6. 思维导图软件TheBrain 8全新发布 提供更强大的信息管理

    TheBrain思维导图软件是全球唯一一款动态的网状结构的思维导图软件,广泛用于学习.演讲.项目管理.会议.需求调研与分析等.其独特的信息组织方式使得用户可以创建并连接到数以万计的数字想法,为此在全球 ...

  7. 注意在<s:if test="#session.user.power==0">中不能用 <s:if test=$sessionScope.user.power==0">

    获取封装在session的对象 用#session.对象名,可以获取对象 用#session.对象名.属性,可以获取属性. 注意在<s:iftest="#session.user.po ...

  8. HDU 2019 数列有序!

    Time Limit: 1000 MS Memory Limit: 32768 KB 64-bit integer IO format: %I64d , %I64u   Java class name ...

  9. ubuntu下使用nginx部署Laravel

    问题描述 Laravel是PHP下当今最受欢迎的web应用开发框架,github上start数远超第二名Symfony,以前我用这个框架做项目的时候通常就是扔到apache里面,然后配置.htacce ...

  10. 深入理解java虚拟机【类加载机制】

    Java虚拟机类加载过程是把Class类文件加载到内存,并对Class文件中的数据进行校验.转换解析和初始化,最终形成可以被虚拟机直接使用的java类型的过程. 在加载阶段,java虚拟机需要完成以下 ...