Jmeter 测试 JMS (Java Message Service)/ActiveMQ 性能
前言
JMS介绍:JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送消息,进行异步通信。(百度 )
本文只测试ActiveMQ,其他消息中间件应该同理.
ActiveMQ介绍
JMS常见2种消息模型:
- 点对点(Queues队列)
生产者产生消息,仍1条消息给ActiveMQ,消费者监听ActiveMQ,从ActiveMQ中取走1条消息,并销毁这个消息,且只会有一个监听的消费者取走.其他消费者不会取走信息 - 广播/订阅(Topics 队列)
广播出1条消息给ActiveMQ,订阅监听ActiveMQ,所有当时监听ActiveMQ的订阅都可以取到这条消息,并销毁这个消息,
3 . 虚拟Topics
为什么说2种消息模型,这里会有第三种,因为Topics队列的性质决定,当我要发消息给很多订阅,但是如果订阅监听服务挂掉,就不能收到这个消息,导致消息未发布到这个订阅,所以引申出第三个消息模型,虚拟Topics.
广播出1条消息给ActiveMQ Topics队列,ActiveMQ会自动转换给要分发消息的订阅 Queues 队列.然后订阅监听Queues队列去取走消息.这2种消息模型的结合,产生出第三种消息模型,虚拟Topics.
准备工作
以ActiveMQ为例子,使用jmeter测试JMS.
- Jmeter版本:3.2
- ActiveMQ版本5.14.5
编写jndi.properties添加到ApacheJMeter.jar 中
- 新建
jndi.properties到jmeter/bin目录下 - 复制内容为:
java.naming.factory.initial = org.apache.activemq.jndi.ActiveMQInitialContextFactory
java.naming.provider.url = tcp://IP:61616
connectionFactoryNames = connectionFactory
queue.T_MDM_Q = Queue.T_MDM
queue.T_IPS_Q= Queue.T_IPS
topic.T_MDM_T= VirtualTopic.T_MDM
topic.T_IPS_T= VirtualTopic.T_IPS
java.naming.factory.initial:ActiveMQ jar包中 init 所需的 类名java.naming.provider.url:ActiveMQ的地址connectionFactoryNames:链接工厂名称queue.T_MDM_Q:队列名称queue:说明是queue队列T_MDM_Q:自定义字段,在后面用来指向队列名称同理topic.T_MDM_T
- 把配置文件打到
ApacheJMeter.jar中 在jmeter/bin目录下运行jar uf ApacheJMeter.jar jndi.properties
下载ActiveMQ
把ActiveMQ下 activemq-all-x.x.x.jar放到Jmeter/lib下
配置Jmeter进行测试 点对点(Queues队列)
- 待测消息模型:点对点(Queues队列)
- 待测队列名称:Queue.T_MDM
右键》添加》sampler》JMS point-to-point 添加一个队列的界面
QueueConnection Factory:jndi.properties中connectionFactoryNames 字段
JNDI Name Request queue:生产者向哪个队列插入消息,jndi.properties中对应待测队列名称的queue.xxxxx
JNDI Name Reply queue:消费者从哪个队列取消息,jndi.properties中对应待测队列名称的queue.xxxxx
Content:消息内容
InitialContextFactory:org.apache.activemq.jndi.ActiveMQInitialContextFactory
Provider URL:ActiveMQ地址
配置Jmeter进行测试 发布/订阅(Topic队列)
- 待测消息模型:发布/订阅(Topic队列)
- 待测队列名称:VirtualTopic.T_MDM
配置发布 Publisher
右键》添加》sampler》JMS Publisher 添加一个Publisher界面
InitialContextFactory:org.apache.activemq.jndi.ActiveMQInitialContextFactory
Provider URL:ActiveMQ地址
QueueConnection Factory:jndi.properties中connectionFactoryNames 字段
Destination:发布往队列的名称,jndi.properties中对应Topic队列名称的topic.xxxx
Text Massage:发布的消息
配置订阅 Subscriber
右键》添加》sampler》JMS Subscriber添加一个Publisher界面
总结
上面只介绍了ActiveMQ的配置方法,因为我也只调了ActiveMQ,其他JMS中间件没有试过,如果你们项目中需要,可以试一下.
Jmeter测试JMS中涉及的其他参数设置,可能会用到的,查看Jmeter说明http://jmeter.apache.org/usermanual/build-jms-point-to-point-test-plan.html
Jmeter 测试 JMS (Java Message Service)/ActiveMQ 性能的更多相关文章
- 17) JMS: java Message Service(Java消息服务)
JMS是一个标准,就像EJB,有很多开源的,商业的实现,ms技术对应的规范是jsr914,规范的实现称为jms provider,常见的实现有ActiveMQ.JBoss MQ.IBM We ...
- Java Message Service学习(一)
一,背景 近期需要用到ActiveMQ接收Oozie执行作业之后的返回结果.Oozie作为消息的生产者,将消息发送给ActiveMQ,然后Client可以异步去ActiveMQ取消息. ActiveM ...
- 认识 Java Message Service
1. Java Message Service : 是一个消息服务的标准或者说是规范,允许应用程序组件基于JavaEE平台创建.发送.接收和读取消息. 实现Java 程序与MQ Server 之间互相 ...
- Java Message Service
en.wikipedia.org/wiki/Java_Message_Service Messaging is a form of loosely coupled distributed commun ...
- Simple guide to Java Message Service (JMS) using ActiveMQ
JMS let’s you send messages containing for example a String, array of bytes or a serializable Java o ...
- Jmeter测试普通java类说明
概述 Apache JMeter是Apache组织开发的基于Java的压力测试工具.本文档主要描述用Jmeter工具对基于Dubbo.Zookeeper框架的Cassandra接口.区块链接口进行压力 ...
- JMS Java消息服务(Java Message Service)
JMS 在一些场景下RPC的同步方式可能不太适合业务逻辑的处理,并且这种方式在某些场景下会导致业务的紧耦合. 基于异步交互模型的JMS解决了RPC产生的紧耦合问题,它提供了一个可以通过网络访问的抽象消 ...
- Spring的消息 Java Message Service (JMS)
Spring有两种方法提供对EJB的支持: Spring能让你在Spring的配置文件里,把EJB作为Bean来声明.这样,把EJB引用置入到其他Bean的属性里就成为可能了,好像EJB就是另一个P ...
- 【转】JMeter测试有无数据库连接池的性能
使用JMeter测试一下有无数据库连接池的性能: 1.下载JMeter 2.无连接池的servlet Java代码 public void doGet(HttpServletRequest reque ...
随机推荐
- Java之IO(八)PipedIutputStream和PipedOutputStream
转载请注明源出处:http://www.cnblogs.com/lighten/p/7056278.html 1.前言 本章介绍Java的IO体系中最后一对字节流--管道流.之前在字节数组流的时候就说 ...
- Linux的文件的打包(tar方法)
Linux的文件的打包(tar方法) tar -c: 建立压缩档案 -x:解压 -t:查看内容 -r:向压缩归档文件末尾追加文件 -u:更新原压缩包中的文件 这五个是独立的命令,压缩解压都要用到其中一 ...
- 【链表】Reorder List
题目: Given a singly linked list L: L0→L1→…→Ln-1→Ln,reorder it to: L0→Ln→L1→Ln-1→L2→Ln-2→… You must do ...
- 一口一口吃掉Hexo(六)
如果你想得到更好的阅读效果,请访问我的个人网站 ,版权所有,未经许可不得转载! 不知不觉已经更新到了最后一节了,很开心你能看到这一节,相信你也已经在你的虚拟主机上成功部署了你的网站,但是可能总会遇到一 ...
- JAVA实现单双向链表的增、删、改、查
单向链表 package com.ywx.link; /** * 单向链表 * @author vashon * */ public class LinkTest { public static vo ...
- unity 图片 粉碎效果 破碎效果
效果: 点击按钮后: 这些碎片具有物理碰撞效果,下面会有隐形的支柱垫着碎片,n秒后支柱消失,碎片落下 当然你也可以控制生成的碎片,让他们从下而上一块一块地落下 插件源码: https://github ...
- ActiveMQ消息持久化到Mysql数据库
1.把连接MySQL数据库的jar文件,放到ActiveMQ的lib目录下 2.修改ActiveMQ的conf目录下的activemq.xml文件,修改数据持久化的方式2.1 修改原来的kahadb的 ...
- tomcat启动(Ⅶ)请求处理--Processor.process(SocketWrapper<S> socketWrapper)
tomcat启动(六)Catalina分析-StandardServer.start() 上一篇分析到:Http11NioProcessor.process(SocketWrapper<S> ...
- 蝴蝶效应--由'sudo -s ...'引发的vim autocmd使用异常
1. 背景介绍 自加入RedHat起,我就把家里的台式机(Ubuntu 16.04 LTS)的默认登录用户veli切换成了huanli, 主要是为了跟公司的电脑配置对齐以方便未来WFH,但引发了一个v ...
- 下拉加载dropload.js
使用下拉加载 使用需要引用的css <link rel="stylesheet" href="../dist/dropload.css"> 使用需要 ...