Flex消息服务

1, 初识消息服务: 
相关概念: 
      消息(message):包括头信息(head)和主题(body),头信息又包括消息标识和路径信息,消息主题包括应用数据生产者(producer)和消费者(consumer):发信息的应用成为生产者,接收信息的应该称为消费者,生产者将消息发送到特定的消息接收点,消息服务会将这条信息转发到适合的消费者 
消息接收点(message destination):负责将数据转换为消息,以及将消息转换为消费者可以使用的数据格式的代码 
消息通道(message channel):用来将生产者和消费者连接到消息接收点 
消息适配器(message adapter):消息适配器是flex消息服务和其他系统的转换器,比如JMS适配器使得基于java的JMS消息应用可以像flex应用一样共享相同的接收点,java应用可以向flex应用分布消息,同时也可以相应flex应用发送的消息 

消息流程: 
flex消息服务支持两种类型的消息:发布/订阅消息和点到点消息 

2, 使用flex消息服务 


Producer的创建: 
1,使用MXML方式: 

 

Mxml代码 复制代码  收藏代码
  1. <mx:Producer id=”user1” destination=”msCenter” acknowledge=”handleAck(event)” fault=”handleFault(event)”/>   
<mx:Producer id=”user1” destination=”msCenter” acknowledge=”handleAck(event)” fault=”handleFault(event)”/> 

 

 

 

MessageEvent-----消息处理,MessageAckEvent------确认事件处理,MessageFaultEvent--------错误事件处理 
2,  使用as方式 

As3代码 复制代码  收藏代码
  1. private var user1:Producer;    
  2.    user1 = new Prodicer();    
  3.    user1.destination = “msCenter”;    
  4.    user1.addEventListener(MessageAckEvent.ACKNOWLEDGE,handleAck);    
  5.    user1.addEventListener(MessageFaultEvent.FAULT,handleFault);   
 private var user1:Producer; 
    user1 = new Prodicer(); 
    user1.destination = “msCenter”; 
    user1.addEventListener(MessageAckEvent.ACKNOWLEDGE,handleAck); 
    user1.addEventListener(MessageFaultEvent.FAULT,handleFault); 

 
创建好之后,就是发送,发送有三个步骤: 
1, 创建用于消息发送的mx.messaging.messages.AsyncMessage对象 
2, 定义对象的主体内容,即要发送的信息 
3, 调用组件的send()方法发送信息 

As3代码 复制代码  收藏代码
  1. 如:var content:AsyncMessage=new AsyncMessage();    
  2. content.body=”韩定”;    
  3. user1.send();    
  4. 可以向消息中添加额外信息    
  5. 如:var content:AsyncMessage=new AsyncMessage();    
  6. content.headers = new Array();    
  7. content.headers[“user”]=”张三”;   
如:var content:AsyncMessage=new AsyncMessage(); 
content.body=”韩定”; 
user1.send(); 
可以向消息中添加额外信息 
如:var content:AsyncMessage=new AsyncMessage(); 
content.headers = new Array(); 
content.headers[“user”]=”张三”; 

 

消息发送错误处理: 
      对于producer组件,有两个事件可以触发发送错误 
      1.requestTimeout:用户可以设定从消息发出到收到确认消息的时间,超出,则表明消息发送可能发生错误 
      2.传输故障:在确认收到消息之前底层的消息通道发生故障,断开连接 
      在处理错误时,不同的错误,处理的方式不同,所以在处理错误时,首先要获取当前的错误消息,是通过ErrorMessgae.MESSAGE_DELIVERY_IN_DOUBT的ErrorMessage下的faultCode属性,该属性记录了当前发送的错误信息,用户可以根据错误,来决定忽略错误或者重新发送消息。

Consumer的创建: 
      它的创建和producer差不多,但不同的是,consumer必须要向接收点订阅,这样才能接受来自接收点的消息,通过subscribe()方法可以实现消息过滤:通过消息的头部信息,对接收的消息进行选择,过滤掉不符合条件的消息,消息过滤使用的是consumer组件的selector属性,又称为消息选择器,如:selector=”age>18”;使用Subtopic:是用来对Priducer组件向接收点发送信息进行分类,在consumer组件中可以设置Subtopic,使得它能从订阅的接收点特定subtopic或者Subtopic集合的消息。使用通配符*可以发送或接收多个Subtopic消息 



3.配置消息服务 

 

 

 

 

      消息服务配置主要完成的任务是定义消息接收点,对消息接收点使用安全策略,修改日志设置,,消息服务的配置是在flex服务文件中(默认是services-config.xml)的消息服务部分进行,,,,,,,,,以下是相关概念: 

 

 

1.消息服务接收点 
      它是producer和cosumer组件连接服务端处理程序。。 
2.消息通道 
      它是消息传输的路径,,,,,通常使用最普遍的两个通道时RTMP通道和AMF通道,第一个是客户和服务器之间保证着一条连接,因此不需要轮询服务器,,,而AMF通道当有新的消息到来时需要轮询服务器 
3.消息服务适配器  
      它是用在与其他系统交互时,提供消息传递功能的服务器处理程序,在接收点的定义中有对适配器的引用,用户也可以指定特定的适配器 
4.安全 
      指的是接收点的安全,安全保证是通过secutity constraint实现的,它定义了接收点的访问权利,,,secutity constraint在用户访问接收点之前,对用户进行授权和验证 



a, .设置网络属性:

      用来定义client-server之间消息通信的行为---在<destination>下的<properties>下的<network>标签 。session-timeout:设定一个订阅者从订阅到退订之前空闲的时间,以分钟计,如果该值等于0,则订阅者不会自动转为退订;throttle-inbound:max-frequency属性控制每秒服务器最大接收消息的条数,policy属性指示了消息限制达到后的处理,如果为error表示将返回一个错误,IGNORE则不返回错误直接忽略;throttle-outbound:max-frequency属性控制每秒服务器最大接收消息的条数,,policy属性指示了消息限制达到后的处理,如果为error表示将返回一个错误,IGNORE则不返回错误直接忽略,REPLACE表示当达到最大数时以前的消息将会被替换。
b.设置服务器属性:

      指的是接收点中包含的一系列属性用于控制服务器相关的参数,在  <destination>下的<properties>下的<server>标签 。max-cache-size:存储缓存中保存消息的最大条数 ;message-time-to-live:消息在服务器上保存的时间,为0表示将永久保存 ;durable:这个是个布尔值,表示消息是否转为持久存储,以防止连接中断,保证消息到达接收点订阅者。当使用JMS适配器时,它会继承该值durable-store-manager:当flex客户端不使用JMS适配器时会用到这个类,默认情况下包含在Flex Data Services中的flex.messaging.durabilitu.FileStoreManager类,会将消息存储在flex应用中的WEB-INF/flex/message_store/DESTINATION_NAME文件中,,用户也可以通过设置file-store-root属性值来改变存储位置 
      batch-write-size:每一批写入的持久消息的数量 
      file-store-root:持久消息文件的存放位置 
      max-file-size:最大的持久消息的大小,单位kb 
c.引用消息通道:

      消息通过消息通道来回进行传输………在<destination>下的<channels>下的<channel>中的ref属性,,可以定义多个消息通道的引用。
d.引用消息适配器:

      在flex数据应用中使用Flex Data Service中包含的ActionScript,JMS或者ColdFusion Event Gateway适配器,在<destination>下的<adapter>的ref属性 

 

http://zhanshenlvbu.iteye.com/blog/1540502

 

http://keren.iteye.com/blog/560896

 

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值