JMS基本概念

■JMs是什么
          JMS Java Messag/ Servite,Java消息服务,是 Java EE中的一个技术
■JMs规范
         JMS定义a和访问消息中间件的接口,并没有给实现,实现]s接口的消息
中间件称为JMS Provider。例如ActiveMQ

JMS provider: 实现jms接口和规范的信息中间件

JMS message :jms的信息,jms信息有三部分组成
    1:消息头:每个消息头字段部有相应的getter和 serter:方法
    2:消息属性:如果需要除消息头字段以的值,那么以使用消息属性
    3:消息体:封装具体的消息数据
JMs producer:消息生产者,创速和发送M消息的客户端应用
JMS consumer:消息消费者,接收和处理W消息的客户端应用
      消息的消费可以采用以下两种方法之一:
             1:同步消费:通过调用消费者的 receive方法从目的地中显式提取消息, receive方法可
                以一直阻塞到消息到达。
             2:异步消费:客户可以为消费者注册一个消息监听器,以定义在信息到达时所采取动作

JMS domains:消息传递域,JMs规范中定义了两种消息传递域:点对点( point-to-
point,简写成PTP)消息传递域和发布/订阅消息传递域( publish/ subscribe,简写
成pub/sub)
1:点对点消息传递域的特点如下:
        (1)每个消息只能有一个消费者
        (2)消息的生产者和消费者之间没有时间上的相关性。无论消费者在生产者发送消
            息的时候是否处于运行状态,它都可以提取消息

2:发布/订阅消息传递域的特点如下
              (1)每个消息可以有多个消费者
              (2)生产者和消费者之间有时间上的相关性。订阅一个主题的消费者只能消费自它
              订阅之后发布的消息。JMs规范允许客户创建持久订阅,这在一定程度上放松了时
              上的相关性要求。持久订阅允许消费者消费它在未处于激活状态时发送的消息
3:在点对点消息传递域中,目的地被称为队列( queue);在发布/订阅消息传递域中,
目的地被称为主题( topic)

Connection factory:连接工厂,用来创建连接对象,以连接到JMS的 provider
JMS Connection:封装了客户与JMS提供者之间的一个虚拟的连接
JMS Session:是产和消费消息的一个单线程上下文
     会话用于创建消息生产者(preduce)、消息消费者( consumer)和消息
     ( message)等。会话提供了一个事务性的上下文,在这个上:下文中,一组发送
     和接收被组合到了一个原子操作中。
Destination:消息发送到的日的地
Acknowledge:签收
Transaction:事务
JMS client:用来收发消息的Java应用
       Non- JMS client:使用JM5 provider本地API写j的应用,用来替换 JMS API实现收
       发消息的功能,通常会提供其他的一些特寺性,比如: CORBA、RMI等。
        Administered objects:预定义的JM对象,通常在 provide规范中有定义,提
       供给JM客厂广「来访问,比如: ConnectionFactory和 dEstination

分布式-信息方式- JMS基本概念的更多相关文章

  1. 分布式-信息方式-JMS大纲

     一.简介 JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送消息, ...

  2. 分布式-信息方式-JMS Topic示例

                                                      Topic消息 非持久的 Topic消息示例对于非持久的 Topic消息的发送       基本跟前 ...

  3. 分布式-信息方式-JMS信息结构

    JMS的消息结构JMS消息由以下几部分组成:消息头,属性和消息体消息头包含消息的识别信息和路由信息,消息头包含一些标准的属性如下:1: JMSDestination:由send方法设置2: JMSDe ...

  4. 分布式-信息方式-JMS可靠性机制

                        JMS的可靠性机制1.消息接收确认        JMS消息只有在被确认之后,才认为已经被成功地消费了.消息的成功消费通常包含三个阶段:客户接收消息.客户处理消 ...

  5. 分布式-信息方式-JMS Queue示例

    代码 package test.mq.helloword; import javax.jms.Connection; import javax.jms.ConnectionFactory; impor ...

  6. 分布式-信息方式-ActiveMQ的Destination高级特性3

    虚拟destination用来创建逻辑destination,客户端可以通过它来生产和消费消息,它会把消息映射到物理destination. ActiveMQ支持2种方式: 1:虚拟主题(Virtua ...

  7. 分布式-信息方式-ActiveMQ的Destination高级特性1

    ActiveMQ的Destination高级特性 Destination高级特性----->Composite Destinations 组合队列Composite Destinations : ...

  8. 分布式-信息方式-ActiveMQ的集群

    ActiveMQ的集群Queue consumer clusters              ActiveMQ支持 Consumer对消息高可靠性的负载平衡消费,如果一个 Consumer死掉,该消 ...

  9. 分布式-信息方式-ActiveMQ静态网络连接的容错

    容错的链接Failover Protocol 前面讲述的都是client配置链接到指定的 broker上.但是,如果 Broker的链接失败怎么办呢?此时, Client有两个选项:要么立刻死掉,要么 ...

随机推荐

  1. Erasing Substrings CodeForces - 938F (字符串dp)

    大意: 给定字符串$s$, 长度为$n$, 取$k=\lfloor log2(n)\rfloor$, 第$i$次操作删除一个长度为$2^{i-1}$的子串, 求一种方案使得, $k$次操作后$s$的字 ...

  2. Linux 安装 python3.6 ,并且配置 Pycharm 远程连接开发

    Linux下安装Python3.6和第三方库   如果本机安装了python2,尽量不要管他,使用python3运行python脚本就好,因为可能有程序依赖目前的python2环境, 比如yum!!! ...

  3. Mysql学习(三)之数据库管理工具Navicat

    前言 mysql安装完后默认只有命令行工具,所以我们可以下载一些数据库管理工具Navicat Navicat使用 首先建立一个连接选择mysql,填写信息 发现多了一个localhost,双击,打开连 ...

  4. 面向对象-this关键字的内存图解

    /* 标准的代码改进版 this:哪个对象调用那个方法,this就代表那个对象 */ class Student { private String name; private int age; pub ...

  5. mysql中有条件的插入语句

    今天在参加笔试的过程中,看到一道题,大概意思就是说,当满足了条件就执行插入语句,当时就蒙了,之前从来都没有考虑过满足条件才插入的情况,所以一直都是这样写的 insert into table_name ...

  6. arcgisJs之底图切换插件

    arcgisJs之底图切换插件 底图切换插件在arcgis中有两种表现,如下: 1.两张底图切换 2.多张底图切换 一.两张地图切换 let basemapToggle = new BasemapTo ...

  7. WebSocket的兼容性

    https://github.com/sockjs/sockjs-client https://socket.io/ https://github.com/gimite/web-socket-js h ...

  8. arcgis 地图如何转到supermap平台

    场景:客户使用arcmap配置好的地图数据,由于项目需要转换到超图平台.有如下几种思路供参考. 1. 使用arcmap生成地图缓存,supermap-iServer支持发布arcgis的地图缓存以及t ...

  9. 手把手教你查看网站遭受到的Web应用攻击类型

    常见Web应用攻击类型有:webshell.SQL注入.文件包含.CC攻击.XSS跨站脚本攻击.敏感文件访问.远程命令.恶意扫描.代码执行.恶意采集.特殊攻击.其他攻击十二种攻击类型. 如何查看网站遭 ...

  10. deep_learning_Function_numpy_argmax()函数

    numpy里面的argmax函数 函数原型:def argmax(a, axis=None, out=None)a----输入arrayaxis----为0代表列方向,为1代表行方向out----结果 ...