我们扩大MDBs学前,我们需要理解message(新闻)与JMS(Java Message Service)的概念。

我们在Java EE中谈论消息,实际上就是意味着实现一个松耦合的过程。系统组件之间的异步通信。

在开发中,很多组件之间的调用都是同步的,像简单的方法调用、Java的RMI等。

而此处的异步调用差别于此。在非常多时候,使用异步消息可以提高用户体验。

拿CSDN的注冊功能来举例:用户点击注冊之后,这时client向server发送一个请求。server进行处理后。将注冊成功的提示消息返回给客户,同一时候,向用户的邮箱发送了一封邮件。是不是等邮件发送成功、用户收到邮件之后,再向用户显示注冊成功呢?

当然不会这样,由于用户体验将会非常差。

所以将结果直接返回给用户,将用户注冊的信息通过消息发送给后端程序慢慢处理。

消息

消息是JMS的核心概念,JMSclient和JMS服务提供者通过消息来进行通信。

企业消息不是一种新的概念。和消息相关的产品已经有多年的历史,比方IBM MQSeries,Microsoft的MSMQ,JBoss MQ 和 Apache的 ActiveMQ等。

企业消息系统使用松耦合的方式集成应用程序,在存储和转发的基础上支持应用程序间数据的异步传递;各种应用程序仅仅要和消息server(消息中间件,MOM)打交道就能够实现相互通信。

使用消息系统有一下长处:

1、平台无关性;

2、和网络位置无关。

3、在不同类型的网络环境下互操作性良好。

4、具有良好的扩展性和良好的伸缩性。

JMS

JMS(Java Message Service) 即Java消息服务。它提供标准的产生、发送、接收消息的接口。简化企业应用的开发。JMS是一种企业消息传送的API,并非MOM消息中间件系统的所有,JMS也是一种规范,类似于JDBC。我们通JMS API訪问 JMS的server。

大致由三部分组成:1、消息发送端;2、中间件server;3、消息接收端三个组件。

Java消息server是指。将数据通过消息作为载体在网络中从一个系统异步传送给还有一个系统。这种异步消息传送意味着:发送者不须要等待接收者接收或处理该消息;它能够自由地发送消息并持续进行处理。这样一个异步式的架构主要依赖于一台消息server(message server)。消息server,也称为消息路由器(message router)或代理(broker)。它负责从一个消息传送client向其它消息传送client传送消息。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbGl1NzY1MDIzMDUx/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

JMS支持两种消息通信模型。各自是著名的点到点(point-to-point)(P2P)模型和著名的公布/订阅(Pub/Sub)模型。

P2P与Pub/Sub的简单对照:

P2P 模型规定了一个消息仅仅能有一个接收者;

Pub/Sub 模型同意一个消息能够有多个接收者。

对于点到点模型。消息生产者产生一个消息后,把这个消息发送到一个Queue(队列)中。然后消息接收者再从这个Queue中读取,一旦这个消息被一个接收者读取之后。它就在这个Queue中消失了。所以一个消息仅仅能被一个接收者消费。

与点到点模型不同,公布/订阅模型中,消息生产者产生一个消息后,把这个消息发送到一个Topic中。这个Topic能够同一时候有多个接收者在监听,当一个消息到达这个Topic之后。全部消息接收者都会收到这个消息。

关于点到点模型与公布/订阅模型详细信息,我会安排介绍下一篇文章。

版权声明:本文博客原创文章,博客,未经同意,不得转载。

Ejb in action(七)——message与JMS的更多相关文章

  1. Simple guide to Java Message Service (JMS) using ActiveMQ

    JMS let’s you send messages containing for example a String, array of bytes or a serializable Java o ...

  2. Ejb in action(六)——拦截器

    Ejb拦截器可以监听程序中的一个或全部方法.与Struts2中拦截器同名,并且他们都可以实现切面式服务.同一时候也与Spring中的AOP技术类似. 不同的是struts2的拦截器的实现原理是一层一层 ...

  3. Ejb in action(两)——示例入门

    在前面的文章中,,我们推出Ejb相关概念.在此之前展开的阐述,我给大家Ejb示例.加深印象. 开发环境:eclipse 应用server:jboss 1.服务端程序 在Eclipse中创建一个Ejb项 ...

  4. Ejb in action(一)——开篇介绍

    从今天開始.我们共同来学习JavaEE中一个很重要的规范:Ejb. 既然您已经找到了这篇文章.就说明您至少已经对分布式开发有个大体上的概念了,之前没了解过也没关系,正好通过咱们的共同学习,一起来了解它 ...

  5. Ejb in action(四)——购物车实例演示有状态会话Bean

    前面.我们介绍了一个入门实例.事实上那就是无状态回话Bean的经常使用情况. 上一篇文章中.我们介绍了无状态会话Bean和有状态会话Bean的相关概念.为了加深大家对它们的理解,我们一起来实现一个有状 ...

  6. jms版本

    Java消息服务是一个在 Java标准化组织(JCP)内开发的标准(代号JSR 914). 2001年6月25日,Java消息服务发布JMS 1.0.2b,2002年3月18日Java消息服务发布 1 ...

  7. 深入浅出JMS(一)--JMS基本概念

     from:http://blog.csdn.net/jiuqiyuliang/article/details/46701559 深入浅出JMS(一)--JMS基本概念 标签: jmsmessagin ...

  8. JMS【一】--JMS基本概念

    摘要:The Java Message Service (JMS) API is a messaging standard that allows application components bas ...

  9. JMS基本概念

    原文:http://blog.csdn.net/jiuqiyuliang/article/details/46701559 The Java Message Service (JMS) API is ...

随机推荐

  1. C#使用xpath找到一个节点

    Xpath这是非常强大.但对比是一个更复杂的技术,希望上面去博客园特别想看看一些专业职位.下面是一些简单Xpath的语法和示例,给你参考 <?xml version="1.0" ...

  2. Cocos2d-x 3.2 Lua演示样本CocosDenshionTest(音频测试)

    Cocos2d-x 3.2 Lua演示样本CocosDenshionTest(音频测试)  本篇博客介绍Cocos2d-x 3.2中Lua演示样例的音频測试.Cocos2d-x使用SimpleAudi ...

  3. ActivatedEventArgs.IsApplicationInstancePreserved 属性

    ActivatedEventArgs IsApplicationInstancePreserved 如果 ApplicationInstancePreserved 为 true,则表示该应用程序已休眠 ...

  4. Kafka项目实践

    用户日志上报实时统计之编码实践 1.概述 本课程的视频教程地址:<Kafka实战项目之编码实践>  该课程我以用户实时上报日志案例为基础,带着大家去完成各个KPI的编码工作,实现生产模块. ...

  5. 浅析pinyin4j源码 简单利用pinyin4j对中文字符进行自然排序(转)

    pinyin4j项目  官网地址 http://pinyin4j.sourceforge.net/ 我们先把资源下载下来,连同源码和jar包一起放入工程.如下图: 接下来在demo包下,我们写一个测试 ...

  6. Web在线视频方案浅谈

    写在前面 最近因为项目预研,花时间和精力了解并总结了现如今web在线视频的一些解决方案,由于资历薄浅,措辞或是表述难免出现遗漏,还望各位海涵,有好的建议或方案还望赐教,定细心学习品位. 如今的web技 ...

  7. 选择一个利于SEO的空间

    大家好.今天蜗牛将给大家分享怎么选择一个利于SEO的站点空间. 一.什么是站点空间? 站点空间,是用来存你的站点的HTML,.图片.文件等的一个远程硬盘空间(就像你的电脑里面的空间一回事儿).依据不同 ...

  8. ASP.NET MVC:Razor 引入命名空间

    原文:ASP.NET MVC:Razor 引入命名空间 页面中引用 c# @using MvcApplication83.Models @using MvcApplication83.Common 行 ...

  9. 怎样改动、扩展并重写Magento代码

    作为一个开发人员的你,肯定要改动Magento代码去适应你的业务需求,可是在非常多时候我们不希望改动Magento的核心代码,这里有非常多原因, 比如将来还希望升级Magento.还想使用很多其它的M ...

  10. unity3d 学习笔记_____Native2d 刚体、冲击、联合使用

    Mass Mass of the rigidbody. Linear Drag Drag coefficient affecting positional movement. Angular Drag ...