基基于SOA应用JMX和JMS技术的RFID中间件设计

发布者:cxx7848653最新更新时间:2010-06-11 来源: 电子技术应用关键字:RFID  JMS  JMX  中间件 手机看文章 扫描二维码
随时随地手机看文章

    无线射频识别RFID(Radio Frequency Identification)技术近年来得到了快速的发展,目前已进入商业化应用阶段。

  企业实施RFID方案的最终目的是将RFID产生的海量信息为业务所用。这就需要解决企业现有的业务系统如何与RFID系统接口的问题,包括连接RFID设备、处理RFID数据、将其转换成业务信息等。为了避免因标签种类变化、系统业务逻辑改变而需要重新编写业务信息的情况,需要将RFID硬件模块的连接控制、中间数据处理与上层应用软件分开,因此引入了RFID中间件的概念。

    此外,利用SOA系统具有可扩展性高、可维护性好的特点,以便为用户提供灵活的维护服务,还引入了面向服务体系架构SOA(Service Oriented Architecutures)。

  基于上述分析,本文提出了一种基于SOA的RFID中间件方案。该方案可把各个应用RFID技术的功能抽象成服务,应用基于J2EE构建方法,综合应用JMX、JMS、Struts等技术。企业应用系统通过请求服务的方式来获取RFID中间件提供的服务。用XML进行数据传输,并提供Web Service接口。

1 技术基础

1.1 RFID中间件

  RFID中间件是实现RFID硬件设备与应用系统之间数据传输、过滤、数据格式转换的一种中间程序,将RFID阅读器读取的各种数据信息,经过中间件提取、解密、过滤、格式转换、导入企业的管理信息系统,并通过应用系统反映在程序界面上,供操作者浏览、选择、修改、查询。中间件技术也降低了应用开发的难度,使开发者不需要直接面对底层架构,而是通过中间件进行调用。

  RFID中间件是一种消息导向的软件中间件,信息是以消息的形式从一个程序模块传递到另一个或多个程序模块。消息可以非同步的方式传送,所以传送者不必等待回应。RFID中间件是在企业应用原有的中间件发展的基础上,结合自身应用特性进一步扩展并深化了中间件的应用,使得RFID应用系统的开发变得更容易,提高了软件的可移植性,增强了系统的可维护性和可靠性,所以它的架构设计解决方案是RFID应用的一项极为重要的核心技术[1]。

  目前提供RFID中间件平台的厂商主要有IBM、Oracle、Microsoft、SAP、Sun公司。对于这些厂商,RFID中间件只是其现有软件的扩展,其RFID产品可以迅速方便地与各自现有的软件产品线集成在一起。但缺点是其产品对该厂商其他软件产品的依赖性比较大。

1.2 面向服务的体系结构SOA

  面向服务的体系结构是一种技术架构风格,它代表了一种开放的、敏捷的、可扩展的、可组合的架构[2],定义了服务提供者和消费者之间的松散耦合关系。其业务敏捷的特点,帮助企业把业务变得更加灵活,能够适时、快速地响应变化。SOA的核心概念就是服务[3],其基本结构如图1所示。其中包含服务的3个基本角色:服务提供者、服务请求者和服务注册。在这些角色之间使用了3种操作:服务发布、服务发现和服务绑定。作为SOA的一种实现技术,Web Services提供了基于XML的标准接口,具有完好的封装性、松散的耦合性、协议规范的标准性以及高度的可集成性等特点,能够良好地满足SOA应用模式的需求。

1.3 JMX和JMS

  Java管理扩展JMX(Java Management Extensions)是一个为应用程序、设备、系统等植入管理功能的框架。在JMX规范中,管理组件是一个能代表管理资源的Java对象,遵从一定的设计模式,实现该规范定义的特定的接口。该定义保证了所有的管理组件以一种标准的方式来表示被管理资源。管理接口就是被管理资源暴露出的一些信息,通过对这些信息的修改能够控制被管理资源。管理接口包括:能被接触的属性值、能够执行的操作、能发出的通知事件等[4]。

  JMS(Java Message Service)是访问企业消息系统的标准API,定义了Java中访问消息中间件的接口,但JMS只是接口,并没有给予实现,实现JMS接口的消息中间件称为JMS提供者(JMS Provider)。在JMS框架中运转的方法如下:

    (1)得到1个JNDI初始化上下文(Context)。
    (2)根据上下文以查找1个连接工厂。
    (3)从连接工厂得到1个连接(Connect)。
    (4)通过连接以建立1个会话(Session)。
    (5)查找目的地(Topic/Queue)。
    (6)根据会话以及目的地以建立消息制造者(TopicPub
lisher/QueueSender)和消费者(TopicSubscrib-er/QueueReceiver)。

2 基于SOA的RFID中间件架构

  利用SOA松耦合、面向业务的特点,结合RFID中间件实现的应用系统集成的方案可提供丰富的接口,能够帮助实现对RFID设备的管理以及对数据的处理,简化了对底层设备应用的支持,避免了对底层设备的低级别接口的处理。利用Web Service技术实现RFID中间件与企业系统的集成,完成两者的松耦合集成。

  基于SOA的RFID中间件架构,其基础架构层分为设备管理层、事件处理层和服务接口层,并通过Web Service技术包装了每1层相应的功能,且进行了具体实现。本文重点介绍该RFID中间件架构中的基础架构的3个功能层[5]。这3个层次有着明确的功能划分和层间的交互接口。RFID中间件架构如图2所示。

    中间件设计包括RFID设备管理组件和事件过程管理组件。RFID设备管理组件是分布式的代理,负责第1级的事件过滤;设备管理包括设备询问器,对每1个阅读器和传感器设备,代理必须互相作用。过程管理组件是通过RFID事件下一级的过滤,把事件放置到交易环境中,然后发布应用层事件ALE(Application Layer Event)[5]。

2.1设备管理层

  设备管理层位于架构的最底层,直接与阅读器交互,实现的主要功能包括:

  (1)采集射频卡上的数据。
  (2)对于来自不同类型的阅读器的数据进行适配处理,得到统一的、格式化的数据,并进行数据校验。
  (3)将校验无误的数据按照用户定义的协议进行封包,并将消息包发送到事件处理层的消息系统。

  依据其实现的功能,分别针对射频卡阅读器模块、阅读器接口、数据校验和数据打包4个方面进行研究和开发。阅读器模块是根据硬件供应商提供的规范进行编码实现的;阅读器接口主要解决将来自协议格式的数据转化为系统所需要的EPC码;数据校验采用CRC校验;数据打包先依据获取的卡片编码中“数据分类”内容,判断出该标签数据属于哪种类型,然后按照这种数据类型将标签数据封装成相应的消息包。

  由于每个ALE阅读器事件流可能来自多个物理设备配置表,因此设备管理器为每个设备表创建1个询问器,并通知询问器哪种传感器被绑定到指定的阅读器上。询问器发送传感器事件流到设备管理器,设备管理器将1个或多个传感器事件流构造成阅读器事件。设备管理器把初步处理的阅读器事件发送到ALE服务器。

  询问器代理:1个设备管理器的配置由它管理的设备和它要咨询的询问器组成,然后与它所对应的设备管理器交互。每个设备概要表由物理设备属性和询问器配置组成。物理设备属性是被命名过的传感器(例如天线和1个金属传感器)。

  事件信息空间:事件信息空间类似于公共的容错事件信息经纪人。它支持异步接收来自设备管理器的事件、ALE事件以及其他来自事件过程管理的配置需求。事件信息空间同时提供一个存储转发机制,确保重要的事件在中断的网络或其他组件失效的情况下不丢失[5]。

  在系统中,将每个阅读器模块的远程方法调用封装为1个管理组件(MBean)作为JMX服务器的实例注册到JMX服务器中。通过JMX框架对阅读器进行监控和管理,使RFID中间件系统能提供管理、监控阅读器的功能。本部分描述为阅读器管理组件添加时间服务,以达到定时控制阅读器的目的。

2.2 事件处理层

  在RFID系统中,一方面是各种应用程序以不同的方式频繁地从RFID系统中取得数据;另一方面却是有限的网络带宽,其存在的矛盾,使其有必要设计1套消息传递系统,使设备管理层产生的事件能够传递到消息系统中,由事件管理过程进行处理,然后把数据传递到相关的应用系统。在这种模式下,阅读器不必关心哪个应用系统需要什么数据。同时,应用程序也不需要维护与各个阅读器之间的网络通道,仅需要将需求发送到消息系统中即可。由此,设计出的消息系统应具有如下功能:(1)数据缓存功能;(2)基于内容的路由功能;(3)数据分类存储功能[6]。

  下面将描述创建一个MBean来实现一个数据处理节点。消息组件可以按照MBean来部署。消息处理组件执行功能:从源队列中获取消息,对消息执行处理,然后将结果消息放置到目标队列。消息处理UML图如图3所示。

  JBossMQ是通过xml文件jbossmq-destinations-service.xml进行配置的。以下是获得JBOSS JNDI初始化上下文(Context)的代码:

  Hashtable props=newHashtable();
  props.put(Context.INITIAL CONTEXT FACTORY,"org.jnp.interfaces.NamingContextFactory");
  props.put (Context. PROVIDER URL, ip +":1099");
  props.put("java.naming.rmi.security.manager","yes");
  props.put(Context.URL PKG PREFIXES,"org. jboss.naming");
  Context context=new InitialContext(props);

  来自消息系统的消息以临时XML文件的形式和磁盘文件方式保存,供数据接口使用。消息系统完成消息缓存、分类整合、路由转发、临时存放等操作[4]。

  事件过程管理EPM(Event Process Managment)由ALE服务、配置管理、复杂事件过程以及交易规则执行组成,对EVP的访问能通过HTTP、JMS以及网络服务接口实现。

  EPM登记/订阅其感兴趣的事件,当在信息空间中有事件发生时,即会通知EPM,一旦接收到这些事件,随后会应用复杂事件处理(过滤器),结合交易规则对这些事件进行处理。另一种情况下是:外部的客户端(如EPC-IS)已经注册接收ALE,这些过滤后的事件会被发送到ALE客户端指定的位置。

2.3 服务接口层

  来自事件处理层的数据最终是分类的XML文件。同一类型的数据以XML文件的形式保存,并提供给相应的1个或多个应用程序使用。而服务接口层主要是对这些数据进行过滤、入库操作,并提供访问相应数据库的服务接口。具体操作如下:

  (1)将存放在磁盘上的XML文件进行批量入库操作,当XML数据量达到一定数量时,启动数据入库功能模块,将XML数据移植到各种数据库中。
  (2)在数据移植前将重复的数据过滤掉。
  (3)为企业内部和企业外部访问数据库提供Web Services
接口。

    其中,数据过滤过程是在处理临时存放的XML文件的过程中完成的。方法是:将同一个卡号的多条记录按照读入的时间戳进行比较,若相邻记录的时间戳差值小于用户定义的阈值,则认为重复读取发生,剔出后1条记录。依次类推,剔出掉所有冗余数据。利用Web Services技术将对数据库的访问以服务的形式发布,供企业内部应用程序和企业合作伙伴调用[2]。以数据过滤为例,其核心代码如下:

for(int i=1;i    {span=EndTime.Subtract(StartTime);
  spantiIDe=sPan.Seconds;         //相邻记录的时间戳之差
          if(spantime<=0.002)
              {subtime[i]=i;}
                         //若相邻时间戳差值小于2 ms,
                          //标记第2条记录为冗余数据
              else subtime[i]=0;}
  for(int j=1;j      {if(subtime[j].ToString()!="0")
              {ds.Tables[0].Rows[j].Delete();j=j-1;
              rowcount=rowcount11;}
  }
  以下是服务接口层向应用系统发送SOAP响应,返回处理结果的部分代码[7]。
  
  
  
  

Product Quantity Match Success
  

  success
  
  
  

3 RFID中间件的实现及测试

    RIFD中间件系统开发工具采用Eclipse3.2,应用服务器软件采用JBOSS4.0, Web容器为Tomcat5.5。此外,服务器端采用了基于Struts的MVC多层次结构框架,数据服务层则采用MySQL5.0数据库。

    实验中,终端通过485网络组网,应用系统使用的是仓库管理系统。仓库管理系统作为服务请求者,根据服务接口层公布的入库信息核对服务WSDL,得到该服务的接口定义和服务端侦听地址,由入库管理模块通过服务代理接口向Web服务发送SOAP请求消息,请求入库信息核对服务,Web服务平台收到该服务请求后,向RFID中间件发送消息,创建一个出库信息核对服务的实例,设备管理层根据服务请求参数,启动相应的RFID阅读器读取标签信息。然后将读取的标签信息经处理后打包传给事件处理层,根据服务请求的参数与捕获的标签信息进行核对处理,处理后向服务接口层返回核对数据正确或者错误的信息,如图4所示。最后,服务接口层向仓库管理系统发送SOAP响应,返回处理结果[5]。

    实验表明,原来的应用系统仅仅支持1种固定卡型的阅读器,采用RFID中间件以后,可以在1个系统中采用各种卡型的阅读器,而上层程序不需要再进行修改,增加了系统的可扩展性和易维护性,节约了时间和成本。系统稳定性也有大的提高,有效解决了企业应用中所关心的问题。

    本文提出了一个基于SOA,综合应用JMX、JMS等技术的RFID中间件架构,并说明了RFID中间件各部分的含义和作用及基础架构的实现。这种中间件结构能很好地屏蔽低端各种物理设备的信息。由于采取了模块化的结构,可以根据需要进行裁减,在需要的时候再加入相应的模块,例如,可根据需要是否添加认证和安全模块。通过Web Service,可实现对RFID中间件更高层次包装,保证了RFID基础架构中3个功能层之间的相互独立和协同工作。

关键字:RFID  JMS  JMX  中间件 引用地址:基基于SOA应用JMX和JMS技术的RFID中间件设计

上一篇:德州仪器发布1GHz Cortex-A8嵌入式处理器
下一篇:采用1GHz ARM Cortex-A8 的 Sitara微处理器单元

推荐阅读最新更新时间:2024-05-02 21:04

125KHz RFID读写器的FSK解调器设计
引言   很多工作在125KHz载波频率的RFID芯片,如Microchip公司的MCRF200、MCRF250以及Atmel公司的e5551、T5557等都可以将其调制方式设置为FSK方式。若芯片设置为FSK调制方式,那么读写器(PCD)必须具有FSK解调电路。FSK解调电路将FSK调制信号解调为NRZ码。   本文给出一种FSK解调电路,该电路的特点是电路简单可靠,很适宜PCD中应用。 FSK调制   工作在125KHz的RFID的FSK调制方式都很相似,图1给出了一种FSK调制方式的波形图。从图中可见,此时数据速率为:载波频率fc/40=125K/40=3125bps,在进行FSK调制后,数据0是
[网络通信]
无源高频RFID芯片的FPGA原型验证平台设计
射频识别即RFID技术又称电子标签、无线射频识别,是一种通信技术 .RFID技术作为物联网发展的关键技术,其应用必将随着物联网的发展而扩大。常用的RFID分低频、高频、超高频3种,其中高频RFID典型工作频率为13.56 MHz,一般以无源为主。高频标签比超高频标签具有价格便宜、节省能量、穿透非金属物体力强、工作频率不受无线电频率管制约束的优势,最适合应用于含水成分较高的物体中,例如水果等。 基于FPGA的原型验证方法凭借其速度快、易修改、真实性的特点,已经成为ASIC芯片设计中重要的验证方法 .本文主要描述高频RFID芯片的FPGA原型验证平台的设计,并给出验证结果。 1 RFID芯片的FPGA原型验证环境概述 一套完整的RFI
[电源管理]
无源高频<font color='red'>RFID</font>芯片的FPGA原型验证平台设计
基于RFID的智能纱布可有效防止术后残留
    恩智浦半导体NXP Semiconductors 近日宣布,ClearCount Medical Solutions选择恩智浦RFID解决方案以增强其SmartSponge系统。SmartSponge (智能纱布) 系统可以轻松而准确地检测并记录手术过程中残留在病人体内的纱布,从而实现“不留异物”,确保病人安全。     SmartSponge系统由以下部件构成:采用了RFID技术的手术纱布;基于方便使用的自动化软件记录系统的嵌入式RFID阅读器;用于检测意外残留在病人体内纱布的附属SmartWand (智能条形码阅读器);以及用于记录废弃纱布的智能处理系统。     ClearCount首席执行官David Pa
[网络通信]
中电信原总工称物联网复杂:RFID就有250个标准
  在近日出席一次会议时,中国电信原总工程师、现任科技委主任韦乐平表示,我国建设智慧城市的条件已经基本具备,但也面临各种挑战,其中之一就是技术挑战,包括全球物联网缺乏统一的标准体系,全球有几十个标准化组织出台了250个标准。   物联网缺乏统一的标准体系   目前,全国开始出现建设智慧城市的热潮。韦乐平表示,智慧城市应该是以电信网和物联网为基础,通过智能化的方式支持物与物、物与人之间的信息交互、智能化的应用,实现信息基础设施和物理基础设施的融合,最终形成信息化、智能化和人文化的现代文明城市,   他认为,我国建设智慧城市的条件已经基本具备,因为中国已拥有全球最大的固网、互联网、宽带介入网和移动网。比如说,我国每年要建设三个加
[网络通信]
RFID技术如何智慧楼宇安防?
无论是视频监控、楼宇对讲还是出入口控制等领域,“以技术谋取突破”成为了行业共识。在这之中,RFID技术就是安防企业不得不重视的一项技术。下面就随网络通信小编一起来了解一下相关内容吧。 无论是视频监控、楼宇对讲还是出入口控制等领域,产品同质化现象越来越给给企业敲醒了警钟,“以技术谋取突破”成为了行业共识。谁能占领“技术高地”就能抢占先机。在这之中,RFID技术就是安防企业不得不重视的一项技术。RFID所具有的可快速扫描、体积小型化、可重复使用、穿透性和无屏障阅读,数据记忆容量大、抗污染能力及耐久性强等环境适应能力优势令其能够快速的发展与普及。同样,RFID技术应用于智能楼宇领域也如鱼得水一般下面小编带大家来看下他们RFID技术如何
[网络通信]
RFID车辆智能管理系统以及解决方案
  一、系统概述   随着国民经济的迅速发展,城市汽车的拥有量不断增加,汽车在给人们带来交通快捷方便的同时,由于停车管理不善等问题也给人们带来了诸多不便,因此,近年来汽车的静态管理和动态平衡已成为许多有识之士重点研究的新问题。为满足人们生活和工作环境更科学、更规范的要求,管理高效、安全合理、快捷方便的停车场自动管理系统已成为许多大型综合性建筑物和居民小区必备的配套设施。地处繁华地带的许多高级公寓、大型娱乐场所、宾馆、办公楼、球场等停放汽车较多,车流量大,为了保证车辆安全和交通方便,迫切需要采用自动化程度高方便快捷的停车场自动管理系统,提高停车场管理水平。   在多年技术储备的基础上,研制开发了一套车辆智能管理解决方案,该方
[嵌入式]
看专家描绘RFID智能互连的生活场景
如果我们拥有透视眼,您将平均在每辆汽车上发现6颗印有“Melexis”Logo的ICs!当今,几乎全球范围内所有的汽车品牌都在依靠Melexis(迈来芯)的芯片来保证安全,高效和舒适地运送乘客和货物。不过,我们今天的主角——MLX90130/32——13.56MHz RFID/NFC收发器——除了能用在汽车上,他还会出现在我们生活的方方面面,如安防领域的门禁系统,医疗电子中用于监测葡萄糖,在手机上用于NFC近场通讯…… 迈来芯不仅仅在汽车行业,更在许多其他领域赢得商机。射频和射频识别元件的技术开发,帮助迈来芯的客户准时实现既经济又有持续利润的产品开发目标。早在 2000 年,迈来芯就已推出各类传感器标签。2007年,迈来
[物联网]
看专家描绘<font color='red'>RFID</font>智能互连的生活场景
智能照明设计:利用RFID技术的LED路灯智能控制系统
本文应用射频识别( Radio FrequencyIdentification ,RFID) 技术,结合设置在路面的读写装置、安装在车辆上的射频标签,设计了一种LED 路灯自动控制系统,实现对LED 路灯的智能开关,既能够节约能源又可以有效减轻工作人员管理路灯系统的工作负担。   与使用传统光源( 如高压钠灯、金卤灯) 的路灯相比,LED 路灯具有无需预热、耐频繁开关、寿命长、抗震性好、光色好、无污染、适应的环境范围广及节能的优势,因此,国内已有多个城市建成了LED路灯示范道路。但是,我国大多数城市特别是中小城市的路灯管理系统均采用钟控、光控或较简单的自动控制系统,在这种粗放的管理方式中,存在路面长时间无车 而路灯仍处于开启状
[电源管理]
智能照明设计:利用<font color='red'>RFID</font>技术的LED路灯智能控制系统
小广播
最新嵌入式文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved