Jms规范学习
1、什么是消息中间件?
关注于数据的发送和接受,利用高效可靠的异步消息传递机制集成分布式系统。
2、什么是JMS?
Java消息服务(java Message Service)即JMS,是一个java平台中关于面向消息中间件的API,用于在两个应用程序之间或者分布式系统中发送消息,进行异步通信。
3、什么是AMQP?
AMQP(即advanced message queuing protocol)是一个提供统一消息服务的应用层标准高级消息队列协议,基于此协议的客户端与消息中间件可以传递消息,并不受客户端/中间件不同产品,不同开发语言等条件的限制。
4、关于JMS与AMQP的对比如下所示:

5、JMS规范,JMS相关概念。
a、提供者,实现JMS规范的消息中间件服务器。
b、客户端,发送或者接受消息的应用程序。
c、生产者/发布者,创建并发送消息的客户端。
d、消费者/订阅者,接受并处理消息的客户端。
e、消息,应用程序之间传递的数据内容。
f、消息模式,在客户端之间传递消息的方式,JMS中定义了主题和队列两种模式。
6、JMS消息模式(队列模型,主题模型)。
1)、队列模型。
a、客户端包括生产者和消费者。
b、队列中的消息只能被一个消费者消费。
c、消费者可以随时消费队列中的消息。
队列模型的示意图(出自慕课网):

2)、主题模式。
a、客户端包括发布者和订阅者。
b、主题中的消息被所有订阅者消费。
c、消费者不能消费订阅之前就发送到主题中的消息。
主题模型的示意图(出自慕课网):
注意,先订阅,再消费哦!

7、JMS的编码接口:
JMS的编码接口
a、ConnectionFactory用于创建连接到消息中间件的连接工厂。
b、Connection代表了应用程序和消息服务器之间的通信链路。
c、Destination指消息发布和接受的地点,包括队列和主题。
d、Session表示了一个单线程的上下文,用于发送和接受消息。
e、MessageConsumer由会话创建,用于接受发送到目标的消息。
f、MessageProducer由会话创建,用于发送消息到目标。
g、Message是在消费者和生产者之间传送的对象,消息头,一组消息属性,一个消息体。
8、JMS编码接口之间的关系(出自慕课网)。
流程如下所示:
ConnectionFactory创建一个Connection连接,然后可以由Connection连接创建一个会话(或者创建多个会话,每个会话都是在一个线程上下文的,即session会话是单线程的,只在当前的上下文有效,所以会话可以做一些事务方面的处理,连接可以供多个线程使用的)。session会话可以创建MessageConsumer生产者,MessageProducer消费者。会话也可以用来创建一个Message消息的,然后MessageConsumer生产者将创建的消息发送到Destination目的地,MessageProducer消费者从指定的目的地接受到消息。
9、Spring与ActiveMq集成的操作(Spring与JMS集成的操作)。使用Spring集成jms连接ActiveMQ。
a、ConnectionFactory用于管理连接的连接工厂,此处是由Spring提供的。
一个Spring为我们提供的连接池ConnectionFactory,JmsTemplate每次发送消息都会重新创建连接,会话和producer,非常损耗性能。所以需要使用ConnectionFactory连接池。Spring提供了两种连接池,分别是SingleConnectionFactory(返回同一个ConnectionFactory)和CachingConnectionFactory(继承SingleConnectionFactory,新增了缓存功能)。
b、JmsTemplate用于发送和接受消息的模板类。
是Spring提供的,只需要向Spring容器中注册这个类就可以使用JmsTemplate方便的操作JMS。JmsTemplate类线程安全的,可以在整个应用范围内使用。
c、MessageListerner消息监听器。
实现一个onMessage方法,该方法只接受一个Message参数即可对消息进行处理了。
待续......
Jms规范学习的更多相关文章
- MQ学习(一)----JMS规范(转发整合)
最近进行ActiveMQ的学习,总结下已被不时之需. JMS规范: JMS即Java消息服务(Java Message Service)应用程序接口是一个Java平台中关于面向消息中间件(MOM)的A ...
- 消息中间件系列一:入门、JMS规范、ActiveMQ使用
一.入门 1. 消息中间件的定义 没有标准定义,一般认为,采用消息传送机制/消息队列 的中间件技术,进行数据交流,用在分布式系统的集成 2. 为什么要用消息中间件 解决分布式系统之间消息的传递.电商场 ...
- JAVA消息服务JMS规范及原理详解
JAVA消息服务JMS规范及原理详解 一.简介 JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应 ...
- JMS规范与Kafka
一.为什么需要消息队列 消息队列的核心作用就是三点:解耦一个系统中各个子模块的互相绑定与依赖,异步执行后台耗时逻辑,并行处理一个请求中涉及的多个操作. 以我们常见的下订单场景来说明,我们熟悉的淘宝,后 ...
- 实现JMS规范的ActiveMQ
ActiveMQ是Apache软件基金会的开源产品,支持AMQP协议.MQTT协议(和XMPP协议作用类似).Openwire协议和Stomp协议等多种消息协议.并且ActiveMQ完整支持JMS A ...
- JMS规范简介
一.JMS规范 Java消息服务定义: Java消息服务(Java Message Service)即JMS,是一个Java平台中面向消息中间件的API,用于在两个应用程序之间或分布式系统中发送/接受 ...
- JMS API学习总结(一)
三.JMS API简析 顶级接口 P2P Pub/sub 备注 ConnectionFactory QueueConnectionFactory TopicConnectionFactory 基于工厂 ...
- 公司C++规范学习
目录 公司C++规范学习 语法部分 风格/约定 公司C++规范学习 语法部分 class和struct关键字的选择:class表示被封装的用户自定义类型,不公开定义非静态数据成员,struct表示数据 ...
- ActiveMQ 笔记(三)JMS规范和落地产品、小知识Broker
个人博客网:https://wushaopei.github.io/ (你想要这里多有) 一.JMS规范概述 1.JavaEE 概述及主要核心规范 JavaEE是一套使用Java进行企业级应用开 ...
随机推荐
- 零零总总遇到过的CSS 样式
1:添加弹出框阴影 2:禁止文本域缩放 3:直接使用CSS 完成文本内容大小写(针对英文) 4: 文本框中的占位符 5:让table每列一样高 6:不使用js 让内容换行 word-break 7:曾 ...
- java基础(23):字节流、字符流
1. 字节流 在前面的学习过程中,我们一直都是在操作文件或者文件夹,并没有给文件中写任何数据.现在我们就要开始给文件中写数据,或者读取文件中的数据. 1.1 字节输出流OutputStream Out ...
- IP地址网段表示法
172.12.34.0/25 子网掩码:用于表示IP地址中的多少位用来做主机号.因为"其中值为1的比特留给网络号和子网号,为0的比特留给主机号"(TCP/IP V1). 172.1 ...
- XHR 对象实例所有的配置、属性、方法、回调和不可变值
当我们声明了一个XMLHttpRequest对象的实例的时候,使用for-in来循环遍历一下这个实例(本文使用的是chrome45版本浏览器),我们会发现在这个实例上绑定了一些内容,我把这些内容进行了 ...
- JavaScript 错误异常
JavaScript 错误异常 错误异常语句 try 语句测试代码块中的错误 catch 语句处理错误 throw 语句允许自定义错误 finally 语句在错误异常语句后,必须执行的代码块 try ...
- 1042. Flower Planting With No Adjacent
题意: 本题题意为: 寻找一个花园的涂色方案,要求 1.花园和花园之间,不能有路径连接的,不能涂成相同颜色的 一共有4中颜色,花园和花园之间,至多有三条路径 我菜了 - - ,又没做出来.. 看答案 ...
- iOS 唤起APP之URL Scheme
什么是URL Scheme 简单的说,由于苹果选择使用沙盒机制来保障用户的隐私和安全,APP只能访问自己沙盒数据,但同时也阻碍了应用间合理的信息共享.因此苹果提供了一个可以在APP之间跳转的方法:UR ...
- 究竟是什么毁了我的impl实现
Impl模式早就有过接触(本文特指通过指针完成impl),我晓得它具有以下优点: 减少头文件暴露出来的非必要内部类(提供静态库,动态库时尤其重要): 减小文件间的编译依存关系,大型代码库的编译时间就不 ...
- JavaScript—字符串(String)用法
字符串(String)去除空格 str = " hello python " // 去除左空格: str=str.replace( /^\s*/, ''); // 去除右空格: s ...
- nginx 安装 lua_nginx_module 模块(nginx——lua 学习笔记1)
插入两个网站: nginx + lua 的OpenResty 开发 跟我学OpenResty(Nginx+Lua)开发目录贴 两个都是 可以根据目录一步步学习的. 1. 版本下载 nginx版本为 n ...