过了个春节,回到公司的成小胖变成了成大胖。但是你们千万别以为他那个大肚子里面装的都是肥肉,里面的墨水也多了不少嘞,毕竟成小胖利用春节的半个月时间专心学习并研究了 ActiveMQ,嘿嘿……
这不,为了检验下自己的学习成果,上班的第一天成小胖就去找架构师老王交流 ActiveMQ 相关的知识,还顺便向老王讨了个红包,可把成小胖给高兴坏了。
“来,根据你的了解说下 ActiveMQ 是什么。”
“这个简单,ActiveMQ 是一个 MOM,具体来说是一个实现了 JMS 规范的系统间远程通信的消息代理。它……”
“等等,先解释下什么是 MOM。”
“好。MOM 就是面向消息中间件(Message-oriented middleware),是用于以分布式应用或系统中的异步、松耦合、可靠、可扩展和安全通信的一类软件。MOM 的总体思想是它作为消息发送器和消息接收器之间的消息中介,这种中介提供了一个全新水平的松耦合。”
“JMS呢?”
成小胖是个追求极致的人,为了解释得更通俗易懂,索性搬来一块白板边画边说。
“JMS 叫做 Java 消息服务(Java Message Service),是 Java 平台上有关面向 MOM 的技术规范,旨在通过提供标准的产生、发送、接收和处理消息的 API 简化企业应用的开发,类似于 JDBC 和关系型数据库通信方式的抽象。”
“嗯,很好。下面的这些概念你也需要特别理解下”:
Provider:纯 Java 语言编写的 JMS 接口实现(比如 ActiveMQ 就是)
Domains:消息传递方式,包括点对点(P2P)、发布/订阅(Pub/Sub)两种
Connection factory:客户端使用连接工厂来创建与 JMS provider 的连接
Destination:消息被寻址、发送以及接收的对象
“你来说说这其中 P2P 和 Pub/Sub 的区别吧”,老王给成小胖抛出了一个问题。
成小胖可不是吃素的,毕竟要是吃素的话他也吃不到这么胖……这些基本概念对他来说都是小事一桩:
P2P (点对点)消息域使用 queue 作