这节介绍MQ的连接配置
在MQ目录/conf/activemq-demo.xml中可看到如下配置
<transportConnectors>
<transportConnector name="openwire" uri="tcp://localhost:61616"
discoveryUri="multicast://default"/>
<transportConnector name="ssl" uri="ssl://localhost:61617"/>
<transportConnector name="stomp" uri="stomp://localhost:61613"/>
<transportConnector name="xmpp" uri="xmpp://localhost:61222"/>
</transportConnectors>
可以看到在MQ中可配置个连接,并且还可以配置多种协议的连接。
MQ中支持的网络协议有TCP、NIO、UDP、SSL、HTTP(S)、VM等。
下面对其中常用的几种进行一下说明。
TCP:
MQ默认使用的协议,开放性、高效性、可靠性是其主要特点,这个协议可满足一般应用的大部分需求,因此在项目中还是比较常用的。第一节中的例子用到的就是TCP协议。
NIO:
NIO的概念是在JAVASE1.4首先提出来的,这是一种新的JAVA IO模型,是对底层IO的一种封装,让程序员们可以更方便的对IO进行操作。
这种协议下,网络消息的传播效率非常的高。因此,当系统存在高用户量、高并发或网络堵塞时,可考虑用此协议。
配置示例如下:
<transportConnector name="nio" uri="nio:localhost:61618" />
SSL:
安全套接层协议,这种协议比较重要,因此本教程将对SSL协议连接方式作重点介绍。
在MQ目录/conf/activemq.xml文件中修改以下配置
<sslContext>
<sslContext keyStore="file:${activemq.base}/conf/broker.ks" keyStorePassword="password"/>
</sslContext>
<transportConnectors>
<transportConnector name="ssl" uri="ssl://localhost:61617"/>
</transportConnectors>
broker.ks是MQ的默认证书,默认密码为password
启动activemq.bat
可发现MQ已经以SSL方式启动,端口为61617
将第一节中Consumer.java与Publisher.java的以下代码
protected static String brokerURL = "tcp://localhost:61616";
修改为
protected static String brokerURL = "ssl://localhost:61617";
在Consumer.java和Publisher的VM arguments 里输入
-Djavax.net.ssl.keyStore=MQ目录\conf\client.ks
-Djavax.net.ssl.keyStorePassword=password
-Djavax.net.ssl.trustStore=MQ目录\conf\client.ts
设置Consumer.java和Publisher的Program arguments为 ORCL
启动Consumer.java和Publisher,将看到和第一节示例一样的结果,只不过这里的连接协议改为了SSL。
由于本例中用到的证书是MQ自带的,正式环境中不可能用默认证书,否则SSL将形同虚设。因此,我们必须生成自己的证书,以保证其安全性。
在命令行中输入
keytool -genkey -alias broker -keyalg RSA -keystore mybroker.ks
按提示输入密码(本例子的密码为test123)和其它信息,可以看到在当前目录下生成了一个mybroker.ks文件,接着在命令行输入keytool -export -alias broker -keystore mybroker.ks -file mybroker_cert,输入刚才的密码test123,生成mybroker_cert。
接成生成客户端keystore,输入keytool -genkey -alias client -keyalg RSA -keystore myclient.ks,输入客户端密码和其它信息,生成myclient.ks,接着输入keytool -import -alias broker -keystore myclient.ts -file mybroker_cert,生成myclient.ts。
证书生成的工作就完成了。
接着把刚刚生成的证书复制到MQ目录\conf下,将activemq.xml的sslContext节点修改为
<sslContext>
<sslContext keyStore="file:${activemq.base}/conf/mybroker.ks" keyStorePassword="test123"/>
</sslContext>
重启MQ,修改Consumer.java和Publisher.java和VM参数为
-Djavax.net.ssl.keyStore=MQ目录\conf\myclient.ks
-Djavax.net.ssl.keyStorePassword=test123
-Djavax.net.ssl.trustStore=MQ目录\conf\myclient.ts
启动Consumer.java和Publisher.java
到此,我们把我们自己生成的证书用到了SSL协议上。
其它诸如HTTP(S)/UDP(不可靠性)/VM(用于虚拟机内应用程序间的通信)等协议,在实际中用的并不多,本教程就不介绍了。
- 大小: 9.7 KB
- 大小: 45.9 KB
分享到:
相关推荐
总结,本篇文章介绍了如何在 SpringBoot 项目中集成 ActiveMQ,通过引入依赖、配置连接参数、创建消息生产者和消费者,实现了基于 JMS 的消息传递功能。同时,我们还探讨了 ActiveMQ 和 Spring JMS 的核心概念以及...
2. **配置ActiveMQ**:在ActiveMQ的配置文件(通常是`conf/activemq.xml`)中,你需要设置`transportConnectors`元素以启用SSL。你需要指定SSL端口,并将服务器的证书和私钥加载到Keystore中,同时设置Truststore以...
在本篇《ActiveMQ实战——实现一个简易版的聊天室》中,我们将深入探讨如何利用Apache ActiveMQ构建一个简单的在线聊天应用。ActiveMQ是Apache软件基金会的一个开源项目,它是一款功能强大的消息中间件,用于在...
ActiveMQ 集群——JDBC Master Slave + Broker Cluster ActiveMQ 集群是指将多个 ActiveMQ 服务器组合在一起,以提高系统的可扩展性和可靠性。在这个集群中,我们可以使用 JDBC Master Slave 模式和 Broker Cluster...
ActiveMQ是一种广泛使用的企业级消息中间件,它遵循JMS(Java ...对于希望深入学习ActiveMQ的开发者来说,理解其安装、配置以及与不同系统的集成方式是十分必要的,这将有助于他们构建更加健壮和可扩展的应用程序。
4. **网络连接**:ActiveMQ支持网络集群,通过`<networkConnectors>`元素配置。这允许多台ActiveMQ服务器共享消息负载,提高可用性。 5. **安全性**:在`<plugins>`元素下可以配置安全策略,如用户、角色和权限。...
接着,配置ActiveMQ连接。在`application.properties`或`application.yml`文件中,配置ActiveMQ服务器的地址、端口等信息: ```properties spring.activemq.broker-url=tcp://localhost:61616 spring.activemq.user...
### 深入掌握JMS——ActiveMQ 十一章 #### JMS基本概念与重要知识点解析 **JMS(Java Message Service)简介** JMS(Java消息服务)是一种广泛应用于企业级应用中的消息中间件协议,它为应用程序提供了一种高效、...
**ActiveMQ学习笔记之一——ActiveMQ下载** ActiveMQ是Apache软件基金会开发的一个开源消息中间件,它是基于Java消息服务(JMS)规范的,用于在分布式系统中传递消息。作为一个高性能、可伸缩且可靠的解决方案,...
**JMS学习笔记(一)——JMS简介与ActiveMQ安装** Java消息服务(Java Message Service,简称JMS)是Java平台中用于企业级应用间异步通信的标准接口。它为应用程序提供了一种标准的方式,用来创建、发送、接收和读取...
读者将学习如何通过XML配置文件定制ActiveMQ的行为,以适应特定的应用场景和性能需求。此外,这部分还可能涉及JMX(Java Management Extensions)的使用,以监控和管理ActiveMQ实例。 “Using ActiveMQ”章节将展示...
标题中的"activemq-rar-5.0.0.rar"指的是Apache ActiveMQ的一个RAR(Resource Adapter Archive)版本,这是ActiveMQ的特定版本——5.0.0的资源适配器打包文件。RAR文件通常用于Java EE应用服务器,提供与企业服务的...
根据给定文件的信息,我们可以提炼出以下几个重要的知识点: ...综上所述,ActiveMQ 提供了一套完整的企业级消息传递解决方案,但在实际部署过程中还需要注意其特定的配置与优化技巧,以确保系统的稳定性和可靠性。
3. **消息模型**:ActiveMQ支持两种消息模型——点对点(Queue)和发布/订阅(Topic)。点对点模型适用于一对一通信,而发布/订阅模型适用于一对多广播式通信。 4. **协议支持**:ActiveMQ不仅支持JMS,还支持AMQP...
6. **网络连接**:配置网络连接器,使多个ActiveMQ Broker可以形成集群或实现故障转移。 7. **监控和管理**:通过JMX工具(如jconsole)或Web控制台(默认在`http://localhost:8161/admin`)监控和管理ActiveMQ实例...
在提供的“一头扎进JMS之ActiveMQ视频教程”中,你将学习如何配置和使用ActiveMQ,包括安装和启动服务、创建和管理消息队列、使用生产者和消费者发送与接收消息、理解不同消息模式的工作原理,以及如何利用ActiveMQ...
《ActiveMQ与Spring整合——深度解析5.5.0版本》 在Java消息服务(Java Message Service,简称JMS)领域,Apache ActiveMQ是广泛使用的开源消息代理和集成框架。它支持多种协议,如OpenWire、AMQP、STOMP、MQTT等,...
在本例中,我们有一个名为"activemq-5.15.4.zip"的压缩包,它包含了Apache ActiveMQ的一个特定版本——5.15.4。解压此文件后,你会得到一个名为"apache-activemq-5.15.4-bin.tar.gz"的文件,这是ActiveMQ的二进制...
6. **实战示例**:压缩包中的"ActiveMQ_Test2"可能是一个Java项目,包括了创建ActiveMQ连接,创建生产者和消费者,以及配置Quartz Job和Trigger的代码。 7. **学习资源**:除了压缩包中的代码,学习者还应该参考...
**三、ActiveMQ的配置与优化** 配置ActiveMQ涉及多个方面,如设置存储路径、调整内存大小、设置网络连接参数等。优化则包括选择合适的持久化策略、设置合理的消息保留时间、限制队列深度等,以确保ActiveMQ在实际...