基于A2DFramework的事件机制实现
发布订阅 - 基于A2DFramework的事件机制实现
SUMMARY
- 能做什么
- DEMO
- 原理图
- 应用场景
能做什么
A2DFramework的事件机制是基于发布订阅模式改进得来的一套API,中间件部分实现了msmq、redis、Supersocket可替换。能够实现较彻底的模块事件传递过程中的解耦,支持分布式环境。由于订阅端采用了消息队列作为转发层,因此也能支持事件量很大的场景。
DEMO
Demo工程下载地址(可右键保存):
一、建立各个工程,并且加入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、生成报表数据等
- 能保持前端轻,响应速度快
- 模块解耦、面向模块编程
心怀远大理想。
为了家庭幸福而努力。
A2D科技,服务社会。
A2D Framework(Alpha)
- 1. Cache System(本地缓存与分布式缓存共存、支持Memcache和Redis、支持贴标签形式(类似Spring 3.x的Cache形式))
- 2. Event System(本地事件与分布式事件分发)
- 3. IoC(自动匹配功能,实例数量限制功能)
- 4. Sql Dispatcher System(支持ADO.NET及EF)
- 5. Session System(分布式Session系统)
- 6. 分布式Command Bus(MSMQ实现,解决4M限制,支持Session的读取)
- 7. 规则引擎
QQ群:283016070,真材实料的.NET架构师
基于A2DFramework的事件机制实现的更多相关文章
- 发布订阅 - 基于A2DFramework的事件机制实现
SUMMARY 能做什么 DEMO 原理图 应用场景 能做什么 A2DFramework的事件机制是基于发布订阅模式改进得来的一套API,中间件部分实现了msmq.redis.Supersocket可 ...
- 【React】354- 一文吃透 React 事件机制原理
大纲 主要分为4大块儿,主要是结合源码对 react事件机制的原理 进行分析,希望可以让你对 react事件机制有更清晰的认识和理解. 当然肯定会存在一些表述不清或者理解不够标准的地方,还请各位大神. ...
- spring的事件机制实战
理论 在分布式场景下,实现同步转异步的方式有三种方式: 1.异步线程池执行:比如借助@Asyn注解,放到spring自带的线程池中去执行: 2.放到消息队列中,在消费者的代码中异步的消费,执行相关的逻 ...
- Ext JS学习第十六天 事件机制event(一) DotNet进阶系列(持续更新) 第一节:.Net版基于WebSocket的聊天室样例 第十五节:深入理解async和await的作用及各种适用场景和用法 第十五节:深入理解async和await的作用及各种适用场景和用法 前端自动化准备和详细配置(NVM、NPM/CNPM、NodeJs、NRM、WebPack、Gulp/Grunt、G
code&monkey Ext JS学习第十六天 事件机制event(一) 此文用来记录学习笔记: 休息了好几天,从今天开始继续保持更新,鞭策自己学习 今天我们来说一说什么是事件,对于事件 ...
- Node.js入门:事件机制
Evented I/O for V8 JavaScript 基于V8引擎实现的事件驱动IO. 事件机制的实现 Node.js中大部分的模块,都继承自Event模块(http://n ...
- Android事件机制之一:事件传递和消费
http://www.cnblogs.com/lwbqqyumidi/p/3500997.html 关于Android中的事件机制,用到的地方还是很多的,并且这个知识点还真有点复杂. 在写这篇文章前, ...
- U3D C# 实现AS3事件机制
写了很多年的AS3,最近接触U3D感觉事件机制没AS3的爽.咬紧牙关一鼓作气 基于C# 的委托实现了一版.废话不多说上干货. EventDispatcher代码如下: using UnityEngin ...
- AS3事件机制概述
事件机制是AS3的核心功能之一,没有充分掌握事件机制的方方面面,就不能算是精通AS3语言. 1. AS3事件机制的主要成员 IEventDispatcher:事件派发对象接口,定义了添加.派发.移除. ...
- 百度地图API详解之事件机制,function“闭包”解决for循环和监听器冲突的问题:
原文:百度地图API详解之事件机制,function"闭包"解决for循环和监听器冲突的问题: 百度地图API详解之事件机制 2011年07月26日 星期二 下午 04:06 和D ...
随机推荐
- ios正在使用NSDateComponents、NSDate、NSCalendar它的结论是在当前时间是在一段时间在一天。
一般应用程序设置这一组的存在,比如夜间模式,如果你.从8:00-23:00.在这个当前的时间是如何推断出期间.主要的困难在于如何使用NSDate生成8:00时间和23:00时间.然后用当前时间,也许有 ...
- 【android】ImageView的src和background以及两者之间的神奇的差异
一.ImageView中XML属性src和background的差别: background会依据ImageView组件给定的长宽进行拉伸.而src就存放的是原图的大小,不会进行拉伸.src是图片内容 ...
- DynamicReports 导出Excel 例子
import java.awt.Color; import java.io.FileOutputStream; import java.util.ArrayList; import java.util ...
- Redhat Linux挂载NTFS格式的移动硬盘
Redhat Linux挂载NTFS格式的移动硬盘 1. 选择下载ntfs-3g的源码包或rpm包 http://www.tuxera.com/community/open-source-ntfs-3 ...
- 【高德地图API】如何制作自己的旅游地图?
原文:[高德地图API]如何制作自己的旅游地图? “旅行的梦想并不遥远,只要一颗流浪四方的心.”——唐人立. 最早认识唐人立的时候,他还是大二的学生.他独自完成了“南京20年规划地图”.几年前,他完成 ...
- Swift # 异常处理
面向轨道编程 - Swift 中的异常处理 问题 在开发过程中,异常处理算是比较常见的问题了. 举一个比较常见的例子:用户修改注册的邮箱,大概分为以下几个步骤: 接收到一个用户的请求:我要修改邮箱地址 ...
- MVC应用程序使用Web Services(asmx)
原文:MVC应用程序使用Web Services(asmx) 这次,我们练习MVC应用程序中,应用web service.先在MVC应用程序中创建一个目录Services,将用来存储Service.a ...
- 【翻译自mos文章】SYS_OP_C2C 导致的全表扫描(fts)/全索引扫描
SYS_OP_C2C 导致的全表扫描(fts)/全索引扫描 參考原文: SYS_OP_C2C Causing Full Table/Index Scans (Doc ID 732666.1) 适用于: ...
- Struts2和Struts1的主要区别(完整版)
Struts1和Struts2的区别和对比: Action 类: • Struts1要求Action类继承一个抽象基类.Struts1的一个普遍问题是使用抽象类编程而不是接口,而struts2的Act ...
- springmvc继承activemq(原创)
1.加入jar包 我项目是用maven构建的,所以这里就给大家贴一下配置了,具体jar大家可以参看下Activemq分类中的文章 <project xmlns="http://mave ...