文档章节

ActiveMQ学习之通讯协议

冥焱
 冥焱
发布于 01/23 22:55
字数 842
阅读 185
收藏 0

一、支持的通讯协议

            ActiveMQ支持的client-broker通讯协议有:TCP、NIO、UDP、SSL、HTTP(S)、VM

            其中配置Transport  Connector的文件在ActiveMQ安装目录的conf/activemq.xml中的<TransportConnectors>标签内

            上图中给出的配置信息中

            url描述信息的头部都是采用协议名称:例如上图给出的

            描述amqp协议的监听端口时,采用的url描述格式为“amqp://........”

            描述stomp协议的监听端口时,采用的url描述格式为“stomp://........”

            唯独在进行openwire协议进行描述时,url头部采用的是"tcp://........"这是因为activeMQ中默认的消息协议就是openwire

二、Transmission  Control Protocol(TCP)

            1、这是默认的broker配置,TCP的Client监听的端口为61616

            2、在网络传输协议之前,必须要序列化数据,消息是通过一个叫wire protocol的来序列化成字节流,

                  默认情况下 ActiveMQ默认把wire protocol叫做openwire,目的是促使网络上的效率和数据进行快速交互

            3、TCP连接的url形式如下:“tcp://hostname:port?key=value&key=value”后面的参数是可选的

            4、TCP传输的优点:

                  4.1、TCP协议可靠性高,稳定性强

                  4.2、高效性:字节流方式传输,效率很高

                  4.3、有效性、可用性:应用广泛,支持任何平台

三、NEW I/O API Protocol(NIO)

            1、NIO协议和TCP协议类似但是NIO更侧重于底层访问操作。它允许开发人员对统一资源可有更多的client调用和服务端有更多的负载

            2、适合NIO的应用场景:

                2.1、可能有大量的Client去连接到Broker上,一般情况下,大量的client去连接Broker是被操作系统的线程所限制。因此,NIO的实现

                        比TCP需要更少的线程去运行,所以建议使用NIO协议

                2.2、可能对于Broker有一个很迟钝的网络传输,NIO比TCP提供更好的性能。

            3、NIO连接URI形式“nio://hostname:port?key=value&key=value”

            4、配置方式

                将下面这个配置到ActiveMQ安装目录的conf/activemq.xml中的<TransportConnectors>标签内                

<transportConnector name="openwire" uri="nio://0.0.0.0:61618?trace=true"/>

四、Advanced Message Queuing Protocol(amqp协议)

            amqp协议是一个提供统一消息服务的应用层标准高级消息队列协议,是应用层的协议的一个开放标准,为面向消息的中间件设计,基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同开发语言等条件限制。

五、Streaming Text Orientated  Message Protocol(stomp协议)

            流文本定向协议 ,是一种为MOM(Message Oriented Middleware ),面向消息中间件设计的的简单文本协议

六、Message Queuing  Telemetry Transport(MQTT协议)

            是IBM开发的即时通讯协议,有可能成为物联网的重要组成部分,该协议支持所有的平台,几乎可以把所有的联网物品和外部连接起来,被用来当做传感器和致动器(比如通过Twitter让房屋联网)的通讯协议

 

© 著作权归作者所有

冥焱
粉丝 19
博文 131
码字总数 104348
作品 0
运城
私信 提问
加载中

评论(0)

ActiveMQ-CPP v3.8.3 发布,C++ 的消息服务

ActiveMQ-CPP v3.8.3 发布了,该版本主要是 bug 修复,包括 ConnectionAudit 类的一些线程问题;增强了 SSL 代码允许在包含多个 CN 值的证书中查找域名。详细介绍请看 ChangeLog。 CMS (全称...

红薯
2014/07/19
2.3K
0
跟我学习dubbo-ActiveMQ的安装-单节点与使用(9)

ActiveMQ 的安装与使用(单节点) 1、 安装 JDK 并配置环境变量 JAVA_HOME=/usr/local/java/jdk1.7.0_72 2、 下载 Linux 版的 ActiveMQ(当前最新版 apache-activemq-5.11.1-bin.tar.gz) $ ...

HI曲奇饼干
2016/01/19
238
0
[中间件] 消息处理利器 ActiveMQ 的介绍 & Stomp 协议的使用

随着互联网企业业务量的不断扩大,企业信息网络系统的愈加复杂,性能问题也就越来越凸显出来,串行的业务处理方式显然已经成为主要的瓶颈,我们需要更多异步的并行处理来提高企业信息系统的业...

长平狐
2012/11/19
1.8K
0
Linux 安装ActiveMQ(使用Mac远程访问)

阅读本文需要安装JDK 一 ActiveMQ简介 activemq是用java语言编写的一款开源消息总线 activemq是apache出品 activemq消息的传递有两种类型 一种是点对点(即一个生产者和一个消费者一一对应) 另...

梦三
2018/07/15
0
0
JMS配置说明-----activeMQ-5.6

1 简介 activeMQ是一个完全支持JMS1.1 和J2EE规范的JMS Provider实现; 尽管规范出台已经是很久的事情了,但JMS在当今的J2EE应用中仍然扮演着特殊的地位; 特性列表 多种语言和协议编写客户端...

次渠龙哥
2018/06/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Minecraft Fabric Client 教程 #5 添加Event、Sprint和ToggleCommand

首发于Enaium的个人博客 添加Event 下载 放在cn.enaium.excel里 然后在Excel.java里面添加EventManager public enum Excel { [...] public EventManager eventManager; pu......

Enaium
25分钟前
65
0
记 S3Service 代码中的一个低级错误

osgl-storage 是 osgl 工具箱 中用于简化存储的. 其特点是接口简单, 支持多种存储引擎插件, 包括本地文件系统, AWS S3, Azure Blob, 七牛 Kodo 服务. 最近老码农在一次调试中偶然发现了 osgl...

开源老码农
27分钟前
513
2
如何实现Samba文件共享服务

目标:实现Samba文件共享服务 试验环境:两台主机服务端:192.168.56.11客户端:192.168.56.12 配置用户认证共享 服务端操作: 1.关闭防火墙,关闭selunix [root@hejie ~]# setenforce 0[...

linuxprobe2020
29分钟前
44
0
SQL Server Profiler - 如何过滤跟踪以仅显示来自一个数据库的事件?

如何将SQL Server Profiler跟踪限制为特定数据库? 我看不到如何过滤跟踪,看不到我连接的实例上的所有数据库的事件。 #1楼 在Trace properties> Events Selection选项卡下>选择show all co...

技术盛宴
29分钟前
59
0
Kafka配置及常用命令笔记

一、kafka配置 1. 服务端 server.properties #broker 的全局唯一编号,不能重复broker.id=0#删除 topic 功能使能delete.topic.enable=true#处理网络请求的线程数量num.network.thr...

liddblog
33分钟前
41
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部