WCF实现事件通知是一个比较容易掌握的知识点,不过在实现的过程中,我们还是需要注意一些事项,以保证功能的完善性。

  WCF中有一些方法的应用对于初学者来说还是比较容易应用。只要熟练的联系这些方法操作,一般都能牢固的掌握。看了一些WCF的例子,实现事件通知使用的是多播委托的特性,有点复杂,操作起来也不是很直观,看到一堆委托和事件我一般头就晕了。

下面介绍一种使用观察者模式WCF实现事件通知的简单方法。没别的,就是简单,简单最美。
工程代码如下:

WCF实现事件通知1.定义接口

 [ServiceContract(SessionModeSessionMode =
  SessionMode.Required, CallbackContract
 = typeof(IWriteLogCallback))]
 public interface ILogService
 {
 [OperationContract(IsInitiating =
 true, IsTerminating = false)]
 void Write(string logMsg);
 [OperationContract(IsInitiating =
 true, IsTerminating = false)]
 void RegisterListener();
 [OperationContract(IsInitiating =
 false, IsTerminating = false)]
 void UnregisterListener();
 }
 [ServiceContract]
 public interface IWriteLogCallback
 {
 [OperationContract(IsOneWay = true)]
 void OnWriteLog(string logMsg);
 } 

为了简单举了一个写日志的例子, Write(string logMsg)就是写入日志的方法,参数logMsg是需要写入的日志信息。当客户单没有调用RegisterListener()订阅事件的时候,是不会收到写日志的事件通知的,相应的要获得写日志的事件通知,就需要调用RegisterListener()方法。如果要取消订阅就调用UnregisterListener()方法。写日志的功能和事件的订阅功能是分开的。

WCF实现事件通知2.服务实现

 [ServiceBehavior(
 IncludeExceptionDetailInFaults = true,
 InstanceContextModeInstanceContextMode =
  InstanceContextMode.Single,
 ConcurrencyModeConcurrencyMode =
 ConcurrencyMode.Multiple)]
 class LogService:ILogService
 {
 public LogService()
 {
 Trace.WriteLine("Create LogService Instance.");
 }
 Dictionary<string, OperationContext>
 listeners = new Dictionary<string,
  OperationContext>();
 private void BroadCast(string logMsg)
 {
 List<string> errorClints = new List<string>();
 foreach (KeyValuePair<string, OperationContext>
 listener in listeners)
 {
 try
 {
 listener.Value.GetCallbackChannel
 <IWriteLogCallback>().OnWriteLog(logMsg);
 }
 catch (System.Exception e)
 {
 errorClints.Add(listener.Key);
 Trace.WriteLine("BROAD EVENT ERROR:" + e.Message);
 }
 }
 foreach (string id in errorClints)
 {
 listeners.Remove(id);
 }
 }
 #region ILogService 成员
 public void Write(string logMsg)
 {
 Trace.WriteLine("Write LOG:"+logMsg);
 BroadCast(logMsg);
 }
 public void RegisterListener()
 {
 listeners.Add(OperationContext.Current.
 SessionId, OperationContext.Current);
 Trace.WriteLine("SessionID:" +
  OperationContext.Current.SessionId);
 Trace.WriteLine("Register listener.
 Client Count:" + listeners.Count.ToString());
 }
 public void UnregisterListener()
 {
 listeners.Remove(OperationContext
 .Current.SessionId);
 Trace.WriteLine("SessionID:" +
 OperationContext.Current.SessionId);
 Trace.WriteLine("Unregister listener.
  Client Count:" + listeners.Count.ToString());
 }
 #endregion
 } Dictionary<string, OperationContext> 

listeners包含了所有的事件订阅者。发布事件的时候,如果调用订阅者的回调函数失败,就把该订阅者从listeners移除。代码很简单,就不多说了。

WCF实现事件通知3.客户端访问

定义回调的客户端:

 class LogClient:IWrite
 LogCallback
 {
 #region IWriteLog
 Callback 成员
 public void OnWriteLog
 (string logMsg)
 {
 Trace.WriteLine("RECV
 LOG EVENT:" + logMsg);
 }
 #endregion
 } 

然后在程序中使用它:

 class Program
 {
 static void Main(string[] args)
 {
 Trace.Listeners.Add(new
  ConsoleTraceListener());
 LogClient client = new LogClient();
 ILogService service =
  DuplexChannelFactory<ILogService>.
 CreateChannel(client,
 new WSDualHttpBinding(), new
 EndpointAddress("http:
 //localhost:8888/log"));
 //订阅消息
 service.RegisterListener();
 service.Write("Client start");
 Console.WriteLine("Press
 enter key to exit.");
 Console.ReadLine();
 service.UnregisterListener();
 } 

WCF实现事件通知需要注意的问题:
A. 因为客户也要监听端口,所以确保防火墙没有对它进行阻止。
B. 这里使用的是单实例的服务,所以需要进行多进程访问的保护,才能实际使用。

本文来自:http://developer.51cto.com/

WCF实现事件通知相关应用技巧介绍的更多相关文章

  1. ------- 软件调试——注销 QQ 过滤驱动设置的事件通知 CallBack (完)-------

    ---------------------------------------------------------------------------------- 本系列的最后一篇演示如何通过调试手 ...

  2. PHP 命令行模式实战之cli+mysql 模拟队列批量发送邮件(在Linux环境下PHP 异步执行脚本发送事件通知消息实际案例)

    源码地址:https://github.com/Tinywan/PHP_Experience 测试环境配置: 环境:Windows 7系统 .PHP7.0.Apache服务器 PHP框架:ThinkP ...

  3. C#的Xamarin开发小米盒子应用并以WCF实现微信通知

    对于熟悉C#语言的开发人员而言,用Xamarin开发Android应用也是一个不错的选择.小米盒子是Android系统.当然也就能够使用Xamarin来开发.首选来看效果图. watermark/2/ ...

  4. SQL Server 事件通知(Event notifications)

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 基础知识(Rudimentary Knowledge) 事件通知监控DDL(NotifyQue ...

  5. spring事件通知机制详解

    优势 解耦 对同一种事件有多种处理方式 不干扰主线(main line) 起源 要讲spring的事件通知机制,就要先了解一下spring中的这些接口和抽象类: ApplicationEventPub ...

  6. Linux内核基础--事件通知链(notifier chain)

    转载: http://blog.csdn.net/wuhzossibility/article/details/8079025 http://blog.chinaunix.net/uid-277176 ...

  7. 如何扩展分布式日志组件(Exceptionless)的Webhook事件通知类型?

    写在前面 从上一篇博客高并发.低延迟之C#玩转CPU高速缓存(附示例)到现在又有几个月没写博客了,啥也不说,变得越来越懒了,懒惰产生了拖延后遗症. 最近一周升级了微服务项目使用的分布式日志组件Exce ...

  8. .NET Core 实践二:事件通知和异步处理

    首先让我们来先看一个例子: 这是一个简单的用户下单购买商品的业务模型,输入端是用户,相关物料有订单和货物,相关的内部服务有业务(订单).财务(支付).仓储(备货)和物流(运输). 从图中我们可以看到, ...

  9. 08 Zabbix4.0系统配置事件通知 - 动作Action

    点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 08 Zabbix4.0系统配置事件通知 - 动作Action 请点击查看Zabbix3.0.8版 ...

随机推荐

  1. SuperMap-iServer-单点登录功能验证(CAS)

    SuperMap-iServer-单点登录功能验证(CAS) 1.测试目的: 验证SuperMap-iServer使用CAS单点登录的功能是否正常. 2.测试环境: SuperMap-iServer8 ...

  2. windows 7(32/64位)GHO安装指南(U盘引导篇)~

    上一篇我们说了怎么制作U盘启动盘,那么这一篇让我们来看看如何进行正确的U盘引导启动. 现在的个人计算机一般分为台式机和笔记本,由于各厂商的喜好不同(开玩笑的啦),所以对于主板的BIOS设置各所不同.进 ...

  3. Spark Streaming+Kafka

    Spark Streaming+Kafka 前言 在WeTest舆情项目中,需要对每天千万级的游戏评论信息进行词频统计,在生产者一端,我们将数据按照每天的拉取时间存入了Kafka当中,而在消费者一端, ...

  4. 入园记------我的DBA之路

    今天周一拖着疲惫的身躯 11点才离开公司,回到家估计写完这篇博客就要17号了. 一个人走在回家的路上,很黑,突然很多感触,一个人在北京拼搏,不敢停止学习的脚步,因为只要停下来就会感觉到孤独. 回顾一下 ...

  5. (转)linux下和云端通讯的例程, ubuntu和openwrt下实验成功(二)

    前言: 上节用纯linux的函数实现了和云端通讯, 本节开始利用传说中的神器libcurl 话说一个网络程序员对书法十分感兴趣,退休后决定在这方面有所建树. 于是花重金购买了上等的文房四宝.    一 ...

  6. RabbitMQ的安装过程

    原创文章转载请注明出处:@协思, http://zeeman.cnblogs.com 网上一些安装教程都较为繁琐,实际上只需要两个RPM包,几分钟即可完成一台实例部署. 准备下载Erlang包: ht ...

  7. Spark2 ML 学习札记

    摘要: 1.pipeline 模式 1.1相关概念 1.2代码示例 2.特征提取,转换以及特征选择 2.1特征提取 2.2特征转换 2.3特征选择 3.模型选择与参数选择 3.1 交叉验证 3.2 训 ...

  8. 使用python crontab设置linux定时任务

    熟悉linux的朋友应该知道在linux中可以使用crontab设置定时任务.可以通过命令crontab -e编写任务.当然也可以直接写配置文件设置任务. 但是有时候希望通过脚本自动设置,比如我们应用 ...

  9. Spring学习记录(十二)---AOP理解和基于注解配置

    Spring核心之二:AOP(Aspect Oriented Programming) --- 面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术.AOP是OOP的延续,是软 ...

  10. Apply Newton Method to Find Extrema in OPEN CASCADE

    Apply Newton Method to Find Extrema in OPEN CASCADE eryar@163.com Abstract. In calculus, Newton’s me ...