JMeter之JMS接口测试
? JMeter中的JMS Point-to Point、JMS Publisher和JMS Subscriber分別用于發(fā)送JMS的PTP消息和PUB/SUB消息,可以選擇使用JMeter來(lái)測(cè)試JMS。
MOM(消息中間件)作為消息數(shù)據(jù)交換的平臺(tái),也是影響應(yīng)用執(zhí)行效率的潛在環(huán)節(jié)。在Java程序中,是通過(guò)JMS與MOM進(jìn)行交互的。作為Java實(shí)現(xiàn)的性能測(cè)試工具JMeter也能使用JMS對(duì)應(yīng)用的消息交換和相關(guān)的數(shù)據(jù)處理能力進(jìn)行測(cè)試。在整個(gè)測(cè)試過(guò)程中,JMeter測(cè)試的重點(diǎn)是消息的產(chǎn)生者和消費(fèi)者的能力,而不是MOM本身。JMeter雖然能使用JMS對(duì)MOM進(jìn)行測(cè)試,但是它本身并沒(méi)有提供JMS需要使用的包(實(shí)現(xiàn)類)。因此在使用JMeter測(cè)試JMS時(shí)需要使用到具體的MOM的相關(guān)jar包。以下結(jié)合流行的開(kāi)源消息中間件ActiveMQ來(lái)演示如何使用JMeter來(lái)實(shí)現(xiàn)對(duì)JMS的測(cè)試。
1、安裝并啟動(dòng)ActiveMQ服務(wù)
2、測(cè)試前的準(zhǔn)備
使用JMeter進(jìn)行壓力測(cè)試時(shí),所有的JMeter依賴的包需要復(fù)制到%JMETER_HOME%/lib目錄下。對(duì)于ActiveMQ來(lái)說(shuō),就是復(fù)制%ACTIVEMQ_HOME%/lib目錄下jar包。JMeter在測(cè)試時(shí)使用了JNDI,為了提供JNDI提供者的信息,需要提供jndi.properties。同時(shí)需要將jndi.properties放到JMeter的%JMETER_HOME%/lib和%JMETER_HOME%/bin目錄中,還需要將jndi.properties與%JMETER_HOME%/bin目錄下的ApacheJMeter.jar打包在一起。對(duì)于ActiveMQ,jndi.properties的演示內(nèi)容如下:
1 #java.naming.factory.initial = org.activemq.jndi.ActiveMQInitialContextFactory2 java.naming.factory.initial = org.apache.activemq.jndi.ActiveMQInitialContextFactory3 java.naming.provider.url = tcp://localhost:616164 5 #指定connectionFactory的jndi名字,多個(gè)名字之間可以逗號(hào)分隔。6 #以下為例:7 #對(duì)于topic,使用(TopicConnectionFactory)context.lookup("connectionFactry")8 #對(duì)于queue,(QueueConnectionFactory)context.lookup("connectionFactory")9 connectionFactoryNames = connectionFactory 10 11 #注冊(cè)queue,格式: 12 #queue.[jndiName] = [physicalName] 13 #使用時(shí):(Queue)context.lookup("jndiName"),此處是MyQueue 14 queue.MyQueue = example.MyQueue 15 16 #注冊(cè)topic,格式: 17 # topic.[jndiName] = [physicalName] 18 #使用時(shí):(Topic)context.lookup("jndiName"),此處是MyTopic 19 topic.MyTopic = example.MyTopic?
3、測(cè)試JMS的PTP模型
? ??對(duì)于點(diǎn)對(duì)點(diǎn)模型,JMeter只提供了一種Sampler:JMS Point-to-Point。如圖所示建立測(cè)試計(jì)劃:
? ? ?
?
QueueConnection Factory:連接工廠,輸入jndi配置文件中配置的connectionFactory
JNDI name Request queue:請(qǐng)求隊(duì)列名,輸入jndi配置文件中配置的MyQueue
JNDI name Receive queue:接收隊(duì)列名,輸入jndi配置文件中配置的MyQueue
Content:消息內(nèi)容,比如輸入:this is a test
Initial Context Factory:輸入org.apache.activemq.jndi.ActiveMQInitialContextFactory
Provider URL:提供者URL,即安裝的ActiveMQ的服務(wù)地址tcp://yourIP:61616
運(yùn)行調(diào)試時(shí)通過(guò)監(jiān)視器元件查看是否發(fā)送成功,如下說(shuō)明發(fā)送成功:
? ? ?
?
4、測(cè)試JMS的PUB/SUB模型
在實(shí)際測(cè)試時(shí),發(fā)布者和訂閱者并不是需要同時(shí)(異步)出現(xiàn)的。比如有時(shí)我們可能想測(cè)試單位時(shí)間內(nèi)消息發(fā)布者的消息產(chǎn)生量,此時(shí)就不需要消息發(fā)布者,只需要訂閱者就可以了。本例為了說(shuō)明這兩種Sampler的使用,建立兩個(gè)JMeter實(shí)例分別用于發(fā)送和接收消息。
1)首先新建如下訂閱者的測(cè)試計(jì)劃:
? ??
勾選使用jndi配置文件,并分別輸入jndi中配置的連接工廠和目的地名稱,如上圖所示,點(diǎn)擊運(yùn)行下的啟動(dòng),使用消息消費(fèi)者處于接收狀態(tài)。
2)然后新建如下發(fā)布者的測(cè)試計(jì)劃:
? ??
?
勾選使用jndi配置文件,并分別輸入jndi中配置的連接工廠和目的地名稱以及要發(fā)送的消息內(nèi)容,此處為:this is a pubish test,如上圖所示,點(diǎn)擊運(yùn)行下的啟動(dòng),以發(fā)送消息,查看監(jiān)視器元件檢查消息是否發(fā)送成功,如下說(shuō)明發(fā)送成功:
? ??
檢查消息消費(fèi)者是否接收到消息,如下說(shuō)明接收成功:
上面即完成了JMeter對(duì)JMS的基本測(cè)試演示。
?
轉(zhuǎn)載于:https://www.cnblogs.com/yezhaohui/p/5026434.html
總結(jié)
以上是生活随笔為你收集整理的JMeter之JMS接口测试的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: LeetCode - 3Sum Clos
- 下一篇: Koa -- 基于 Node.js 平台