ActiveMQ测试实例
ActiveMQ的安装与启动
1 下载ActiveMQ:http://activemq.apache.org/download.html
2 下载后解压到任意文件夹,解压后文件夹内的目录为:
3 进入bin目录下的win64目录,运行activemq.bat程序,启动前需要设置jdk的环境变量,启动后如图所示:
在浏览器中输入http://localhost:8161/admin验证,需要输入用户名和密码登录,都为admin,登录后界面:
在conf目录下的jetty.xml中可以配置登录的用户名密码和端口号
<bean id="securityConstraint" class="org.eclipse.jetty.util.security.Constraint">
<property name="name" value="BASIC" />
<property name="roles" value="user,admin" />
<!-- set authenticate=false to disable login -->
<property name="authenticate" value="true" />
</bean>
设置authenticate为false时,登录不用输入用户名和密码;roles指的是登录的用户角色,这些角色在jetty-realm.properties文件中配置
<bean id="jettyPort" class="org.apache.activemq.web.WebConsolePort" init-method="start">
<!-- the default port number for the web console -->
<property name="host" value="0.0.0.0"/>
<property name="port" value="8161"/>
</bean>
port的值设置登录的端口号
ActiveMQ代码测试
1 新建一个java工程,结构如下:
2 消息发送者代码:
package com.cn.active; import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory; public class JMSProducer {
//默认连接用户名和默认连接密码,在conf文件夹下的credentials.properties文件中配置
private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;
private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;
//默认连接地址
private static final String BROKEURL = ActiveMQConnection.DEFAULT_BROKER_URL;
//连接工厂
static ConnectionFactory connectionFactory;
//连接
static Connection connection;
//会话 接受或者发送消息的线程
static Session session;
//消息的目的地
static Destination destination;
//消息生产者
static MessageProducer messageProducer;
//消息内容
static TextMessage textMessage; static {
//实例化连接工厂,仅在启动时加载
connectionFactory = new ActiveMQConnectionFactory(USERNAME,PASSWORD,BROKEURL);
} public static void main(String[] args){
try {
//通过连接工厂获取连接
connection = connectionFactory.createConnection();
//启动连接
connection.start();
/*
* 创建session
* 第一个参数指是否使用事务:
* 当消息发送者向消息提供者(即消息代理)发送消息时,消息发送者等待消息代理的确认,没有回应则抛出异常,消息发送者负责处理这个错误
* 第二个参数指参数的确认模式:
* AUTO_ACKNOWLEDGE:消息提供者每次收到消息时自动发送确认,消息只向目标发送一次,传输过程中可能因为错误丢失消息
* CLIENT_ACKNOWLEDGE:由消息接收者确认收到消息,通过调用消息的acknowledge()方法通知消息提供者收到了消息
* DUPS_OK_ACKNOWLEDGE:消息提供者在消息接收者没有确认发送时重新发送消息(这种模式不在乎接收者收到重复的消息)
*/
session = connection.createSession(true, Session.AUTO_ACKNOWLEDGE);
//创建一个名称为test的消息队列
destination = session.createQueue("test");
//创建消息生产者
messageProducer = session.createProducer(destination);
//发送消息
sendMessage(session,messageProducer);
session.commit();
connection.close();
} catch (JMSException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public static void sendMessage(Session session,MessageProducer messageProducer){
try {
for(int i=0;i<2;i++){
//创建一条文本消息
textMessage = session.createTextMessage("activeMQ"+i);
System.out.println("activeMQ"+i);
//通过消息生产者发出消息
messageProducer.send(textMessage);
}
} catch (JMSException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
运行后监视台显示一个test队列和二条消息:
3 消息接收者代码:
package com.cn.active; import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MessageConsumer;
import javax.jms.Session;
import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory; public class JMSConsumer {
//默认连接用户名和默认连接密码,在conf文件夹下的credentials.properties文件中配置
private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;
private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;
//默认连接地址
private static final String BROKEURL = ActiveMQConnection.DEFAULT_BROKER_URL;
//连接工厂
static ConnectionFactory connectionFactory;
//连接
static Connection connection;
//会话 接受或者发送消息的线程
static Session session;
//消息的目的地
static Destination destination;
//消息消费者
static MessageConsumer messageConsumer;
//消息内容
static TextMessage textMessage; static {
//实例化连接工厂,仅在启动时加载
connectionFactory = new ActiveMQConnectionFactory(USERNAME,PASSWORD,BROKEURL);
} public static void main(String[] args){
try {
//通过连接工厂获取连接
connection = connectionFactory.createConnection();
//启动连接
connection.start();
/*
* 创建session
* 第一个参数指是否使用事务:
* 当消息发送者向消息提供者(即消息代理)发送消息时,消息发送者等待消息代理的确认,没有回应则抛出异常,消息发送者负责处理这个错误
* 第二个参数指参数的确认模式:
* AUTO_ACKNOWLEDGE:消息提供者每次收到消息时自动发送确认,消息只向目标发送一次,传输过程中可能因为错误丢失消息
* CLIENT_ACKNOWLEDGE:由消息接收者确认收到消息,通过调用消息的acknowledge()方法通知消息提供者收到了消息
* DUPS_OK_ACKNOWLEDGE:消息提供者在消息接收者没有确认发送时重新发送消息(这种模式不在乎接收者收到重复的消息)
*/
session = connection.createSession(true, Session.AUTO_ACKNOWLEDGE);
//创建一个名称为test的消息队列
destination = session.createQueue("test");
//创建消息消费者
messageConsumer = session.createConsumer(destination); while(true){
//接收消息,参数表示接收消息的超时时间,为0表示不超时,receive返回下一个消息
//若超时了或者消费者被关闭了,返回null
textMessage = (TextMessage) messageConsumer.receive(1000);
if (textMessage != null) {
System.out.println("接收:"+textMessage.getText());
}else{
break;
}
}
connection.close();
} catch (JMSException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} }
运行后监视台变为:
ActiveMQ的特性和使用情况
ActiveMQ特性列表
1 多种语言和协议编写客户端。语言: Java, C, C++, C#, Ruby, Perl, Python, PHP。应用协议: OpenWire,Stomp REST,WS Notification,XMPP,AMQP
2 完全支持JMS1.1和J2EE 1.4规范 (持久化,XA消息,事务)
3 对Spring的支持,ActiveMQ可以很容易内嵌到使用Spring的系统里面去,而且也支持Spring2.0的特性
4 通过了常见J2EE服务器(如 Geronimo,JBoss 4, GlassFish,WebLogic)的测试,其中通过JCA 1.5 resource adaptors的配置,可以让ActiveMQ可以自动的部署到任何兼容J2EE 1.4 商业服务器上
5 支持多种传送协议:in-VM,TCP,SSL,NIO,UDP,JGroups,JXTA
6 支持通过JDBC和journal提供高速的消息持久化
7 从设计上保证了高性能的集群,客户端-服务器,点对点
8 支持Ajax
9 支持与Axis的整合
10 可以很容易得调用内嵌JMS provider,进行测试
什么情况下使用ActiveMQ?
1 多个项目之间集成
(1) 跨平台
(2) 多语言
(3) 多项目
2 降低系统间模块的耦合度,解耦
(1) 软件扩展性
3 系统前后端隔离
(1) 前后端隔离,屏蔽高安全区
ActiveMQ测试实例的更多相关文章
- ActiveMQ介绍和ActiveMQ入门实例
ActiveMQ百度百科 ActiveMQ入门实例-cnblogs.com 作者用的是5.5的版本,我测试时用的是5.6,按照作者说的整了一下,走得通
- JMeter学习-026-JMeter 分布式(远程)参数化测试实例
以前文所述对文章详情的HTTP请求进行性能测试为例.日常实际场景中,不可能所有的人都在同时访问一篇文章,而是多人访问不同的文章,因而需要对文章编号进行参数化,以更好的模拟日常的性能测试场景.同时,因文 ...
- webservice测试实例
webservice测试实例(LR8.1) 接口声明:这个接口是sina的短信服务接口,我只是用来做脚本学习使用,不会对其产生压力:希望读者也只是用来进行录制学习,而不是产生压力. 接口文档:http ...
- [原]在Fedora中编译Libevent测试实例
在我的昨天的博文<[原]我在Windows环境下的首个Libevent测试实例>中介绍了在Windows环境下如何编译一个echo server例子.今天我又试了一下在Linux环境中编译 ...
- C++动态链接库测试实例
前话 上一章节我导出了一个动态链接库 要使用该链接库,我们还需要该链接库对外公开的函数,即头文件 下面开始实例 测试实例 第一步--将动态链接库的dll.lib.和头文件导入项目中 文件目录如下: 项 ...
- Linux下简易蜂鸣器驱动代码及测试实例
驱动代码: #include <linux/module.h> #include <linux/kernel.h> #include <linux/init.h> ...
- 微服务架构 - 离线部署k8s平台并部署测试实例
一般在公司部署或者真实环境部署k8s平台,很有可能是内网环境,也即意味着是无法连接互联网的环境,这时就需要离线部署k8s平台.在此整理离线部署k8s的步骤,分享给大家,有什么不足之处,欢迎指正. 1. ...
- WinForm中 Asp.Net Signalr消息推送测试实例
p{ text-align:center; } blockquote > p > span{ text-align:center; font-size: 18px; color: #ff0 ...
- Confluence 6 从生产环境中恢复一个测试实例
请参考 Restoring a Test Instance from Production 页面中的内容获得更多完整的说明. 很多 Confluence 的管理员将会使用生产实例运行完整数据和服务的 ...
随机推荐
- Android(java)学习笔记34:Android原理揭秘系列之View、ViewGroup
1. 作过Android 应用开发的朋友都知道,Android的UI界面都是由View和ViewGroup及其派生类组合而成的.其中,View是所有UI组件的基类,而ViewGroup是容纳这些组件的 ...
- LA 3126 出租车
题目链接:https://vjudge.net/problem/UVALive-3126 题意:有m个客人,位于不同的位置,去一些地方,出发的时间给出,要一些出租车去接,但是,每辆出租车要在出发前一分 ...
- 项目Alpha冲刺(团队7/10)
项目Alpha冲刺(团队7/10) 团队名称: 云打印 作业要求: 项目Alpha冲刺(团队) 作业目标: 完成项目Alpha版本 团队队员 队员学号 队员姓名 个人博客地址 备注 221600412 ...
- ART_20190430
Algorithm-算法题 第一个只出现一次的字符 在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要 ...
- caffe卷积层实现
下图是jiayangqing在知乎上的回答,其实过程就是把image转换成矩阵,然后进行矩阵运算 卷积的实现在conv_layer层,conv_layer层继承了base_conv_layer层,ba ...
- 【洛谷P2577】[ZJOI2005]午餐
午餐 题目链接 DP题都辣么毒瘤的么.. 首先,看一下题解 我们就有了思路: 贪心:显然,让吃饭慢的先打饭,sort一遍(证明?不存在的.. DP:f[i][j][k]表示前i个人,窗口1的打饭时间为 ...
- 【luogu P2024 食物链】 题解
题目链接:https://www.luogu.org/problemnew/show/P2024 摘吊打集训队的九日dalao一句话 关于带有多个相对集合的全集,我们可以多开几倍的空间.每一倍的元素表 ...
- [luoguP3627][APIO2009]抢掠计划
先来看一下题目描述: 题目描述 Siruseri 城中的道路都是单向的.不同的道路由路口连接.按照法律的规定, 在每个路口都设立了一个 Siruseri 银行的 ATM 取款机.令人奇怪的是,Siru ...
- Android学习笔记_71_Android 多个项目之间如何引用 项目怎样打jar包
一.将整个项目作为资源文件 1.需要将被应用的项目设置为库项目. 2.将该项目的配置文件中的四大组件清空,例如下面代码: <?xml version="1.0" encodi ...
- scala性能测试
主要对比scala 的for, while循环,以及和java for while循环作对比 scala代码 object TestScalaClass { var maxindex = 100000 ...