mirror of https://github.com/apache/activemq.git
- Redesigned the perf plugin
- Added the cpu sampler for linux using vmstat (no summary as of the moment). git-svn-id: https://svn.apache.org/repos/asf/incubator/activemq/trunk@416542 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
ab027d0867
commit
f1c6e4c663
|
@ -1,13 +1,12 @@
|
|||
package org.apache.activemq.maven;
|
||||
|
||||
/*
|
||||
* Copyright 2001-2005 The Apache Software Foundation.
|
||||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
|
@ -15,13 +14,18 @@ package org.apache.activemq.maven;
|
|||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.maven;
|
||||
|
||||
import org.apache.activemq.tool.JmsConsumerSystem;
|
||||
import org.apache.maven.plugin.AbstractMojo;
|
||||
import org.apache.maven.plugin.MojoExecutionException;
|
||||
|
||||
import javax.jms.JMSException;
|
||||
|
||||
import java.util.Properties;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Set;
|
||||
import java.util.HashSet;
|
||||
|
||||
/**
|
||||
* Goal which touches a timestamp file.
|
||||
|
@ -29,211 +33,40 @@ import javax.jms.JMSException;
|
|||
* @goal consumer
|
||||
* @phase process-sources
|
||||
*/
|
||||
public class ConsumerMojo
|
||||
extends AbstractMojo {
|
||||
public class ConsumerMojo extends AbstractMojo {
|
||||
|
||||
/**
|
||||
* @parameter expression="${sampler.duration}" default-value="60000"
|
||||
* @required
|
||||
*/
|
||||
private String duration;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sampler.interval}" default-value="1000"
|
||||
* @required
|
||||
*/
|
||||
private String interval;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sampler.rampUpTime}" default-value="10000"
|
||||
* @required
|
||||
*/
|
||||
private String rampUpTime;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sampler.rampDownTime}" default-value="10000"
|
||||
* @required
|
||||
*/
|
||||
private String rampDownTime;
|
||||
|
||||
/**
|
||||
* @parameter expression="${consumer.spiClass}" default-value="org.apache.activemq.tool.spi.ActiveMQPojoSPI"
|
||||
* @required
|
||||
*/
|
||||
private String spiClass;
|
||||
|
||||
/**
|
||||
* @parameter expression="${consumer.sessTransacted}" default-value="false"
|
||||
* @required
|
||||
*/
|
||||
private String sessTransacted;
|
||||
|
||||
/**
|
||||
* @parameter expression="${consumer.sessAckMode}" default-value="autoAck"
|
||||
* @required
|
||||
*/
|
||||
private String sessAckMode;
|
||||
|
||||
/**
|
||||
* @parameter expression="${consumer.destName}" default-value="topic://TEST.PERFORMANCE.FOO.BAR"
|
||||
* @required
|
||||
*/
|
||||
private String destName;
|
||||
|
||||
/**
|
||||
* @parameter expression="${consumer.destCount}" default-value="1"
|
||||
* @required
|
||||
*/
|
||||
private String destCount;
|
||||
|
||||
/**
|
||||
* @parameter expression="${consumer.destComposite}" default-value="false"
|
||||
* @required
|
||||
*/
|
||||
private String destComposite;
|
||||
|
||||
/**
|
||||
* @parameter expression="${consumer.durable}" default-value="false"
|
||||
* @required
|
||||
*/
|
||||
private String durable;
|
||||
|
||||
/**
|
||||
* @parameter expression="${consumer.asyncRecv}" default-value="true"
|
||||
* @required
|
||||
*/
|
||||
private String asyncRecv;
|
||||
|
||||
/**
|
||||
* @parameter expression="${consumer.recvCount}" default-value="1000000"
|
||||
* @required
|
||||
*/
|
||||
private String recvCount;
|
||||
|
||||
/*
|
||||
* @parameter expression="${consumer.recvDuration}" default-value="60000"
|
||||
* @required
|
||||
|
||||
private String recvDuration;
|
||||
*/
|
||||
|
||||
/**
|
||||
* @parameter expression="${consumer.recvType}" default-value="time"
|
||||
* @required
|
||||
*/
|
||||
private String recvType;
|
||||
|
||||
/**
|
||||
* @parameter expression="${factory.brokerUrl}" default-value="tcp://localhost:61616"
|
||||
* @required
|
||||
*/
|
||||
private String brokerUrl;
|
||||
|
||||
/**
|
||||
* @parameter expression="${factory.optimAck}" default-value="true"
|
||||
* @required
|
||||
*/
|
||||
private String optimAck;
|
||||
|
||||
/**
|
||||
* @parameter expression="${factory.optimDispatch}" default-value="true"
|
||||
* @required
|
||||
*/
|
||||
private String optimDispatch;
|
||||
|
||||
/**
|
||||
* @parameter expression="${factory.prefetchQueue}" default-value="5000"
|
||||
* @required
|
||||
*/
|
||||
private String prefetchQueue;
|
||||
|
||||
/**
|
||||
* @parameter expression="${factory.prefetchTopic}" default-value="5000"
|
||||
* @required
|
||||
*/
|
||||
private String prefetchTopic;
|
||||
|
||||
/**
|
||||
* @parameter expression="${factory.useRetroactive}" default-value="false"
|
||||
* @required
|
||||
*/
|
||||
private String useRetroactive;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sysTest.numClients}" default-value="1"
|
||||
* @required
|
||||
*/
|
||||
private String numClients;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sysTest.totalDests}" default-value="1"
|
||||
* @required
|
||||
*/
|
||||
private String totalDests;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sysTest.destDistro}" default-value="all"
|
||||
* @required
|
||||
*/
|
||||
private String destDistro;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sysTest.reportDirectory}" default-value="${project.build.directory}/test-perf"
|
||||
* @required
|
||||
*/
|
||||
private String reportDirectory;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sysTest.reportType}" default-value="xml"
|
||||
* @required
|
||||
*/
|
||||
private String reportType;
|
||||
|
||||
public void execute()
|
||||
throws MojoExecutionException {
|
||||
|
||||
try {
|
||||
JmsConsumerSystem.main(createArgument());
|
||||
} catch (JMSException e) {
|
||||
throw new MojoExecutionException(e.getMessage());
|
||||
}
|
||||
private String[] validPrefix = {
|
||||
"sysTest.",
|
||||
"factory.",
|
||||
"consumer.",
|
||||
"tpSampler.",
|
||||
"cpuSampler."
|
||||
};
|
||||
|
||||
public void execute() throws MojoExecutionException {
|
||||
JmsConsumerSystem.main(createArgument());
|
||||
}
|
||||
|
||||
public String[] createArgument() {
|
||||
String[] options = {
|
||||
"sampler.duration=" + duration,
|
||||
"sampler.interval=" + interval,
|
||||
"sampler.rampUpTime=" + rampUpTime,
|
||||
"sampler.rampDownTime=" + rampDownTime,
|
||||
|
||||
"consumer.spiClass=" + spiClass,
|
||||
"consumer.sessTransacted=" + sessTransacted,
|
||||
"consumer.sessAckMode=" + sessAckMode,
|
||||
"consumer.destName=" + destName,
|
||||
"consumer.destCount=" + destCount,
|
||||
"consumer.destComposite=" + destComposite,
|
||||
|
||||
"consumer.durable=" + durable,
|
||||
"consumer.asyncRecv=" + asyncRecv,
|
||||
"consumer.recvCount=" + recvCount,
|
||||
"consumer.recvDuration=" + duration,
|
||||
"consumer.recvType=" + recvType,
|
||||
|
||||
"factory.brokerUrl=" + brokerUrl,
|
||||
"factory.optimAck=" + optimAck,
|
||||
"factory.optimDispatch=" + optimDispatch,
|
||||
"factory.prefetchQueue=" + prefetchQueue,
|
||||
"factory.prefetchTopic=" + prefetchTopic,
|
||||
"factory.useRetroactive=" + useRetroactive,
|
||||
|
||||
"sysTest.numClients=" + numClients,
|
||||
"sysTest.totalDests=" + totalDests,
|
||||
"sysTest.destDistro=" + destDistro,
|
||||
"sysTest.reportDirectory=" + reportDirectory,
|
||||
"sysTest.reportType=" + reportType
|
||||
};
|
||||
protected String[] createArgument() {
|
||||
List args = new ArrayList();
|
||||
Properties sysProps = System.getProperties();
|
||||
Set keys = new HashSet(sysProps.keySet());
|
||||
|
||||
return options;
|
||||
for (Iterator i=keys.iterator(); i.hasNext();) {
|
||||
String key = (String)i.next();
|
||||
if (isRecognizedProperty(key)) {
|
||||
args.add(key + "=" + sysProps.remove(key));
|
||||
}
|
||||
}
|
||||
return (String[])args.toArray(new String[0]);
|
||||
}
|
||||
|
||||
protected boolean isRecognizedProperty(String key) {
|
||||
for (int j=0; j<validPrefix.length; j++) {
|
||||
if (key.startsWith(validPrefix[j])) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,17 +1,12 @@
|
|||
package org.apache.activemq.maven;
|
||||
|
||||
import org.apache.activemq.tool.JmsProducerSystem;
|
||||
import org.apache.maven.plugin.AbstractMojo;
|
||||
import org.apache.maven.plugin.MojoExecutionException;
|
||||
|
||||
/*
|
||||
* Copyright 2001-2005 The Apache Software Foundation.
|
||||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
|
@ -19,7 +14,18 @@ import org.apache.maven.plugin.MojoExecutionException;
|
|||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.maven;
|
||||
|
||||
import org.apache.activemq.tool.JmsProducerSystem;
|
||||
import org.apache.maven.plugin.AbstractMojo;
|
||||
import org.apache.maven.plugin.MojoExecutionException;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Properties;
|
||||
import java.util.Iterator;
|
||||
import java.util.Set;
|
||||
import java.util.HashSet;
|
||||
|
||||
/**
|
||||
* Goal which touches a timestamp file.
|
||||
|
@ -27,180 +33,40 @@ import org.apache.maven.plugin.MojoExecutionException;
|
|||
* @goal producer
|
||||
* @phase process
|
||||
*/
|
||||
public class ProducerMojo
|
||||
extends AbstractMojo {
|
||||
public class ProducerMojo extends AbstractMojo {
|
||||
|
||||
/**
|
||||
* @parameter expression="${sampler.duration}" default-value="60000"
|
||||
* @required
|
||||
*/
|
||||
private String duration;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sampler.interval}" default-value="1000"
|
||||
* @required
|
||||
*/
|
||||
private String interval;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sampler.rampUpTime}" default-value="10000"
|
||||
* @required
|
||||
*/
|
||||
private String rampUpTime;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sampler.rampDownTime}" default-value="10000"
|
||||
* @required
|
||||
*/
|
||||
private String rampDownTime;
|
||||
|
||||
/**
|
||||
* @parameter expression="${producer.spiClass}" default-value="org.apache.activemq.tool.spi.ActiveMQPojoSPI"
|
||||
* @required
|
||||
*/
|
||||
private String spiClass;
|
||||
|
||||
/**
|
||||
* @parameter expression="${producer.sessTransacted}" default-value="false"
|
||||
* @required
|
||||
*/
|
||||
private String sessTransacted;
|
||||
|
||||
/**
|
||||
* @parameter expression="${producer.sessAckMode}" default-value="autoAck"
|
||||
* @required
|
||||
*/
|
||||
private String sessAckMode;
|
||||
|
||||
/**
|
||||
* @parameter expression="${producer.destName}" default-value="topic://TEST.PERFORMANCE.FOO.BAR"
|
||||
* @required
|
||||
*/
|
||||
private String destName;
|
||||
|
||||
/**
|
||||
* @parameter expression="${producer.destCount}" default-value="1"
|
||||
* @required
|
||||
*/
|
||||
private String destCount;
|
||||
|
||||
/**
|
||||
* @parameter expression="${producer.destComposite}" default-value="false"
|
||||
* @required
|
||||
*/
|
||||
private String destComposite;
|
||||
|
||||
/**
|
||||
* @parameter expression="${producer.deliveryMode}" default-value="nonpersistent"
|
||||
* @required
|
||||
*/
|
||||
private String deliveryMode;
|
||||
|
||||
/**
|
||||
* @parameter expression="${producer.messageSize}" default-value="1024"
|
||||
* @required
|
||||
*/
|
||||
private String messageSize;
|
||||
|
||||
/**
|
||||
* @parameter expression="${producer.sendCount}" default-value="1000000"
|
||||
* @required
|
||||
*/
|
||||
private String sendCount;
|
||||
|
||||
/*
|
||||
* @parameter expression="${producer.sendDuration}" default-value="60000"
|
||||
* @required
|
||||
|
||||
private String sendDuration;
|
||||
*/
|
||||
|
||||
/**
|
||||
* @parameter expression="${producer.sendType}" default-value="time"
|
||||
* @required
|
||||
*/
|
||||
private String sendType;
|
||||
|
||||
/**
|
||||
* @parameter expression="${factory.brokerUrl}" default-value="tcp://localhost:61616"
|
||||
* @required
|
||||
*/
|
||||
private String brokerUrl;
|
||||
|
||||
/**
|
||||
* @parameter expression="${factory.asyncSend}" default-value="true"
|
||||
* @required
|
||||
*/
|
||||
private String asyncSend;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sysTest.numClients}" default-value="1"
|
||||
* @required
|
||||
*/
|
||||
private String numClients;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sysTest.totalDests}" default-value="1"
|
||||
* @required
|
||||
*/
|
||||
private String totalDests;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sysTest.destDistro}" default-value="all"
|
||||
* @required
|
||||
*/
|
||||
private String destDistro;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sysTest.reportDirectory}" default-value="${project.build.directory}/test-perf"
|
||||
* @required
|
||||
*/
|
||||
private String reportDirectory;
|
||||
|
||||
/**
|
||||
* @parameter expression="${sysTest.reportType}" default-value="xml"
|
||||
* @required
|
||||
*/
|
||||
private String reportType;
|
||||
|
||||
|
||||
public void execute()
|
||||
throws MojoExecutionException {
|
||||
private String[] validPrefix = {
|
||||
"sysTest.",
|
||||
"factory.",
|
||||
"producer.",
|
||||
"tpSampler.",
|
||||
"cpuSampler."
|
||||
};
|
||||
|
||||
public void execute() throws MojoExecutionException {
|
||||
JmsProducerSystem.main(createArgument());
|
||||
}
|
||||
|
||||
public String[] createArgument() {
|
||||
protected String[] createArgument() {
|
||||
List args = new ArrayList();
|
||||
Properties sysProps = System.getProperties();
|
||||
Set keys = new HashSet(sysProps.keySet());
|
||||
|
||||
String[] options = {
|
||||
"sampler.duration=" + duration,
|
||||
"sampler.interval=" + interval,
|
||||
"sampler.rampUpTime=" + rampUpTime,
|
||||
"sampler.rampDownTime=" + rampDownTime,
|
||||
|
||||
"producer.spiClass=" + spiClass,
|
||||
"producer.sessTransacted=" + sessTransacted,
|
||||
"producer.sessAckMode=" + sessAckMode,
|
||||
"producer.destName=" + destName,
|
||||
"producer.destCount=" + destCount,
|
||||
"producer.destComposite=" + destComposite,
|
||||
for (Iterator i=keys.iterator(); i.hasNext();) {
|
||||
String key = (String)i.next();
|
||||
if (isRecognizedProperty(key)) {
|
||||
args.add(key + "=" + sysProps.remove(key));
|
||||
}
|
||||
}
|
||||
return (String[])args.toArray(new String[0]);
|
||||
}
|
||||
|
||||
"producer.deliveryMode="+deliveryMode,
|
||||
"producer.messageSize="+messageSize,
|
||||
"producer.sendCount="+sendCount,
|
||||
"producer.sendDuration="+duration,
|
||||
"producer.sendType="+sendType,
|
||||
|
||||
"factory.brokerUrl="+brokerUrl,
|
||||
"factory.asyncSend="+asyncSend,
|
||||
|
||||
"sysTest.numClients=" + numClients,
|
||||
"sysTest.totalDests=" + totalDests,
|
||||
"sysTest.destDistro=" + destDistro,
|
||||
"sysTest.reportDirectory=" + reportDirectory,
|
||||
"sysTest.reportType=" + reportType
|
||||
};
|
||||
|
||||
return options;
|
||||
protected boolean isRecognizedProperty(String key) {
|
||||
for (int j=0; j<validPrefix.length; j++) {
|
||||
if (key.startsWith(validPrefix[j])) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,13 +1,12 @@
|
|||
package org.apache.activemq.maven;
|
||||
|
||||
/*
|
||||
* Copyright 2001-2005 The Apache Software Foundation.
|
||||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
|
@ -15,6 +14,7 @@ package org.apache.activemq.maven;
|
|||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.maven;
|
||||
|
||||
import org.apache.activemq.console.Main;
|
||||
import org.apache.maven.plugin.AbstractMojo;
|
||||
|
@ -33,8 +33,7 @@ import java.nio.channels.FileChannel;
|
|||
* @goal broker
|
||||
* @phase process-sources
|
||||
*/
|
||||
public class ServerMojo
|
||||
extends AbstractMojo {
|
||||
public class ServerMojo extends AbstractMojo {
|
||||
/**
|
||||
* Location of the output directory. Defaults to target.
|
||||
*
|
||||
|
@ -83,7 +82,6 @@ public class ServerMojo
|
|||
out.mkdirs();
|
||||
}
|
||||
|
||||
|
||||
String[] args = new String[2];
|
||||
if (url != null) {
|
||||
args[0] = "start";
|
||||
|
|
|
@ -0,0 +1,150 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool;
|
||||
|
||||
import org.apache.activemq.tool.properties.JmsClientProperties;
|
||||
|
||||
import javax.jms.ConnectionFactory;
|
||||
import javax.jms.Connection;
|
||||
import javax.jms.Session;
|
||||
import javax.jms.JMSException;
|
||||
import javax.jms.Destination;
|
||||
|
||||
public abstract class AbstractJmsClient {
|
||||
protected ConnectionFactory factory;
|
||||
protected Connection jmsConnection;
|
||||
protected Session jmsSession;
|
||||
|
||||
protected int destCount = 1, destIndex = 0;
|
||||
protected String clientName = "";
|
||||
|
||||
public AbstractJmsClient(ConnectionFactory factory) {
|
||||
this.factory = factory;
|
||||
}
|
||||
|
||||
abstract public JmsClientProperties getClient();
|
||||
abstract public void setClient(JmsClientProperties client);
|
||||
|
||||
public ConnectionFactory getFactory() {
|
||||
return factory;
|
||||
}
|
||||
|
||||
public void setFactory(ConnectionFactory factory) {
|
||||
this.factory = factory;
|
||||
}
|
||||
|
||||
public int getDestCount() {
|
||||
return destCount;
|
||||
}
|
||||
|
||||
public void setDestCount(int destCount) {
|
||||
this.destCount = destCount;
|
||||
}
|
||||
|
||||
public int getDestIndex() {
|
||||
return destIndex;
|
||||
}
|
||||
|
||||
public void setDestIndex(int destIndex) {
|
||||
this.destIndex = destIndex;
|
||||
}
|
||||
|
||||
public String getClientName() {
|
||||
return clientName;
|
||||
}
|
||||
|
||||
public void setClientName(String clientName) {
|
||||
this.clientName = clientName;
|
||||
}
|
||||
|
||||
public Connection getConnection() throws JMSException {
|
||||
if (jmsConnection == null) {
|
||||
jmsConnection = factory.createConnection();
|
||||
}
|
||||
return jmsConnection;
|
||||
}
|
||||
|
||||
public Session getSession() throws JMSException {
|
||||
if (jmsSession == null) {
|
||||
int ackMode;
|
||||
if (getClient().getSessAckMode().equalsIgnoreCase(JmsClientProperties.SESSION_AUTO_ACKNOWLEDGE)) {
|
||||
ackMode = Session.AUTO_ACKNOWLEDGE;
|
||||
} else if (getClient().getSessAckMode().equalsIgnoreCase(JmsClientProperties.SESSION_CLIENT_ACKNOWLEDGE)) {
|
||||
ackMode = Session.CLIENT_ACKNOWLEDGE;
|
||||
} else if (getClient().getSessAckMode().equalsIgnoreCase(JmsClientProperties.SESSION_DUPS_OK_ACKNOWLEDGE)) {
|
||||
ackMode = Session.DUPS_OK_ACKNOWLEDGE;
|
||||
} else if (getClient().getSessAckMode().equalsIgnoreCase(JmsClientProperties.SESSION_TRANSACTED)) {
|
||||
ackMode = Session.SESSION_TRANSACTED;
|
||||
} else {
|
||||
ackMode = Session.AUTO_ACKNOWLEDGE;
|
||||
}
|
||||
jmsSession = getConnection().createSession(getClient().isSessTransacted(), ackMode);
|
||||
}
|
||||
return jmsSession;
|
||||
}
|
||||
|
||||
public Destination[] createDestination(int destIndex, int destCount) throws JMSException {
|
||||
|
||||
if (getClient().isDestComposite()) {
|
||||
return new Destination[] {createCompositeDestination(getClient().getDestName(), destIndex, destCount)};
|
||||
} else {
|
||||
Destination[] dest = new Destination[destCount];
|
||||
for (int i=0; i<destCount; i++) {
|
||||
dest[i] = createDestination(getClient().getDestName() + "." + (destIndex + i));
|
||||
}
|
||||
|
||||
return dest;
|
||||
}
|
||||
}
|
||||
|
||||
public Destination createCompositeDestination(int destIndex, int destCount) throws JMSException {
|
||||
return createCompositeDestination(getClient().getDestName(), destIndex, destCount);
|
||||
}
|
||||
|
||||
protected Destination createCompositeDestination(String name, int destIndex, int destCount) throws JMSException {
|
||||
String compDestName;
|
||||
String simpleName;
|
||||
|
||||
if (name.startsWith("queue://")) {
|
||||
simpleName = name.substring("queue://".length());
|
||||
} else if (name.startsWith("topic://")) {
|
||||
simpleName = name.substring("topic://".length());
|
||||
} else {
|
||||
simpleName = name;
|
||||
}
|
||||
|
||||
int i;
|
||||
compDestName = name + "." + destIndex + ","; // First destination
|
||||
for (i=1; i<destCount-1; i++) {
|
||||
compDestName += (simpleName + "." + (destIndex + i) +",");
|
||||
}
|
||||
compDestName += (simpleName + "." + (destIndex + i)); // Last destination (minus the comma)
|
||||
|
||||
return createDestination(compDestName);
|
||||
}
|
||||
|
||||
protected Destination createDestination(String name) throws JMSException {
|
||||
if (name.startsWith("queue://")) {
|
||||
return getSession().createQueue(name.substring("queue://".length()));
|
||||
} else if (name.startsWith("topic://")) {
|
||||
return getSession().createTopic(name.substring("topic://".length()));
|
||||
} else {
|
||||
return getSession().createTopic(name);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,210 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool;
|
||||
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
import org.apache.activemq.tool.sampler.ThroughputSamplerTask;
|
||||
import org.apache.activemq.tool.sampler.CpuSamplerTask;
|
||||
import org.apache.activemq.tool.reports.PerformanceReportWriter;
|
||||
import org.apache.activemq.tool.reports.XmlFilePerfReportWriter;
|
||||
import org.apache.activemq.tool.reports.VerbosePerfReportWriter;
|
||||
import org.apache.activemq.tool.properties.JmsClientSystemProperties;
|
||||
import org.apache.activemq.tool.properties.AbstractObjectProperties;
|
||||
import org.apache.activemq.tool.properties.JmsFactoryProperties;
|
||||
import org.apache.activemq.tool.properties.ReflectionUtil;
|
||||
import org.apache.activemq.tool.properties.JmsClientProperties;
|
||||
import org.apache.activemq.tool.spi.SPIConnectionFactory;
|
||||
|
||||
import javax.jms.ConnectionFactory;
|
||||
import javax.jms.JMSException;
|
||||
import java.util.Properties;
|
||||
import java.io.IOException;
|
||||
|
||||
public abstract class AbstractJmsClientSystem extends AbstractObjectProperties {
|
||||
private static final Log log = LogFactory.getLog(AbstractJmsClientSystem.class);
|
||||
|
||||
private int clientDestIndex, clientDestCount;
|
||||
|
||||
protected ThreadGroup clientThreadGroup;
|
||||
protected ConnectionFactory jmsConnFactory;
|
||||
|
||||
// Properties
|
||||
protected JmsFactoryProperties factory = new JmsFactoryProperties();
|
||||
protected ThroughputSamplerTask tpSampler = new ThroughputSamplerTask();
|
||||
protected CpuSamplerTask cpuSampler = new CpuSamplerTask();
|
||||
|
||||
public void runSystemTest() throws JMSException {
|
||||
// Create connection factory
|
||||
jmsConnFactory = loadJmsFactory(getSysTest().getSpiClass(), factory.getFactorySettings());
|
||||
|
||||
// Create performance sampler
|
||||
PerformanceReportWriter writer = createPerfWriter();
|
||||
tpSampler.setPerfReportWriter(writer);
|
||||
cpuSampler.setPerfReportWriter(writer);
|
||||
|
||||
writer.openReportWriter();
|
||||
writer.writeProperties("jvmSettings", System.getProperties());
|
||||
writer.writeProperties("testSystemSettings", ReflectionUtil.retrieveObjectProperties(getSysTest()));
|
||||
writer.writeProperties("jmsFactorySettings", ReflectionUtil.retrieveObjectProperties(jmsConnFactory));
|
||||
writer.writeProperties("jmsClientSettings", ReflectionUtil.retrieveObjectProperties(getJmsClientProperties()));
|
||||
writer.writeProperties("tpSamplerSettings", ReflectionUtil.retrieveObjectProperties(tpSampler));
|
||||
writer.writeProperties("cpuSamplerSettings", ReflectionUtil.retrieveObjectProperties(cpuSampler));
|
||||
|
||||
clientThreadGroup = new ThreadGroup(getSysTest().getClientPrefix() + " Thread Group");
|
||||
for (int i=0; i<getSysTest().getNumClients(); i++) {
|
||||
distributeDestinations(getSysTest().getDestDistro(), i, getSysTest().getNumClients(), getSysTest().getTotalDests());
|
||||
|
||||
final String clientName = getSysTest().getClientPrefix() + i;
|
||||
final int clientDestIndex = this.clientDestIndex;
|
||||
final int clientDestCount = this.clientDestCount;
|
||||
Thread t = new Thread(clientThreadGroup, new Runnable() {
|
||||
public void run() {
|
||||
runJmsClient(clientName, clientDestIndex, clientDestCount);
|
||||
}
|
||||
});
|
||||
t.setName(getSysTest().getClientPrefix() + i + " Thread");
|
||||
t.start();
|
||||
}
|
||||
|
||||
// Run samplers
|
||||
if (getSysTest().getSamplers().indexOf(JmsClientSystemProperties.SAMPLER_TP) > -1) {
|
||||
tpSampler.startSampler();
|
||||
}
|
||||
|
||||
if (getSysTest().getSamplers().indexOf(JmsClientSystemProperties.SAMPLER_CPU) > -1) {
|
||||
try {
|
||||
cpuSampler.createPlugin();
|
||||
cpuSampler.startSampler();
|
||||
} catch (IOException e) {
|
||||
log.warn("Unable to start CPU sampler plugin. Reason: " + e.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
tpSampler.waitUntilDone();
|
||||
cpuSampler.waitUntilDone();
|
||||
|
||||
writer.closeReportWriter();
|
||||
}
|
||||
|
||||
public ThroughputSamplerTask getTpSampler() {
|
||||
return tpSampler;
|
||||
}
|
||||
|
||||
public void setTpSampler(ThroughputSamplerTask tpSampler) {
|
||||
this.tpSampler = tpSampler;
|
||||
}
|
||||
|
||||
public CpuSamplerTask getCpuSampler() {
|
||||
return cpuSampler;
|
||||
}
|
||||
|
||||
public void setCpuSampler(CpuSamplerTask cpuSampler) {
|
||||
this.cpuSampler = cpuSampler;
|
||||
}
|
||||
|
||||
public JmsFactoryProperties getFactory() {
|
||||
return factory;
|
||||
}
|
||||
|
||||
public void setFactory(JmsFactoryProperties factory) {
|
||||
this.factory = factory;
|
||||
}
|
||||
|
||||
public abstract JmsClientSystemProperties getSysTest();
|
||||
public abstract void setSysTest(JmsClientSystemProperties sysTestProps);
|
||||
public abstract JmsClientProperties getJmsClientProperties();
|
||||
|
||||
protected PerformanceReportWriter createPerfWriter() {
|
||||
if (getSysTest().getReportType().equalsIgnoreCase(JmsClientSystemProperties.REPORT_XML_FILE)) {
|
||||
String reportName;
|
||||
|
||||
if ((reportName = getSysTest().getReportName()) == null) {
|
||||
reportName = getSysTest().getClientPrefix() + "_" +
|
||||
"numClients" + getSysTest().getNumClients() + "_" +
|
||||
"numDests" + getSysTest().getTotalDests() + "_" +
|
||||
getSysTest().getDestDistro();
|
||||
}
|
||||
return new XmlFilePerfReportWriter(getSysTest().getReportDir(), reportName);
|
||||
} else if (getSysTest().getReportType().equalsIgnoreCase(JmsClientSystemProperties.REPORT_VERBOSE)) {
|
||||
return new VerbosePerfReportWriter();
|
||||
} else {
|
||||
// Use verbose if unknown report type
|
||||
return new VerbosePerfReportWriter();
|
||||
}
|
||||
}
|
||||
|
||||
protected void distributeDestinations(String distroType, int clientIndex, int numClients, int numDests) {
|
||||
if (distroType.equalsIgnoreCase(JmsClientSystemProperties.DEST_DISTRO_ALL)) {
|
||||
clientDestCount = numDests;
|
||||
clientDestIndex = 0;
|
||||
} else if (distroType.equalsIgnoreCase(JmsClientSystemProperties.DEST_DISTRO_EQUAL)) {
|
||||
int destPerClient = (numDests / numClients);
|
||||
// There are equal or more destinations per client
|
||||
if (destPerClient > 0) {
|
||||
clientDestCount = destPerClient;
|
||||
clientDestIndex = destPerClient * clientIndex;
|
||||
// If there are more clients than destinations, share destinations per client
|
||||
} else {
|
||||
clientDestCount = 1; // At most one destination per client
|
||||
clientDestIndex = clientIndex % numDests;
|
||||
}
|
||||
} else if (distroType.equalsIgnoreCase(JmsClientSystemProperties.DEST_DISTRO_DIVIDE)) {
|
||||
int destPerClient = (numDests / numClients);
|
||||
// There are equal or more destinations per client
|
||||
if (destPerClient > 0) {
|
||||
int remain = numDests % numClients;
|
||||
int nextIndex;
|
||||
if (clientIndex < remain) {
|
||||
destPerClient++;
|
||||
nextIndex = clientIndex * destPerClient;
|
||||
} else {
|
||||
nextIndex = (clientIndex * destPerClient) + remain;
|
||||
}
|
||||
|
||||
clientDestCount = destPerClient;
|
||||
clientDestIndex = nextIndex;
|
||||
|
||||
// If there are more clients than destinations, share destinations per client
|
||||
} else {
|
||||
clientDestCount = 1; // At most one destination per client
|
||||
clientDestIndex = clientIndex % numDests;
|
||||
}
|
||||
|
||||
// Send to all for unknown behavior
|
||||
} else {
|
||||
log.warn("Unknown destination distribution type: " + distroType);
|
||||
clientDestCount = numDests;
|
||||
clientDestIndex = 0;
|
||||
}
|
||||
}
|
||||
|
||||
protected ConnectionFactory loadJmsFactory(String spiClass, Properties factorySettings) throws JMSException {
|
||||
try {
|
||||
Class spi = Class.forName(spiClass);
|
||||
SPIConnectionFactory spiFactory = (SPIConnectionFactory)spi.newInstance();
|
||||
ConnectionFactory jmsFactory = spiFactory.createConnectionFactory(factorySettings);
|
||||
log.info("Created: " + jmsFactory.getClass().getName() + " using SPIConnectionFactory: " + spiFactory.getClass().getName());
|
||||
return jmsFactory;
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
throw new JMSException(e.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
protected abstract void runJmsClient(String clientName, int clientDestIndex, int clientDestCount);
|
||||
}
|
|
@ -16,26 +16,23 @@
|
|||
*/
|
||||
package org.apache.activemq.tool;
|
||||
|
||||
import org.apache.activemq.tool.sampler.MeasurableClient;
|
||||
|
||||
import javax.jms.ConnectionFactory;
|
||||
|
||||
import edu.emory.mathcs.backport.java.util.concurrent.atomic.AtomicLong;
|
||||
|
||||
public class JmsPerformanceSupport extends JmsClientSupport implements PerfMeasurable {
|
||||
|
||||
public abstract class AbstractJmsMeasurableClient extends AbstractJmsClient implements MeasurableClient {
|
||||
protected AtomicLong throughput = new AtomicLong(0);
|
||||
protected PerfEventListener listener = null;
|
||||
protected String clientName = null;
|
||||
|
||||
public AbstractJmsMeasurableClient( ConnectionFactory factory) {
|
||||
super( factory);
|
||||
}
|
||||
|
||||
public void reset() {
|
||||
setThroughput(0);
|
||||
}
|
||||
|
||||
public String getClientName() {
|
||||
return clientName;
|
||||
}
|
||||
|
||||
public void setClientName(String clientName) {
|
||||
this.clientName = clientName;
|
||||
}
|
||||
|
||||
public long getThroughput() {
|
||||
return throughput.get();
|
||||
}
|
||||
|
@ -51,12 +48,4 @@ public class JmsPerformanceSupport extends JmsClientSupport implements PerfMeasu
|
|||
public void incThroughput(long val) {
|
||||
throughput.addAndGet(val);
|
||||
}
|
||||
|
||||
public void setPerfEventListener(PerfEventListener listener) {
|
||||
this.listener = listener;
|
||||
}
|
||||
|
||||
public PerfEventListener getPerfEventListener() {
|
||||
return listener;
|
||||
}
|
||||
}
|
|
@ -1,212 +0,0 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool;
|
||||
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
|
||||
import javax.jms.ConnectionFactory;
|
||||
import javax.jms.Session;
|
||||
import javax.jms.Connection;
|
||||
import javax.jms.Destination;
|
||||
import javax.jms.JMSException;
|
||||
import java.util.Properties;
|
||||
|
||||
public class JmsClientSupport extends JmsFactorySupport {
|
||||
private static final Log log = LogFactory.getLog(JmsClientSupport.class);
|
||||
|
||||
public static final String DEFAULT_SPI_CLASS = "org.apache.activemq.tool.spi.ActiveMQPojoSPI";
|
||||
|
||||
private static final String PREFIX_CONFIG_CLIENT = "client.";
|
||||
public static final String SESSION_AUTO_ACKNOWLEDGE = "autoAck";
|
||||
public static final String SESSION_CLIENT_ACKNOWLEDGE = "clientAck";
|
||||
public static final String SESSION_DUPS_OK_ACKNOWLEDGE = "dupsAck";
|
||||
public static final String SESSION_TRANSACTED = "transacted";
|
||||
|
||||
protected Properties clientSettings = new Properties();
|
||||
protected Connection jmsConnection;
|
||||
protected Session jmsSession;
|
||||
|
||||
// Client settings
|
||||
protected String spiClass = DEFAULT_SPI_CLASS;
|
||||
protected boolean sessTransacted = false;
|
||||
protected String sessAckMode = SESSION_AUTO_ACKNOWLEDGE;
|
||||
protected String destName = "TEST.FOO";
|
||||
protected int destCount = 1;
|
||||
protected int destIndex = 0;
|
||||
protected boolean destComposite = false;
|
||||
|
||||
public ConnectionFactory createConnectionFactory() throws JMSException {
|
||||
return super.createConnectionFactory(getSpiClass());
|
||||
}
|
||||
|
||||
public Connection getConnection() throws JMSException {
|
||||
if (jmsConnection == null) {
|
||||
jmsConnection = createConnectionFactory().createConnection();
|
||||
}
|
||||
return jmsConnection;
|
||||
}
|
||||
|
||||
public Session getSession() throws JMSException {
|
||||
if (jmsSession == null) {
|
||||
int ackMode;
|
||||
if (getSessAckMode().equalsIgnoreCase(SESSION_AUTO_ACKNOWLEDGE)) {
|
||||
ackMode = Session.AUTO_ACKNOWLEDGE;
|
||||
} else if (getSessAckMode().equalsIgnoreCase(SESSION_CLIENT_ACKNOWLEDGE)) {
|
||||
ackMode = Session.CLIENT_ACKNOWLEDGE;
|
||||
} else if (getSessAckMode().equalsIgnoreCase(SESSION_DUPS_OK_ACKNOWLEDGE)) {
|
||||
ackMode = Session.DUPS_OK_ACKNOWLEDGE;
|
||||
} else if (getSessAckMode().equalsIgnoreCase(SESSION_TRANSACTED)) {
|
||||
ackMode = Session.SESSION_TRANSACTED;
|
||||
} else {
|
||||
ackMode = Session.AUTO_ACKNOWLEDGE;
|
||||
}
|
||||
jmsSession = getConnection().createSession(isSessTransacted(), ackMode);
|
||||
}
|
||||
return jmsSession;
|
||||
}
|
||||
|
||||
public Destination[] createDestination() throws JMSException {
|
||||
|
||||
if (isDestComposite()) {
|
||||
return new Destination[] {createCompositeDestination(getDestName(), getDestCount())};
|
||||
} else {
|
||||
Destination[] dest = new Destination[getDestCount()];
|
||||
for (int i=0; i<getDestCount(); i++) {
|
||||
dest[i] = createDestination(getDestName() + "." + (getDestIndex() + i));
|
||||
}
|
||||
|
||||
return dest;
|
||||
}
|
||||
}
|
||||
|
||||
public Destination createDestination(String name) throws JMSException {
|
||||
if (name.startsWith("queue://")) {
|
||||
return getSession().createQueue(name.substring("queue://".length()));
|
||||
} else if (name.startsWith("topic://")) {
|
||||
return getSession().createTopic(name.substring("topic://".length()));
|
||||
} else {
|
||||
return getSession().createTopic(name);
|
||||
}
|
||||
}
|
||||
|
||||
public Destination createCompositeDestination(String name, int count) throws JMSException {
|
||||
String compDestName = "";
|
||||
String simpleName;
|
||||
|
||||
if (name.startsWith("queue://")) {
|
||||
simpleName = name.substring("queue://".length());
|
||||
} else if (name.startsWith("topic://")) {
|
||||
simpleName = name.substring("topic://".length());
|
||||
} else {
|
||||
simpleName = name;
|
||||
}
|
||||
|
||||
int i;
|
||||
compDestName = name + ".0,"; // First destination
|
||||
for (i=1; i<count-1; i++) {
|
||||
compDestName += (simpleName + "." + i +",");
|
||||
}
|
||||
compDestName += (simpleName + "." + i); // Last destination (minus the comma)
|
||||
|
||||
return createDestination(compDestName);
|
||||
}
|
||||
|
||||
public String getSpiClass() {
|
||||
return spiClass;
|
||||
}
|
||||
|
||||
public void setSpiClass(String spiClass) {
|
||||
this.spiClass = spiClass;
|
||||
}
|
||||
|
||||
public boolean isSessTransacted() {
|
||||
return sessTransacted;
|
||||
}
|
||||
|
||||
public void setSessTransacted(boolean sessTransacted) {
|
||||
this.sessTransacted = sessTransacted;
|
||||
}
|
||||
|
||||
public String getSessAckMode() {
|
||||
return sessAckMode;
|
||||
}
|
||||
|
||||
public void setSessAckMode(String sessAckMode) {
|
||||
this.sessAckMode = sessAckMode;
|
||||
}
|
||||
|
||||
public String getDestName() {
|
||||
return destName;
|
||||
}
|
||||
|
||||
public void setDestName(String destName) {
|
||||
this.destName = destName;
|
||||
}
|
||||
|
||||
public int getDestCount() {
|
||||
return destCount;
|
||||
}
|
||||
|
||||
public void setDestCount(int destCount) {
|
||||
this.destCount = destCount;
|
||||
}
|
||||
|
||||
public int getDestIndex() {
|
||||
return destIndex;
|
||||
}
|
||||
|
||||
public void setDestIndex(int destIndex) {
|
||||
this.destIndex = destIndex;
|
||||
}
|
||||
|
||||
public boolean isDestComposite() {
|
||||
return destComposite;
|
||||
}
|
||||
|
||||
public void setDestComposite(boolean destComposite) {
|
||||
this.destComposite = destComposite;
|
||||
}
|
||||
|
||||
public Properties getClientSettings() {
|
||||
return clientSettings;
|
||||
}
|
||||
|
||||
public void setClientSettings(Properties clientSettings) {
|
||||
this.clientSettings = clientSettings;
|
||||
ReflectionUtil.configureClass(this, clientSettings);
|
||||
}
|
||||
|
||||
public Properties getSettings() {
|
||||
Properties allSettings = new Properties(clientSettings);
|
||||
allSettings.putAll(super.getSettings());
|
||||
return allSettings;
|
||||
}
|
||||
|
||||
public void setSettings(Properties settings) {
|
||||
super.setSettings(settings);
|
||||
ReflectionUtil.configureClass(this, clientSettings);
|
||||
}
|
||||
|
||||
public void setProperty(String key, String value) {
|
||||
if (key.startsWith(PREFIX_CONFIG_CLIENT)) {
|
||||
clientSettings.setProperty(key, value);
|
||||
} else {
|
||||
super.setProperty(key, value);
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,283 +0,0 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool;
|
||||
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
import org.apache.activemq.tool.reports.VerbosePerfReportWriter;
|
||||
import org.apache.activemq.tool.reports.PerformanceReportWriter;
|
||||
import org.apache.activemq.tool.reports.XmlFilePerfReportWriter;
|
||||
|
||||
import java.util.Properties;
|
||||
import java.util.Iterator;
|
||||
|
||||
public abstract class JmsClientSystemSupport {
|
||||
private static final Log log = LogFactory.getLog(JmsClientSystemSupport.class);
|
||||
|
||||
public static final String PREFIX_CONFIG_SYSTEM_TEST = "sysTest.";
|
||||
public static final String DEST_DISTRO_ALL = "all"; // Each client will send/receive to all destination;
|
||||
public static final String DEST_DISTRO_EQUAL = "equal"; // Equally divide the number of destinations to the number of clients
|
||||
public static final String DEST_DISTRO_DIVIDE = "divide"; // Divide the destination among the clients, even if some have more destination than others
|
||||
public static final String REPORT_VERBOSE = "verbose";
|
||||
public static final String REPORT_XML_FILE = "xml";
|
||||
|
||||
protected Properties sysTestSettings = new Properties();
|
||||
protected Properties samplerSettings = new Properties();
|
||||
protected Properties jmsClientSettings = new Properties();
|
||||
protected ThreadGroup clientThreadGroup;
|
||||
protected PerfMeasurementTool performanceSampler;
|
||||
|
||||
protected String reportType = REPORT_XML_FILE;
|
||||
protected String reportDirectory = "./";
|
||||
protected String reportName = null;
|
||||
|
||||
protected String clientName = null;
|
||||
protected int numClients = 1;
|
||||
protected int totalDests = 1;
|
||||
protected String destDistro = DEST_DISTRO_ALL;
|
||||
|
||||
public void runSystemTest() {
|
||||
// Create performance sampler
|
||||
performanceSampler = new PerfMeasurementTool();
|
||||
performanceSampler.setSamplerSettings(samplerSettings);
|
||||
|
||||
PerformanceReportWriter writer = createPerfWriter();
|
||||
performanceSampler.setPerfWriter(writer);
|
||||
|
||||
writer.openReportWriter();
|
||||
writer.writeProperties("testProperties", getSettings());
|
||||
|
||||
clientThreadGroup = new ThreadGroup(getThreadGroupName());
|
||||
for (int i=0; i<getNumClients(); i++) {
|
||||
final Properties clientSettings = new Properties();
|
||||
clientSettings.putAll(getJmsClientSettings());
|
||||
distributeDestinations(getDestDistro(), i, getNumClients(), getTotalDests(), clientSettings);
|
||||
|
||||
final String clientName = getClientName() + i;
|
||||
Thread t = new Thread(clientThreadGroup, new Runnable() {
|
||||
public void run() {
|
||||
runJmsClient(clientName, clientSettings);
|
||||
}
|
||||
});
|
||||
t.setName(getThreadName() + i);
|
||||
t.start();
|
||||
}
|
||||
|
||||
performanceSampler.startSampler();
|
||||
performanceSampler.waitForSamplerToFinish(0);
|
||||
|
||||
writer.closeReportWriter();
|
||||
}
|
||||
|
||||
public PerfMeasurementTool getPerformanceSampler() {
|
||||
return performanceSampler;
|
||||
}
|
||||
|
||||
public void setPerformanceSampler(PerfMeasurementTool performanceSampler) {
|
||||
this.performanceSampler = performanceSampler;
|
||||
}
|
||||
|
||||
public Properties getSettings() {
|
||||
Properties allSettings = new Properties();
|
||||
allSettings.putAll(sysTestSettings);
|
||||
allSettings.putAll(samplerSettings);
|
||||
allSettings.putAll(jmsClientSettings);
|
||||
return allSettings;
|
||||
}
|
||||
|
||||
public void setSettings(Properties settings) {
|
||||
for (Iterator i=settings.keySet().iterator(); i.hasNext();) {
|
||||
String key = (String)i.next();
|
||||
String val = settings.getProperty(key);
|
||||
setProperty(key, val);
|
||||
}
|
||||
ReflectionUtil.configureClass(this, sysTestSettings);
|
||||
}
|
||||
|
||||
public void setProperty(String key, String value) {
|
||||
if (key.startsWith(PREFIX_CONFIG_SYSTEM_TEST)) {
|
||||
sysTestSettings.setProperty(key, value);
|
||||
} else if (key.startsWith(PerfMeasurementTool.PREFIX_CONFIG_SYSTEM_TEST)) {
|
||||
samplerSettings.setProperty(key, value);
|
||||
} else {
|
||||
jmsClientSettings.setProperty(key, value);
|
||||
}
|
||||
}
|
||||
|
||||
public String getReportDirectory(){
|
||||
return reportDirectory;
|
||||
}
|
||||
|
||||
public void setReportDirectory(String reportDirectory){
|
||||
this.reportDirectory = reportDirectory;
|
||||
}
|
||||
|
||||
public Properties getSysTestSettings() {
|
||||
return sysTestSettings;
|
||||
}
|
||||
|
||||
public void setSysTestSettings(Properties sysTestSettings) {
|
||||
this.sysTestSettings = sysTestSettings;
|
||||
ReflectionUtil.configureClass(this, sysTestSettings);
|
||||
}
|
||||
|
||||
public Properties getSamplerSettings() {
|
||||
return samplerSettings;
|
||||
}
|
||||
|
||||
public void setSamplerSettings(Properties samplerSettings) {
|
||||
this.samplerSettings = samplerSettings;
|
||||
}
|
||||
|
||||
public Properties getJmsClientSettings() {
|
||||
return jmsClientSettings;
|
||||
}
|
||||
|
||||
public void setJmsClientSettings(Properties jmsClientSettings) {
|
||||
this.jmsClientSettings = jmsClientSettings;
|
||||
}
|
||||
|
||||
public int getNumClients() {
|
||||
return numClients;
|
||||
}
|
||||
|
||||
public void setNumClients(int numClients) {
|
||||
this.numClients = numClients;
|
||||
}
|
||||
|
||||
public String getDestDistro() {
|
||||
return destDistro;
|
||||
}
|
||||
|
||||
public void setDestDistro(String destDistro) {
|
||||
this.destDistro = destDistro;
|
||||
}
|
||||
|
||||
public int getTotalDests() {
|
||||
return totalDests;
|
||||
}
|
||||
|
||||
public void setTotalDests(int totalDests) {
|
||||
this.totalDests = totalDests;
|
||||
}
|
||||
|
||||
public String getReportName() {
|
||||
if (reportName == null) {
|
||||
return "clientPerformanceReport.xml";
|
||||
} else {
|
||||
return reportName;
|
||||
}
|
||||
}
|
||||
|
||||
public void setReportName(String reportName) {
|
||||
this.reportName = reportName;
|
||||
}
|
||||
|
||||
public String getReportType() {
|
||||
return reportType;
|
||||
}
|
||||
|
||||
public void setReportType(String reportType) {
|
||||
this.reportType = reportType;
|
||||
}
|
||||
|
||||
public String getClientName() {
|
||||
if (clientName == null) {
|
||||
return "JMS Client: ";
|
||||
} else {
|
||||
return clientName;
|
||||
}
|
||||
}
|
||||
|
||||
public void setClientName(String clientName) {
|
||||
this.clientName = clientName;
|
||||
}
|
||||
|
||||
protected PerformanceReportWriter createPerfWriter() {
|
||||
if (reportType.equalsIgnoreCase(REPORT_XML_FILE)) {
|
||||
return new XmlFilePerfReportWriter(getReportDirectory(), getReportName());
|
||||
} else if (reportType.equalsIgnoreCase(REPORT_VERBOSE)) {
|
||||
return new VerbosePerfReportWriter();
|
||||
} else {
|
||||
// Use verbose if unknown report type
|
||||
return new VerbosePerfReportWriter();
|
||||
}
|
||||
}
|
||||
|
||||
protected void distributeDestinations(String distroType, int clientIndex, int numClients, int numDests, Properties clientSettings) {
|
||||
if (distroType.equalsIgnoreCase(DEST_DISTRO_ALL)) {
|
||||
clientSettings.setProperty(getDestCountKey(), String.valueOf(numDests));
|
||||
clientSettings.setProperty(getDestIndexKey(), "0");
|
||||
} else if (distroType.equalsIgnoreCase(DEST_DISTRO_EQUAL)) {
|
||||
int destPerClient = (numDests / numClients);
|
||||
// There are equal or more destinations per client
|
||||
if (destPerClient > 0) {
|
||||
clientSettings.setProperty(getDestCountKey(), String.valueOf(destPerClient));
|
||||
clientSettings.setProperty(getDestIndexKey(), String.valueOf(destPerClient * clientIndex));
|
||||
|
||||
// If there are more clients than destinations, share destinations per client
|
||||
} else {
|
||||
clientSettings.setProperty(getDestCountKey(), "1"); // At most one destination per client
|
||||
clientSettings.setProperty(getDestIndexKey(), String.valueOf(clientIndex % numDests));
|
||||
}
|
||||
} else if (distroType.equalsIgnoreCase(DEST_DISTRO_DIVIDE)) {
|
||||
int destPerClient = (numDests / numClients);
|
||||
// There are equal or more destinations per client
|
||||
if (destPerClient > 0) {
|
||||
int remain = numDests % numClients;
|
||||
int nextIndex;
|
||||
if (clientIndex < remain) {
|
||||
destPerClient++;
|
||||
nextIndex = clientIndex * destPerClient;
|
||||
} else {
|
||||
nextIndex = (clientIndex * destPerClient) + remain;
|
||||
}
|
||||
|
||||
clientSettings.setProperty(getDestCountKey(), String.valueOf(destPerClient));
|
||||
clientSettings.setProperty(getDestIndexKey(), String.valueOf(nextIndex));
|
||||
|
||||
// If there are more clients than destinations, share destinations per client
|
||||
} else {
|
||||
clientSettings.setProperty(getDestCountKey(), "1"); // At most one destination per client
|
||||
clientSettings.setProperty(getDestIndexKey(), String.valueOf(clientIndex % numDests));
|
||||
}
|
||||
|
||||
// Send to all for unknown behavior
|
||||
} else {
|
||||
clientSettings.setProperty(getDestCountKey(), String.valueOf(numDests));
|
||||
clientSettings.setProperty(getDestIndexKey(), "0");
|
||||
}
|
||||
}
|
||||
|
||||
protected abstract void runJmsClient(String clientName, Properties clientSettings);
|
||||
|
||||
protected String getThreadName() {
|
||||
return "JMS Client Thread: ";
|
||||
}
|
||||
|
||||
protected String getThreadGroupName() {
|
||||
return "JMS Clients Thread Group";
|
||||
}
|
||||
|
||||
protected String getDestCountKey() {
|
||||
return "client.destCount";
|
||||
}
|
||||
|
||||
protected String getDestIndexKey() {
|
||||
return "client.destIndex";
|
||||
}
|
||||
}
|
|
@ -14,176 +14,195 @@
|
|||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package org.apache.activemq.tool;
|
||||
|
||||
import edu.emory.mathcs.backport.java.util.concurrent.atomic.AtomicInteger;
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.activemq.tool.properties.JmsConsumerProperties;
|
||||
import org.apache.activemq.tool.properties.JmsClientProperties;
|
||||
|
||||
import java.util.Properties;
|
||||
|
||||
import javax.jms.MessageConsumer;
|
||||
import javax.jms.JMSException;
|
||||
import javax.jms.ConnectionFactory;
|
||||
import javax.jms.Connection;
|
||||
import javax.jms.Destination;
|
||||
import javax.jms.JMSException;
|
||||
import javax.jms.Message;
|
||||
import javax.jms.MessageConsumer;
|
||||
import javax.jms.MessageListener;
|
||||
import javax.jms.Topic;
|
||||
|
||||
public class JmsConsumerClient extends JmsPerformanceSupport {
|
||||
import edu.emory.mathcs.backport.java.util.concurrent.atomic.AtomicInteger;
|
||||
|
||||
public class JmsConsumerClient extends AbstractJmsMeasurableClient {
|
||||
private static final Log log = LogFactory.getLog(JmsConsumerClient.class);
|
||||
|
||||
private static final String PREFIX_CONFIG_CONSUMER = "consumer.";
|
||||
public static final String TIME_BASED_RECEIVING = "time";
|
||||
public static final String COUNT_BASED_RECEIVING = "count";
|
||||
|
||||
protected Properties jmsConsumerSettings = new Properties();
|
||||
protected MessageConsumer jmsConsumer;
|
||||
protected JmsConsumerProperties client;
|
||||
|
||||
protected boolean durable = false;
|
||||
protected boolean asyncRecv = true;
|
||||
public JmsConsumerClient(ConnectionFactory factory) {
|
||||
this(new JmsConsumerProperties(), factory);
|
||||
}
|
||||
|
||||
protected long recvCount = 1000000; // Receive a million messages by default
|
||||
protected long recvDuration = 5 * 60 * 1000; // Receive for 5 mins by default
|
||||
protected String recvType = TIME_BASED_RECEIVING;
|
||||
public JmsConsumerClient(JmsConsumerProperties clientProps, ConnectionFactory factory) {
|
||||
super(factory);
|
||||
client = clientProps;
|
||||
}
|
||||
|
||||
public void receiveMessages() throws JMSException {
|
||||
if (listener != null) {
|
||||
listener.onConfigEnd(this);
|
||||
}
|
||||
if (isAsyncRecv()) {
|
||||
receiveAsyncMessages();
|
||||
if (client.isAsyncRecv()) {
|
||||
if (client.getRecvType().equalsIgnoreCase(JmsConsumerProperties.TIME_BASED_RECEIVING)) {
|
||||
receiveAsyncTimeBasedMessages(client.getRecvDuration());
|
||||
} else {
|
||||
receiveAsyncCountBasedMessages(client.getRecvCount());
|
||||
}
|
||||
} else {
|
||||
receiveSyncMessages();
|
||||
if (client.getRecvType().equalsIgnoreCase(JmsConsumerProperties.TIME_BASED_RECEIVING)) {
|
||||
receiveSyncTimeBasedMessages(client.getRecvDuration());
|
||||
} else {
|
||||
receiveSyncCountBasedMessages(client.getRecvCount());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void receiveSyncMessages() throws JMSException {
|
||||
public void receiveMessages(int destCount) throws JMSException {
|
||||
this.destCount = destCount;
|
||||
receiveMessages();
|
||||
}
|
||||
|
||||
public void receiveMessages(int destIndex, int destCount) throws JMSException {
|
||||
this.destIndex = destIndex;
|
||||
receiveMessages(destCount);
|
||||
}
|
||||
|
||||
public void receiveSyncTimeBasedMessages(long duration) throws JMSException {
|
||||
if (getJmsConsumer() == null) {
|
||||
createJmsConsumer();
|
||||
}
|
||||
|
||||
try {
|
||||
getConnection().start();
|
||||
if (listener != null) {
|
||||
listener.onConsumeStart(this);
|
||||
}
|
||||
if (getRecvType().equalsIgnoreCase(TIME_BASED_RECEIVING)) {
|
||||
long endTime = System.currentTimeMillis() + getRecvDuration();
|
||||
while (System.currentTimeMillis() < endTime) {
|
||||
getJmsConsumer().receive();
|
||||
incThroughput();
|
||||
}
|
||||
} else {
|
||||
int count = 0;
|
||||
while (count < getRecvCount()) {
|
||||
getJmsConsumer().receive();
|
||||
incThroughput();
|
||||
count++;
|
||||
}
|
||||
|
||||
log.info("Starting to synchronously receive messages for " + duration + " ms...");
|
||||
long endTime = System.currentTimeMillis() + duration;
|
||||
while (System.currentTimeMillis() < endTime) {
|
||||
getJmsConsumer().receive();
|
||||
incThroughput();
|
||||
}
|
||||
} finally {
|
||||
if (listener != null) {
|
||||
listener.onConsumeEnd(this);
|
||||
}
|
||||
getConnection().close();
|
||||
}
|
||||
}
|
||||
|
||||
public void receiveAsyncMessages() throws JMSException {
|
||||
public void receiveSyncCountBasedMessages(long count) throws JMSException {
|
||||
if (getJmsConsumer() == null) {
|
||||
createJmsConsumer();
|
||||
}
|
||||
|
||||
if (getRecvType().equalsIgnoreCase(TIME_BASED_RECEIVING)) {
|
||||
getJmsConsumer().setMessageListener(new MessageListener() {
|
||||
public void onMessage(Message msg) {
|
||||
incThroughput();
|
||||
}
|
||||
});
|
||||
try {
|
||||
getConnection().start();
|
||||
log.info("Starting to synchronously receive " + count + " messages...");
|
||||
|
||||
try {
|
||||
getConnection().start();
|
||||
if (listener != null) {
|
||||
listener.onConsumeStart(this);
|
||||
}
|
||||
try {
|
||||
Thread.sleep(getRecvDuration());
|
||||
} catch (InterruptedException e) {
|
||||
throw new JMSException("JMS consumer thread sleep has been interrupted. Message: " + e.getMessage());
|
||||
}
|
||||
} finally {
|
||||
if (listener != null) {
|
||||
listener.onConsumeEnd(this);
|
||||
}
|
||||
getConnection().close();
|
||||
}
|
||||
} else {
|
||||
final AtomicInteger count = new AtomicInteger(0);
|
||||
getJmsConsumer().setMessageListener(new MessageListener() {
|
||||
public void onMessage(Message msg) {
|
||||
incThroughput();
|
||||
count.incrementAndGet();
|
||||
count.notify();
|
||||
}
|
||||
});
|
||||
|
||||
try {
|
||||
getConnection().start();
|
||||
if (listener != null) {
|
||||
listener.onConsumeStart(this);
|
||||
}
|
||||
try {
|
||||
while (count.get() < getRecvCount()) {
|
||||
count.wait();
|
||||
}
|
||||
} catch (InterruptedException e) {
|
||||
throw new JMSException("JMS consumer thread wait has been interrupted. Message: " + e.getMessage());
|
||||
}
|
||||
} finally {
|
||||
if (listener != null) {
|
||||
listener.onConsumeEnd(this);
|
||||
}
|
||||
getConnection().close();
|
||||
int recvCount = 0;
|
||||
while (recvCount < count) {
|
||||
getJmsConsumer().receive();
|
||||
incThroughput();
|
||||
recvCount++;
|
||||
}
|
||||
} finally {
|
||||
getConnection().close();
|
||||
}
|
||||
}
|
||||
|
||||
public Connection getConnection() throws JMSException {
|
||||
Connection c = super.getConnection();
|
||||
if (c.getClientID() == null && isDurable()) {
|
||||
c.setClientID(getClientName());
|
||||
}
|
||||
return c;
|
||||
|
||||
public void receiveAsyncTimeBasedMessages(long duration) throws JMSException {
|
||||
if (getJmsConsumer() == null) {
|
||||
createJmsConsumer();
|
||||
}
|
||||
|
||||
getJmsConsumer().setMessageListener(new MessageListener() {
|
||||
public void onMessage(Message msg) {
|
||||
incThroughput();
|
||||
}
|
||||
});
|
||||
|
||||
try {
|
||||
getConnection().start();
|
||||
log.info("Starting to asynchronously receive messages for " + duration + " ms...");
|
||||
try {
|
||||
Thread.sleep(duration);
|
||||
} catch (InterruptedException e) {
|
||||
throw new JMSException("JMS consumer thread sleep has been interrupted. Message: " + e.getMessage());
|
||||
}
|
||||
} finally {
|
||||
getConnection().close();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public void receiveAsyncCountBasedMessages(long count) throws JMSException {
|
||||
if (getJmsConsumer() == null) {
|
||||
createJmsConsumer();
|
||||
}
|
||||
|
||||
final AtomicInteger recvCount = new AtomicInteger(0);
|
||||
getJmsConsumer().setMessageListener(new MessageListener() {
|
||||
public void onMessage(Message msg) {
|
||||
incThroughput();
|
||||
recvCount.incrementAndGet();
|
||||
recvCount.notify();
|
||||
}
|
||||
});
|
||||
|
||||
try {
|
||||
getConnection().start();
|
||||
log.info("Starting to asynchronously receive " + client.getRecvCount() + " messages...");
|
||||
try {
|
||||
while (recvCount.get() < count) {
|
||||
recvCount.wait();
|
||||
}
|
||||
} catch (InterruptedException e) {
|
||||
throw new JMSException("JMS consumer thread wait has been interrupted. Message: " + e.getMessage());
|
||||
}
|
||||
} finally {
|
||||
getConnection().close();
|
||||
}
|
||||
}
|
||||
|
||||
public Connection getConnection() throws JMSException {
|
||||
Connection c = super.getConnection();
|
||||
if (c.getClientID() == null && client.isDurable()) {
|
||||
c.setClientID(getClientName());
|
||||
}
|
||||
return c;
|
||||
}
|
||||
|
||||
public MessageConsumer createJmsConsumer() throws JMSException {
|
||||
Destination[] dest = createDestination();
|
||||
Destination[] dest = createDestination(destIndex, destCount);
|
||||
return createJmsConsumer(dest[0]);
|
||||
}
|
||||
|
||||
public MessageConsumer createJmsConsumer(Destination dest) throws JMSException {
|
||||
if (isDurable()) {
|
||||
if (client.isDurable()) {
|
||||
String clientName = getClientName();
|
||||
if (clientName == null) {
|
||||
clientName = "JmsConsumer";
|
||||
}
|
||||
log.info("Creating durable subscriber to: " + dest.toString());
|
||||
jmsConsumer = getSession().createDurableSubscriber((Topic) dest, clientName);
|
||||
} else {
|
||||
log.info("Creating non-durable consumer to: " + dest.toString());
|
||||
jmsConsumer = getSession().createConsumer(dest);
|
||||
}
|
||||
return jmsConsumer;
|
||||
}
|
||||
|
||||
public MessageConsumer createJmsConsumer(Destination dest, String selector, boolean noLocal) throws JMSException {
|
||||
if (isDurable()) {
|
||||
if (client.isDurable()) {
|
||||
String clientName = getClientName();
|
||||
if (clientName == null) {
|
||||
clientName = "JmsConsumer";
|
||||
}
|
||||
log.info("Creating durable subscriber to: " + dest.toString());
|
||||
jmsConsumer = getSession().createDurableSubscriber((Topic) dest, clientName, selector, noLocal);
|
||||
} else {
|
||||
log.info("Creating non-durable consumer to: " + dest.toString());
|
||||
jmsConsumer = getSession().createConsumer(dest, selector, noLocal);
|
||||
}
|
||||
return jmsConsumer;
|
||||
|
@ -193,101 +212,11 @@ public class JmsConsumerClient extends JmsPerformanceSupport {
|
|||
return jmsConsumer;
|
||||
}
|
||||
|
||||
public Properties getJmsConsumerSettings() {
|
||||
return jmsConsumerSettings;
|
||||
public JmsClientProperties getClient() {
|
||||
return client;
|
||||
}
|
||||
|
||||
public void setJmsConsumerSettings(Properties jmsConsumerSettings) {
|
||||
this.jmsConsumerSettings = jmsConsumerSettings;
|
||||
ReflectionUtil.configureClass(this, jmsConsumerSettings);
|
||||
}
|
||||
|
||||
public boolean isDurable() {
|
||||
return durable;
|
||||
}
|
||||
|
||||
public void setDurable(boolean durable) {
|
||||
this.durable = durable;
|
||||
}
|
||||
|
||||
public boolean isAsyncRecv() {
|
||||
return asyncRecv;
|
||||
}
|
||||
|
||||
public void setAsyncRecv(boolean asyncRecv) {
|
||||
this.asyncRecv = asyncRecv;
|
||||
}
|
||||
|
||||
public long getRecvCount() {
|
||||
return recvCount;
|
||||
}
|
||||
|
||||
public void setRecvCount(long recvCount) {
|
||||
this.recvCount = recvCount;
|
||||
}
|
||||
|
||||
public long getRecvDuration() {
|
||||
return recvDuration;
|
||||
}
|
||||
|
||||
public void setRecvDuration(long recvDuration) {
|
||||
this.recvDuration = recvDuration;
|
||||
}
|
||||
|
||||
public String getRecvType() {
|
||||
return recvType;
|
||||
}
|
||||
|
||||
public void setRecvType(String recvType) {
|
||||
this.recvType = recvType;
|
||||
}
|
||||
|
||||
public Properties getSettings() {
|
||||
Properties allSettings = new Properties(jmsConsumerSettings);
|
||||
allSettings.putAll(super.getSettings());
|
||||
return allSettings;
|
||||
}
|
||||
|
||||
public void setSettings(Properties settings) {
|
||||
super.setSettings(settings);
|
||||
ReflectionUtil.configureClass(this, jmsConsumerSettings);
|
||||
}
|
||||
|
||||
public void setProperty(String key, String value) {
|
||||
if (key.startsWith(PREFIX_CONFIG_CONSUMER)) {
|
||||
jmsConsumerSettings.setProperty(key, value);
|
||||
} else {
|
||||
super.setProperty(key, value);
|
||||
}
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws JMSException {
|
||||
|
||||
Properties samplerSettings = new Properties();
|
||||
Properties consumerSettings = new Properties();
|
||||
|
||||
for (int i = 0; i < args.length; i++) {
|
||||
// Get property define options only
|
||||
int index = args[i].indexOf("=");
|
||||
String key = args[i].substring(0, index);
|
||||
String val = args[i].substring(index + 1);
|
||||
if (key.startsWith("sampler.")) {
|
||||
samplerSettings.setProperty(key, val);
|
||||
} else {
|
||||
consumerSettings.setProperty(key, val);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
JmsConsumerClient client = new JmsConsumerClient();
|
||||
client.setSettings(consumerSettings);
|
||||
|
||||
PerfMeasurementTool sampler = new PerfMeasurementTool();
|
||||
sampler.setSamplerSettings(samplerSettings);
|
||||
sampler.registerClient(client);
|
||||
sampler.startSampler();
|
||||
|
||||
client.setPerfEventListener(sampler);
|
||||
client.receiveMessages();
|
||||
public void setClient(JmsClientProperties clientProps) {
|
||||
client = (JmsConsumerProperties)clientProps;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -16,74 +16,72 @@
|
|||
*/
|
||||
package org.apache.activemq.tool;
|
||||
|
||||
import org.apache.activemq.tool.properties.JmsClientSystemProperties;
|
||||
import org.apache.activemq.tool.properties.JmsConsumerSystemProperties;
|
||||
import org.apache.activemq.tool.properties.JmsConsumerProperties;
|
||||
import org.apache.activemq.tool.properties.JmsClientProperties;
|
||||
import org.apache.activemq.tool.sampler.ThroughputSamplerTask;
|
||||
|
||||
import javax.jms.JMSException;
|
||||
import java.util.Properties;
|
||||
|
||||
public class JmsConsumerSystem extends JmsClientSystemSupport {
|
||||
public class JmsConsumerSystem extends AbstractJmsClientSystem {
|
||||
protected JmsConsumerSystemProperties sysTest = new JmsConsumerSystemProperties();
|
||||
protected JmsConsumerProperties consumer = new JmsConsumerProperties();
|
||||
|
||||
public String getReportName() {
|
||||
if (reportName == null) {
|
||||
return "JmsConsumer_Client" + getNumClients() + "_Dest" + getTotalDests() + "_" + getDestDistro() + ".xml";
|
||||
} else {
|
||||
return reportName;
|
||||
}
|
||||
public JmsClientSystemProperties getSysTest() {
|
||||
return sysTest;
|
||||
}
|
||||
|
||||
public String getClientName() {
|
||||
if (clientName == null) {
|
||||
return "JmsConsumer";
|
||||
} else {
|
||||
return clientName;
|
||||
}
|
||||
public void setSysTest(JmsClientSystemProperties sysTestProps) {
|
||||
sysTest = (JmsConsumerSystemProperties)sysTestProps;
|
||||
}
|
||||
|
||||
protected void runJmsClient(String clientName, Properties clientSettings) {
|
||||
PerfMeasurementTool sampler = getPerformanceSampler();
|
||||
public JmsClientProperties getJmsClientProperties() {
|
||||
return getConsumer();
|
||||
}
|
||||
|
||||
JmsConsumerClient consumer = new JmsConsumerClient();
|
||||
consumer.setSettings(clientSettings);
|
||||
consumer.setClientName(clientName);
|
||||
public JmsConsumerProperties getConsumer() {
|
||||
return consumer;
|
||||
}
|
||||
|
||||
public void setConsumer(JmsConsumerProperties consumer) {
|
||||
this.consumer = consumer;
|
||||
}
|
||||
|
||||
protected void runJmsClient(String clientName, int clientDestIndex, int clientDestCount) {
|
||||
ThroughputSamplerTask sampler = getTpSampler();
|
||||
|
||||
JmsConsumerClient consumerClient = new JmsConsumerClient(consumer, jmsConnFactory);
|
||||
consumerClient.setClientName(clientName);
|
||||
|
||||
if (sampler != null) {
|
||||
sampler.registerClient(consumer);
|
||||
consumer.setPerfEventListener(sampler);
|
||||
sampler.registerClient(consumerClient);
|
||||
}
|
||||
|
||||
try {
|
||||
consumer.receiveMessages();
|
||||
consumerClient.receiveMessages(clientDestIndex, clientDestCount);
|
||||
} catch (JMSException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
protected String getThreadName() {
|
||||
return "JMS Consumer Thread: ";
|
||||
}
|
||||
|
||||
protected String getThreadGroupName() {
|
||||
return "JMS Consumer Thread Group";
|
||||
}
|
||||
|
||||
protected String getDestCountKey() {
|
||||
return "consumer.destCount";
|
||||
}
|
||||
|
||||
protected String getDestIndexKey() {
|
||||
return "consumer.destIndex";
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws JMSException {
|
||||
Properties sysSettings = new Properties();
|
||||
for (int i = 0; i < args.length; i++) {
|
||||
// Get property define options only
|
||||
public static void main(String[] args) {
|
||||
Properties props = new Properties();
|
||||
for (int i=0; i<args.length; i++) {
|
||||
int index = args[i].indexOf("=");
|
||||
String key = args[i].substring(0, index);
|
||||
String val = args[i].substring(index + 1);
|
||||
sysSettings.setProperty(key, val);
|
||||
props.setProperty(key, val);
|
||||
}
|
||||
|
||||
JmsConsumerSystem sysTest = new JmsConsumerSystem();
|
||||
sysTest.setSettings(sysSettings);
|
||||
sysTest.runSystemTest();
|
||||
JmsConsumerSystem sys = new JmsConsumerSystem();
|
||||
sys.configureProperties(props);
|
||||
|
||||
try {
|
||||
sys.runSystemTest();
|
||||
} catch (JMSException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,102 +0,0 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool;
|
||||
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
import org.apache.activemq.tool.spi.SPIConnectionFactory;
|
||||
|
||||
import javax.jms.ConnectionFactory;
|
||||
import javax.jms.JMSException;
|
||||
import java.util.Properties;
|
||||
import java.util.Iterator;
|
||||
|
||||
public class JmsFactorySupport {
|
||||
private static final Log log = LogFactory.getLog(JmsFactorySupport.class);
|
||||
|
||||
private static final String PREFIX_CONFIG_FACTORY = "factory.";
|
||||
|
||||
private SPIConnectionFactory spiFactory;
|
||||
protected ConnectionFactory jmsFactory;
|
||||
protected Properties jmsFactorySettings = new Properties();
|
||||
|
||||
public ConnectionFactory createConnectionFactory(String spiClass) throws JMSException {
|
||||
jmsFactory = loadJmsFactory(spiClass, jmsFactorySettings);
|
||||
return jmsFactory;
|
||||
}
|
||||
|
||||
protected ConnectionFactory loadJmsFactory(String spiClass, Properties factorySettings) throws JMSException {
|
||||
try {
|
||||
Class spi = Class.forName(spiClass);
|
||||
spiFactory = (SPIConnectionFactory)spi.newInstance();
|
||||
ConnectionFactory jmsFactory = spiFactory.createConnectionFactory(factorySettings);
|
||||
log.debug("Created: " + jmsFactory.getClass().getName() + " using SPIConnectionFactory: " + spiFactory.getClass().getName());
|
||||
return jmsFactory;
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
throw new JMSException(e.getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
public ConnectionFactory getJmsFactory() {
|
||||
return jmsFactory;
|
||||
}
|
||||
|
||||
public Properties getJmsFactorySettings() {
|
||||
return jmsFactorySettings;
|
||||
}
|
||||
|
||||
public void setJmsFactorySettings(Properties jmsFactorySettings) {
|
||||
this.jmsFactorySettings = jmsFactorySettings;
|
||||
if (spiFactory != null) {
|
||||
try {
|
||||
spiFactory.configureConnectionFactory(jmsFactory, jmsFactorySettings);
|
||||
} catch (Exception e) {
|
||||
log.warn(e);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public Properties getSettings() {
|
||||
return jmsFactorySettings;
|
||||
}
|
||||
|
||||
public void setSettings(Properties settings) {
|
||||
for (Iterator i=settings.keySet().iterator(); i.hasNext();) {
|
||||
String key = (String)i.next();
|
||||
String val = settings.getProperty(key);
|
||||
setProperty(key, val);
|
||||
}
|
||||
|
||||
if (spiFactory != null) {
|
||||
try {
|
||||
spiFactory.configureConnectionFactory(jmsFactory, jmsFactorySettings);
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
log.warn(e);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void setProperty(String key, String value) {
|
||||
if (key.startsWith(PREFIX_CONFIG_FACTORY)) {
|
||||
jmsFactorySettings.setProperty(key, value);
|
||||
} else {
|
||||
log.warn("Unknown setting: " + key + "=" + value);
|
||||
}
|
||||
}
|
||||
}
|
|
@ -16,51 +16,60 @@
|
|||
*/
|
||||
package org.apache.activemq.tool;
|
||||
|
||||
import org.apache.activemq.tool.properties.JmsProducerProperties;
|
||||
import org.apache.activemq.tool.properties.JmsClientProperties;
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
|
||||
import javax.jms.*;
|
||||
|
||||
import javax.jms.ConnectionFactory;
|
||||
import javax.jms.MessageProducer;
|
||||
import javax.jms.TextMessage;
|
||||
import javax.jms.JMSException;
|
||||
import javax.jms.Destination;
|
||||
import javax.jms.DeliveryMode;
|
||||
import java.util.Arrays;
|
||||
import java.util.Properties;
|
||||
|
||||
public class JmsProducerClient extends JmsPerformanceSupport {
|
||||
public class JmsProducerClient extends AbstractJmsMeasurableClient {
|
||||
private static final Log log = LogFactory.getLog(JmsProducerClient.class);
|
||||
|
||||
private static final String PREFIX_CONFIG_PRODUCER = "producer.";
|
||||
public static final String TIME_BASED_SENDING = "time";
|
||||
public static final String COUNT_BASED_SENDING = "count";
|
||||
public static final String DELIVERY_MODE_PERSISTENT = "persistent";
|
||||
public static final String DELIVERY_MODE_NON_PERSISTENT = "nonpersistent";
|
||||
|
||||
protected Properties jmsProducerSettings = new Properties();
|
||||
protected JmsProducerProperties client;
|
||||
protected MessageProducer jmsProducer;
|
||||
protected TextMessage jmsTextMessage;
|
||||
|
||||
protected String deliveryMode = DELIVERY_MODE_NON_PERSISTENT;
|
||||
protected int messageSize = 1024; // Send 1kb messages by default
|
||||
protected long sendCount = 1000000; // Send a million messages by default
|
||||
protected long sendDuration = 5 * 60 * 1000; // Send for 5 mins by default
|
||||
protected String sendType = TIME_BASED_SENDING;
|
||||
public JmsProducerClient(ConnectionFactory factory) {
|
||||
this(new JmsProducerProperties(), factory);
|
||||
}
|
||||
|
||||
public JmsProducerClient(JmsProducerProperties clientProps, ConnectionFactory factory) {
|
||||
super(factory);
|
||||
this.client = clientProps;
|
||||
}
|
||||
|
||||
public void sendMessages() throws JMSException {
|
||||
if (listener != null) {
|
||||
listener.onConfigEnd(this);
|
||||
}
|
||||
// Send a specific number of messages
|
||||
if (sendType.equalsIgnoreCase(COUNT_BASED_SENDING)) {
|
||||
sendCountBasedMessages(getSendCount());
|
||||
if (client.getSendType().equalsIgnoreCase(JmsProducerProperties.COUNT_BASED_SENDING)) {
|
||||
sendCountBasedMessages(client.getSendCount());
|
||||
|
||||
// Send messages for a specific duration
|
||||
// Send messages for a specific duration
|
||||
} else {
|
||||
sendTimeBasedMessages(getSendDuration());
|
||||
sendTimeBasedMessages(client.getSendDuration());
|
||||
}
|
||||
}
|
||||
|
||||
public void sendMessages(int destCount) throws JMSException {
|
||||
this.destCount = destCount;
|
||||
sendMessages();
|
||||
}
|
||||
|
||||
public void sendMessages(int destIndex, int destCount) throws JMSException {
|
||||
this.destIndex = destIndex;
|
||||
sendMessages(destCount);
|
||||
}
|
||||
|
||||
public void sendCountBasedMessages(long messageCount) throws JMSException {
|
||||
// Parse through different ways to send messages
|
||||
// Avoided putting the condition inside the loop to prevent effect on performance
|
||||
Destination[] dest = createDestination();
|
||||
Destination[] dest = createDestination(destIndex, destCount);
|
||||
|
||||
// Create a producer, if none is created.
|
||||
if (getJmsProducer() == null) {
|
||||
|
@ -72,11 +81,13 @@ public class JmsProducerClient extends JmsPerformanceSupport {
|
|||
}
|
||||
try {
|
||||
getConnection().start();
|
||||
if (listener != null) {
|
||||
listener.onPublishStart(this);
|
||||
}
|
||||
log.info("Starting to publish " + client.getMessageSize() + " byte(s) of " + messageCount + " messages...");
|
||||
|
||||
// Send one type of message only, avoiding the creation of different messages on sending
|
||||
if (getJmsTextMessage() != null) {
|
||||
if (!client.isCreateNewMsg()) {
|
||||
// Create only a single message
|
||||
createJmsTextMessage();
|
||||
|
||||
// Send to more than one actual destination
|
||||
if (dest.length > 1) {
|
||||
for (int i = 0; i < messageCount; i++) {
|
||||
|
@ -115,9 +126,6 @@ public class JmsProducerClient extends JmsPerformanceSupport {
|
|||
}
|
||||
}
|
||||
} finally {
|
||||
if (listener != null) {
|
||||
listener.onPublishEnd(this);
|
||||
}
|
||||
getConnection().close();
|
||||
}
|
||||
}
|
||||
|
@ -127,7 +135,7 @@ public class JmsProducerClient extends JmsPerformanceSupport {
|
|||
// Parse through different ways to send messages
|
||||
// Avoided putting the condition inside the loop to prevent effect on performance
|
||||
|
||||
Destination[] dest = createDestination();
|
||||
Destination[] dest = createDestination(destIndex, destCount);
|
||||
|
||||
// Create a producer, if none is created.
|
||||
if (getJmsProducer() == null) {
|
||||
|
@ -140,12 +148,13 @@ public class JmsProducerClient extends JmsPerformanceSupport {
|
|||
|
||||
try {
|
||||
getConnection().start();
|
||||
if (listener != null) {
|
||||
listener.onPublishStart(this);
|
||||
}
|
||||
log.info("Starting to publish " + client.getMessageSize() + " byte(s) messages for " + duration + " ms");
|
||||
|
||||
// Send one type of message only, avoiding the creation of different messages on sending
|
||||
if (getJmsTextMessage() != null) {
|
||||
if (!client.isCreateNewMsg()) {
|
||||
// Create only a single message
|
||||
createJmsTextMessage();
|
||||
|
||||
// Send to more than one actual destination
|
||||
if (dest.length > 1) {
|
||||
while (System.currentTimeMillis() < endTime) {
|
||||
|
@ -186,27 +195,17 @@ public class JmsProducerClient extends JmsPerformanceSupport {
|
|||
}
|
||||
}
|
||||
} finally {
|
||||
if (listener != null) {
|
||||
listener.onPublishEnd(this);
|
||||
}
|
||||
getConnection().close();
|
||||
}
|
||||
}
|
||||
|
||||
public Properties getJmsProducerSettings() {
|
||||
return jmsProducerSettings;
|
||||
}
|
||||
|
||||
public void setJmsProducerSettings(Properties jmsProducerSettings) {
|
||||
this.jmsProducerSettings = jmsProducerSettings;
|
||||
ReflectionUtil.configureClass(this, jmsProducerSettings);
|
||||
}
|
||||
|
||||
public MessageProducer createJmsProducer() throws JMSException {
|
||||
jmsProducer = getSession().createProducer(null);
|
||||
if (getDeliveryMode().equalsIgnoreCase(DELIVERY_MODE_PERSISTENT)) {
|
||||
if (client.getDeliveryMode().equalsIgnoreCase(JmsProducerProperties.DELIVERY_MODE_PERSISTENT)) {
|
||||
log.info("Creating producer to possible multiple destinations with persistent delivery.");
|
||||
jmsProducer.setDeliveryMode(DeliveryMode.PERSISTENT);
|
||||
} else if (getDeliveryMode().equalsIgnoreCase(DELIVERY_MODE_NON_PERSISTENT)) {
|
||||
} else if (client.getDeliveryMode().equalsIgnoreCase(JmsProducerProperties.DELIVERY_MODE_NON_PERSISTENT)) {
|
||||
log.info("Creating producer to possible multiple destinations with non-persistent delivery.");
|
||||
jmsProducer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
|
||||
} else {
|
||||
log.warn("Unknown deliveryMode value. Defaulting to non-persistent.");
|
||||
|
@ -217,9 +216,11 @@ public class JmsProducerClient extends JmsPerformanceSupport {
|
|||
|
||||
public MessageProducer createJmsProducer(Destination dest) throws JMSException {
|
||||
jmsProducer = getSession().createProducer(dest);
|
||||
if (getDeliveryMode().equalsIgnoreCase(DELIVERY_MODE_PERSISTENT)) {
|
||||
if (client.getDeliveryMode().equalsIgnoreCase(JmsProducerProperties.DELIVERY_MODE_PERSISTENT)) {
|
||||
log.info("Creating producer to: " + dest.toString() + " with persistent delivery.");
|
||||
jmsProducer.setDeliveryMode(DeliveryMode.PERSISTENT);
|
||||
} else if (getDeliveryMode().equalsIgnoreCase(DELIVERY_MODE_NON_PERSISTENT)) {
|
||||
} else if (client.getDeliveryMode().equalsIgnoreCase(JmsProducerProperties.DELIVERY_MODE_NON_PERSISTENT)) {
|
||||
log.info("Creating producer to: " + dest.toString() + " with non-persistent delivery.");
|
||||
jmsProducer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
|
||||
} else {
|
||||
log.warn("Unknown deliveryMode value. Defaulting to non-persistent.");
|
||||
|
@ -233,7 +234,7 @@ public class JmsProducerClient extends JmsPerformanceSupport {
|
|||
}
|
||||
|
||||
public TextMessage createJmsTextMessage() throws JMSException {
|
||||
return createJmsTextMessage(getMessageSize());
|
||||
return createJmsTextMessage(client.getMessageSize());
|
||||
}
|
||||
|
||||
public TextMessage createJmsTextMessage(int size) throws JMSException {
|
||||
|
@ -242,7 +243,7 @@ public class JmsProducerClient extends JmsPerformanceSupport {
|
|||
}
|
||||
|
||||
public TextMessage createJmsTextMessage(String text) throws JMSException {
|
||||
jmsTextMessage = getSession().createTextMessage(buildText(text, getMessageSize()));
|
||||
jmsTextMessage = getSession().createTextMessage(buildText(text, client.getMessageSize()));
|
||||
return jmsTextMessage;
|
||||
}
|
||||
|
||||
|
@ -250,100 +251,17 @@ public class JmsProducerClient extends JmsPerformanceSupport {
|
|||
return jmsTextMessage;
|
||||
}
|
||||
|
||||
public JmsClientProperties getClient() {
|
||||
return client;
|
||||
}
|
||||
|
||||
public void setClient(JmsClientProperties clientProps) {
|
||||
client = (JmsProducerProperties)clientProps;
|
||||
}
|
||||
|
||||
protected String buildText(String text, int size) {
|
||||
byte[] data = new byte[size - text.length()];
|
||||
Arrays.fill(data, (byte) 0);
|
||||
return text + new String(data);
|
||||
}
|
||||
|
||||
public String getDeliveryMode() {
|
||||
return deliveryMode;
|
||||
}
|
||||
|
||||
public void setDeliveryMode(String deliveryMode) {
|
||||
this.deliveryMode = deliveryMode;
|
||||
}
|
||||
|
||||
public int getMessageSize() {
|
||||
return messageSize;
|
||||
}
|
||||
|
||||
public void setMessageSize(int messageSize) {
|
||||
this.messageSize = messageSize;
|
||||
}
|
||||
|
||||
public long getSendCount() {
|
||||
return sendCount;
|
||||
}
|
||||
|
||||
public void setSendCount(long sendCount) {
|
||||
this.sendCount = sendCount;
|
||||
}
|
||||
|
||||
public long getSendDuration() {
|
||||
return sendDuration;
|
||||
}
|
||||
|
||||
public void setSendDuration(long sendDuration) {
|
||||
this.sendDuration = sendDuration;
|
||||
}
|
||||
|
||||
public String getSendType() {
|
||||
return sendType;
|
||||
}
|
||||
|
||||
public void setSendType(String sendType) {
|
||||
this.sendType = sendType;
|
||||
}
|
||||
|
||||
public Properties getSettings() {
|
||||
Properties allSettings = new Properties(jmsProducerSettings);
|
||||
allSettings.putAll(super.getSettings());
|
||||
return allSettings;
|
||||
}
|
||||
|
||||
public void setSettings(Properties settings) {
|
||||
super.setSettings(settings);
|
||||
ReflectionUtil.configureClass(this, jmsProducerSettings);
|
||||
}
|
||||
|
||||
public void setProperty(String key, String value) {
|
||||
if (key.startsWith(PREFIX_CONFIG_PRODUCER)) {
|
||||
jmsProducerSettings.setProperty(key, value);
|
||||
} else {
|
||||
super.setProperty(key, value);
|
||||
}
|
||||
}
|
||||
|
||||
public static void main(String[] args) throws JMSException {
|
||||
Properties samplerSettings = new Properties();
|
||||
Properties producerSettings = new Properties();
|
||||
|
||||
for (int i = 0; i < args.length; i++) {
|
||||
// Get property define options only
|
||||
int index = args[i].indexOf("=");
|
||||
String key = args[i].substring(0, index);
|
||||
String val = args[i].substring(index + 1);
|
||||
if (key.startsWith("sampler.")) {
|
||||
samplerSettings.setProperty(key, val);
|
||||
} else {
|
||||
producerSettings.setProperty(key, val);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
JmsProducerClient client = new JmsProducerClient();
|
||||
client.setSettings(producerSettings);
|
||||
|
||||
PerfMeasurementTool sampler = new PerfMeasurementTool();
|
||||
sampler.setSamplerSettings(samplerSettings);
|
||||
sampler.registerClient(client);
|
||||
sampler.startSampler();
|
||||
|
||||
client.setPerfEventListener(sampler);
|
||||
|
||||
// This will reuse only a single message every send, which will improve performance
|
||||
client.createJmsTextMessage();
|
||||
client.sendMessages();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -16,76 +16,72 @@
|
|||
*/
|
||||
package org.apache.activemq.tool;
|
||||
|
||||
import org.apache.activemq.tool.properties.JmsClientSystemProperties;
|
||||
import org.apache.activemq.tool.properties.JmsProducerSystemProperties;
|
||||
import org.apache.activemq.tool.properties.JmsProducerProperties;
|
||||
import org.apache.activemq.tool.properties.JmsClientProperties;
|
||||
import org.apache.activemq.tool.sampler.ThroughputSamplerTask;
|
||||
|
||||
import javax.jms.JMSException;
|
||||
import java.util.Properties;
|
||||
|
||||
public class JmsProducerSystem extends JmsClientSystemSupport {
|
||||
public class JmsProducerSystem extends AbstractJmsClientSystem {
|
||||
protected JmsProducerSystemProperties sysTest = new JmsProducerSystemProperties();
|
||||
protected JmsProducerProperties producer = new JmsProducerProperties();
|
||||
|
||||
public String getReportName() {
|
||||
if (reportName == null) {
|
||||
return "JmsProducer_Client" + getNumClients() + "_Dest" + getTotalDests() + "_" + getDestDistro() + ".xml";
|
||||
} else {
|
||||
return reportName;
|
||||
}
|
||||
public JmsClientSystemProperties getSysTest() {
|
||||
return sysTest;
|
||||
}
|
||||
|
||||
public String getClientName() {
|
||||
if (clientName == null) {
|
||||
return "JmsProducer";
|
||||
} else {
|
||||
return clientName;
|
||||
}
|
||||
public void setSysTest(JmsClientSystemProperties sysTestProps) {
|
||||
sysTest = (JmsProducerSystemProperties)sysTestProps;
|
||||
}
|
||||
|
||||
protected void runJmsClient(String clientName, Properties clientSettings) {
|
||||
PerfMeasurementTool sampler = getPerformanceSampler();
|
||||
public JmsClientProperties getJmsClientProperties() {
|
||||
return getProducer();
|
||||
}
|
||||
|
||||
JmsProducerClient producer = new JmsProducerClient();
|
||||
producer.setSettings(clientSettings);
|
||||
producer.setClientName(clientName);
|
||||
public JmsProducerProperties getProducer() {
|
||||
return producer;
|
||||
}
|
||||
|
||||
public void setProducer(JmsProducerProperties producer) {
|
||||
this.producer = producer;
|
||||
}
|
||||
|
||||
protected void runJmsClient(String clientName, int clientDestIndex, int clientDestCount) {
|
||||
ThroughputSamplerTask sampler = getTpSampler();
|
||||
|
||||
JmsProducerClient producerClient = new JmsProducerClient(producer, jmsConnFactory);
|
||||
producerClient.setClientName(clientName);
|
||||
|
||||
if (sampler != null) {
|
||||
sampler.registerClient(producer);
|
||||
producer.setPerfEventListener(sampler);
|
||||
sampler.registerClient(producerClient);
|
||||
}
|
||||
|
||||
try {
|
||||
producer.createJmsTextMessage();
|
||||
producer.sendMessages();
|
||||
producerClient.sendMessages(clientDestIndex, clientDestCount);
|
||||
} catch (JMSException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
protected String getThreadName() {
|
||||
return "JMS Producer Thread: ";
|
||||
}
|
||||
|
||||
protected String getThreadGroupName() {
|
||||
return "JMS Producer Thread Group";
|
||||
}
|
||||
|
||||
protected String getDestCountKey() {
|
||||
return "producer.destCount";
|
||||
}
|
||||
|
||||
protected String getDestIndexKey() {
|
||||
return "producer.destIndex";
|
||||
}
|
||||
|
||||
public static void main(String[] args) {
|
||||
Properties sysSettings = new Properties();
|
||||
|
||||
for (int i = 0; i < args.length; i++) {
|
||||
// Get property define options only
|
||||
Properties props = new Properties();
|
||||
for (int i=0; i<args.length; i++) {
|
||||
int index = args[i].indexOf("=");
|
||||
String key = args[i].substring(0, index);
|
||||
String val = args[i].substring(index + 1);
|
||||
sysSettings.setProperty(key, val);
|
||||
props.setProperty(key, val);
|
||||
}
|
||||
|
||||
JmsProducerSystem sysTest = new JmsProducerSystem();
|
||||
sysTest.setSettings(sysSettings);
|
||||
sysTest.runSystemTest();
|
||||
JmsProducerSystem sys = new JmsProducerSystem();
|
||||
sys.configureProperties(props);
|
||||
|
||||
try {
|
||||
sys.runSystemTest();
|
||||
} catch (JMSException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,45 +0,0 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool;
|
||||
|
||||
import javax.jms.JMSException;
|
||||
|
||||
public class PerfEventAdapter implements PerfEventListener {
|
||||
public void onConfigStart(PerfMeasurable client) {
|
||||
}
|
||||
|
||||
public void onConfigEnd(PerfMeasurable client) {
|
||||
}
|
||||
|
||||
public void onPublishStart(PerfMeasurable client) {
|
||||
}
|
||||
|
||||
public void onPublishEnd(PerfMeasurable client) {
|
||||
}
|
||||
|
||||
public void onConsumeStart(PerfMeasurable client) {
|
||||
}
|
||||
|
||||
public void onConsumeEnd(PerfMeasurable client) {
|
||||
}
|
||||
|
||||
public void onJMSException(PerfMeasurable client, JMSException e) {
|
||||
}
|
||||
|
||||
public void onException(PerfMeasurable client, Exception e) {
|
||||
}
|
||||
}
|
|
@ -1,190 +0,0 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool;
|
||||
|
||||
import edu.emory.mathcs.backport.java.util.concurrent.atomic.AtomicBoolean;
|
||||
|
||||
import javax.jms.JMSException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
import java.util.Properties;
|
||||
|
||||
import org.apache.activemq.tool.reports.PerformanceReportWriter;
|
||||
|
||||
public class PerfMeasurementTool implements PerfEventListener, Runnable {
|
||||
public static final String PREFIX_CONFIG_SYSTEM_TEST = "sampler.";
|
||||
|
||||
private long duration = 5 * 60 * 1000; // 5 mins by default test duration
|
||||
private long interval = 1000; // 1 sec sample interval
|
||||
private long rampUpTime = 1 * 60 * 1000; // 1 min default test ramp up time
|
||||
private long rampDownTime = 1 * 60 * 1000; // 1 min default test ramp down time
|
||||
private long sampleIndex = 0;
|
||||
|
||||
private AtomicBoolean start = new AtomicBoolean(false);
|
||||
private AtomicBoolean stop = new AtomicBoolean(false);
|
||||
private AtomicBoolean isRunning = new AtomicBoolean(false);
|
||||
private PerformanceReportWriter perfWriter = null;
|
||||
private Properties samplerSettings = new Properties();
|
||||
|
||||
private List perfClients = new ArrayList();
|
||||
|
||||
public void registerClient(PerfMeasurable client) {
|
||||
client.setPerfEventListener(this);
|
||||
perfClients.add(client);
|
||||
}
|
||||
|
||||
public void registerClient(PerfMeasurable[] clients) {
|
||||
for (int i = 0; i < clients.length; i++) {
|
||||
registerClient(clients[i]);
|
||||
}
|
||||
}
|
||||
|
||||
public Properties getSamplerSettings() {
|
||||
return samplerSettings;
|
||||
}
|
||||
|
||||
public void setSamplerSettings(Properties samplerSettings) {
|
||||
this.samplerSettings = samplerSettings;
|
||||
ReflectionUtil.configureClass(this, samplerSettings);
|
||||
}
|
||||
|
||||
public PerformanceReportWriter getPerfWriter() {
|
||||
return perfWriter;
|
||||
}
|
||||
|
||||
public void setPerfWriter(PerformanceReportWriter writer) {
|
||||
this.perfWriter = writer;
|
||||
}
|
||||
|
||||
public long getDuration() {
|
||||
return duration;
|
||||
}
|
||||
|
||||
public void setDuration(long duration) {
|
||||
this.duration = duration;
|
||||
}
|
||||
|
||||
public long getInterval() {
|
||||
return interval;
|
||||
}
|
||||
|
||||
public void setInterval(long interval) {
|
||||
this.interval = interval;
|
||||
}
|
||||
|
||||
public long getRampUpTime() {
|
||||
return rampUpTime;
|
||||
}
|
||||
|
||||
public void setRampUpTime(long rampUpTime) {
|
||||
this.rampUpTime = rampUpTime;
|
||||
}
|
||||
|
||||
public long getRampDownTime() {
|
||||
return rampDownTime;
|
||||
}
|
||||
|
||||
public void setRampDownTime(long rampDownTime) {
|
||||
this.rampDownTime = rampDownTime;
|
||||
}
|
||||
|
||||
public void onConfigStart(PerfMeasurable client) {
|
||||
}
|
||||
|
||||
public void onConfigEnd(PerfMeasurable client) {
|
||||
}
|
||||
|
||||
public void onPublishStart(PerfMeasurable client) {
|
||||
}
|
||||
|
||||
public void onPublishEnd(PerfMeasurable client) {
|
||||
}
|
||||
|
||||
public void onConsumeStart(PerfMeasurable client) {
|
||||
}
|
||||
|
||||
public void onConsumeEnd(PerfMeasurable client) {
|
||||
}
|
||||
|
||||
public void onJMSException(PerfMeasurable client, JMSException e) {
|
||||
}
|
||||
|
||||
public void onException(PerfMeasurable client, Exception e) {
|
||||
stop.set(true);
|
||||
}
|
||||
|
||||
public void startSampler() {
|
||||
Thread t = new Thread(this);
|
||||
t.setName("Performance Sampler");
|
||||
|
||||
isRunning.set(true);
|
||||
t.start();
|
||||
}
|
||||
|
||||
public void run() {
|
||||
// Compute for the actual duration window of the sampler
|
||||
long endTime = System.currentTimeMillis() + duration - rampDownTime;
|
||||
try {
|
||||
try {
|
||||
Thread.sleep(rampUpTime);
|
||||
} catch (InterruptedException e) {
|
||||
}
|
||||
|
||||
// Let's reset the throughput first and start getting the samples
|
||||
for (Iterator i = perfClients.iterator(); i.hasNext();) {
|
||||
PerfMeasurable client = (PerfMeasurable) i.next();
|
||||
client.reset();
|
||||
}
|
||||
|
||||
while (System.currentTimeMillis() < endTime && !stop.get()) {
|
||||
try {
|
||||
Thread.sleep(interval);
|
||||
} catch (InterruptedException e) {
|
||||
}
|
||||
sampleClients();
|
||||
sampleIndex++;
|
||||
}
|
||||
} finally {
|
||||
isRunning.set(false);
|
||||
synchronized (isRunning) {
|
||||
isRunning.notifyAll();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void sampleClients() {
|
||||
for (Iterator i = perfClients.iterator(); i.hasNext();) {
|
||||
PerfMeasurable client = (PerfMeasurable) i.next();
|
||||
if (perfWriter != null) {
|
||||
perfWriter.writePerfData("index=" + sampleIndex + ",clientName=" + client.getClientName() + ",throughput=" + client.getThroughput());
|
||||
}
|
||||
client.reset();
|
||||
}
|
||||
}
|
||||
|
||||
public void waitForSamplerToFinish(long timeout) {
|
||||
while (isRunning.get()) {
|
||||
try {
|
||||
synchronized (isRunning) {
|
||||
isRunning.wait(timeout);
|
||||
}
|
||||
} catch (InterruptedException e) {
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -14,17 +14,21 @@
|
|||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool;
|
||||
package org.apache.activemq.tool.properties;
|
||||
|
||||
import javax.jms.JMSException;
|
||||
import java.util.Properties;
|
||||
|
||||
public interface PerfEventListener {
|
||||
public void onConfigStart(PerfMeasurable client);
|
||||
public void onConfigEnd(PerfMeasurable client);
|
||||
public void onPublishStart(PerfMeasurable client);
|
||||
public void onPublishEnd(PerfMeasurable client);
|
||||
public void onConsumeStart(PerfMeasurable client);
|
||||
public void onConsumeEnd(PerfMeasurable client);
|
||||
public void onJMSException(PerfMeasurable client, JMSException e);
|
||||
public void onException(PerfMeasurable client, Exception e);
|
||||
public abstract class AbstractObjectProperties implements ReflectionConfigurable {
|
||||
|
||||
public void configureProperties(Properties props) {
|
||||
ReflectionUtil.configureClass(this, props);
|
||||
}
|
||||
|
||||
public Properties retrieveProperties(Properties props) {
|
||||
return null;
|
||||
}
|
||||
|
||||
public boolean acceptConfig(String key, String val) {
|
||||
return true; // accept by default
|
||||
}
|
||||
}
|
|
@ -0,0 +1,61 @@
|
|||
/**
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
* <p/>
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* <p/>
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* <p/>
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool.properties;
|
||||
|
||||
public class JmsClientProperties extends AbstractObjectProperties {
|
||||
public static final String SESSION_AUTO_ACKNOWLEDGE = "autoAck";
|
||||
public static final String SESSION_CLIENT_ACKNOWLEDGE = "clientAck";
|
||||
public static final String SESSION_DUPS_OK_ACKNOWLEDGE = "dupsAck";
|
||||
public static final String SESSION_TRANSACTED = "transacted";
|
||||
|
||||
protected String destName = "TEST.FOO";
|
||||
protected boolean destComposite = false;
|
||||
|
||||
protected String sessAckMode = SESSION_AUTO_ACKNOWLEDGE;
|
||||
protected boolean sessTransacted = false;
|
||||
|
||||
public String getDestName() {
|
||||
return destName;
|
||||
}
|
||||
|
||||
public void setDestName(String destName) {
|
||||
this.destName = destName;
|
||||
}
|
||||
|
||||
public boolean isDestComposite() {
|
||||
return destComposite;
|
||||
}
|
||||
|
||||
public void setDestComposite(boolean destComposite) {
|
||||
this.destComposite = destComposite;
|
||||
}
|
||||
|
||||
public String getSessAckMode() {
|
||||
return sessAckMode;
|
||||
}
|
||||
|
||||
public void setSessAckMode(String sessAckMode) {
|
||||
this.sessAckMode = sessAckMode;
|
||||
}
|
||||
|
||||
public boolean isSessTransacted() {
|
||||
return sessTransacted;
|
||||
}
|
||||
|
||||
public void setSessTransacted(boolean sessTransacted) {
|
||||
this.sessTransacted = sessTransacted;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,113 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool.properties;
|
||||
|
||||
public class JmsClientSystemProperties extends AbstractObjectProperties {
|
||||
public static final String DEST_DISTRO_ALL = "all"; // Each client will send/receive to all destination;
|
||||
public static final String DEST_DISTRO_EQUAL = "equal"; // Equally divide the number of destinations to the number of clients
|
||||
public static final String DEST_DISTRO_DIVIDE = "divide"; // Divide the destination among the clients, even if some have more destination than others
|
||||
|
||||
public static final String REPORT_VERBOSE = "verbose"; // Report would be generated to the console
|
||||
public static final String REPORT_XML_FILE = "xml"; // Report would be generated to an xml file
|
||||
|
||||
public static final String SAMPLER_TP = "tp";
|
||||
public static final String SAMPLER_CPU = "cpu";
|
||||
|
||||
protected String reportType = REPORT_XML_FILE;
|
||||
protected String reportDir = "./";
|
||||
protected String reportName = null;
|
||||
|
||||
protected String samplers = SAMPLER_TP + "," + SAMPLER_CPU; // Start both samplers
|
||||
|
||||
protected String spiClass = "org.apache.activemq.tool.spi.ActiveMQClassLoaderSPI";
|
||||
protected String clientPrefix = "JmsClient";
|
||||
protected int numClients = 1;
|
||||
protected int totalDests = 1;
|
||||
protected String destDistro = DEST_DISTRO_ALL;
|
||||
|
||||
public String getReportType() {
|
||||
return reportType;
|
||||
}
|
||||
|
||||
public void setReportType(String reportType) {
|
||||
this.reportType = reportType;
|
||||
}
|
||||
|
||||
public String getReportDir() {
|
||||
return reportDir;
|
||||
}
|
||||
|
||||
public void setReportDir(String reportDir) {
|
||||
this.reportDir = reportDir;
|
||||
}
|
||||
|
||||
public String getReportName() {
|
||||
return reportName;
|
||||
}
|
||||
|
||||
public void setReportName(String reportName) {
|
||||
this.reportName = reportName;
|
||||
}
|
||||
|
||||
public String getSamplers() {
|
||||
return samplers;
|
||||
}
|
||||
|
||||
public void setSamplers(String samplers) {
|
||||
this.samplers = samplers;
|
||||
}
|
||||
|
||||
public String getSpiClass() {
|
||||
return spiClass;
|
||||
}
|
||||
|
||||
public void setSpiClass(String spiClass) {
|
||||
this.spiClass = spiClass;
|
||||
}
|
||||
|
||||
public String getClientPrefix() {
|
||||
return clientPrefix;
|
||||
}
|
||||
|
||||
public void setClientPrefix(String clientPrefix) {
|
||||
this.clientPrefix = clientPrefix;
|
||||
}
|
||||
|
||||
public int getNumClients() {
|
||||
return numClients;
|
||||
}
|
||||
|
||||
public void setNumClients(int numClients) {
|
||||
this.numClients = numClients;
|
||||
}
|
||||
|
||||
public int getTotalDests() {
|
||||
return totalDests;
|
||||
}
|
||||
|
||||
public void setTotalDests(int totalDests) {
|
||||
this.totalDests = totalDests;
|
||||
}
|
||||
|
||||
public String getDestDistro() {
|
||||
return destDistro;
|
||||
}
|
||||
|
||||
public void setDestDistro(String destDistro) {
|
||||
this.destDistro = destDistro;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,68 @@
|
|||
/**
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
* <p/>
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
* <p/>
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* <p/>
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool.properties;
|
||||
|
||||
public class JmsConsumerProperties extends JmsClientProperties {
|
||||
public static final String TIME_BASED_RECEIVING = "time"; // Receive messages on a time-based interval
|
||||
public static final String COUNT_BASED_RECEIVING = "count"; // Receive a specific count of messages
|
||||
|
||||
protected boolean durable = false; // Consumer is a durable subscriber
|
||||
protected boolean asyncRecv = true; // If true, use onMessage() to receive messages, else use receive()
|
||||
|
||||
protected long recvCount = 1000000; // Receive a million messages by default
|
||||
protected long recvDuration = 5 * 60 * 1000; // Receive for 5 mins by default
|
||||
protected String recvType = TIME_BASED_RECEIVING;
|
||||
|
||||
public boolean isDurable() {
|
||||
return durable;
|
||||
}
|
||||
|
||||
public void setDurable(boolean durable) {
|
||||
this.durable = durable;
|
||||
}
|
||||
|
||||
public boolean isAsyncRecv() {
|
||||
return asyncRecv;
|
||||
}
|
||||
|
||||
public void setAsyncRecv(boolean asyncRecv) {
|
||||
this.asyncRecv = asyncRecv;
|
||||
}
|
||||
|
||||
public long getRecvCount() {
|
||||
return recvCount;
|
||||
}
|
||||
|
||||
public void setRecvCount(long recvCount) {
|
||||
this.recvCount = recvCount;
|
||||
}
|
||||
|
||||
public long getRecvDuration() {
|
||||
return recvDuration;
|
||||
}
|
||||
|
||||
public void setRecvDuration(long recvDuration) {
|
||||
this.recvDuration = recvDuration;
|
||||
}
|
||||
|
||||
public String getRecvType() {
|
||||
return recvType;
|
||||
}
|
||||
|
||||
public void setRecvType(String recvType) {
|
||||
this.recvType = recvType;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,23 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool.properties;
|
||||
|
||||
public class JmsConsumerSystemProperties extends JmsClientSystemProperties {
|
||||
public JmsConsumerSystemProperties() {
|
||||
clientPrefix = "JmsConsumer";
|
||||
}
|
||||
}
|
|
@ -0,0 +1,34 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool.properties;
|
||||
|
||||
import java.util.Properties;
|
||||
|
||||
public class JmsFactoryProperties extends AbstractObjectProperties {
|
||||
Properties factorySettings = new Properties();
|
||||
|
||||
public boolean acceptConfig(String key, String val) {
|
||||
// Since we do not know the specific properties of each factory,
|
||||
// lets cache it first and give it to the spi later
|
||||
factorySettings.setProperty(key, val);
|
||||
return false;
|
||||
}
|
||||
|
||||
public Properties getFactorySettings() {
|
||||
return factorySettings;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,79 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool.properties;
|
||||
|
||||
public class JmsProducerProperties extends JmsClientProperties {
|
||||
public static final String TIME_BASED_SENDING = "time"; // Produce messages base on a time interval
|
||||
public static final String COUNT_BASED_SENDING = "count"; // Produce a specific count of messages
|
||||
public static final String DELIVERY_MODE_PERSISTENT = "persistent"; // Persistent message delivery
|
||||
public static final String DELIVERY_MODE_NON_PERSISTENT = "nonpersistent"; // Non-persistent message delivery
|
||||
|
||||
protected String deliveryMode = DELIVERY_MODE_NON_PERSISTENT; // Message delivery mode
|
||||
protected int messageSize = 1024; // Send 1kb messages by default
|
||||
protected long sendCount = 1000000; // Send a million messages by default
|
||||
protected long sendDuration = 5 * 60 * 1000; // Send for 5 mins by default
|
||||
protected String sendType = TIME_BASED_SENDING;
|
||||
protected boolean createNewMsg = false; // If true, create a different message on each send, otherwise reuse.
|
||||
|
||||
public String getDeliveryMode() {
|
||||
return deliveryMode;
|
||||
}
|
||||
|
||||
public void setDeliveryMode(String deliveryMode) {
|
||||
this.deliveryMode = deliveryMode;
|
||||
}
|
||||
|
||||
public int getMessageSize() {
|
||||
return messageSize;
|
||||
}
|
||||
|
||||
public void setMessageSize(int messageSize) {
|
||||
this.messageSize = messageSize;
|
||||
}
|
||||
|
||||
public long getSendCount() {
|
||||
return sendCount;
|
||||
}
|
||||
|
||||
public void setSendCount(long sendCount) {
|
||||
this.sendCount = sendCount;
|
||||
}
|
||||
|
||||
public long getSendDuration() {
|
||||
return sendDuration;
|
||||
}
|
||||
|
||||
public void setSendDuration(long sendDuration) {
|
||||
this.sendDuration = sendDuration;
|
||||
}
|
||||
|
||||
public String getSendType() {
|
||||
return sendType;
|
||||
}
|
||||
|
||||
public void setSendType(String sendType) {
|
||||
this.sendType = sendType;
|
||||
}
|
||||
|
||||
public boolean isCreateNewMsg() {
|
||||
return createNewMsg;
|
||||
}
|
||||
|
||||
public void setCreateNewMsg(boolean createNewMsg) {
|
||||
this.createNewMsg = createNewMsg;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,23 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool.properties;
|
||||
|
||||
public class JmsProducerSystemProperties extends JmsClientSystemProperties {
|
||||
public JmsProducerSystemProperties() {
|
||||
clientPrefix = "JmsProducer";
|
||||
}
|
||||
}
|
|
@ -1,28 +1,24 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* <p/>
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* <p/>
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* <p/>
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool;
|
||||
package org.apache.activemq.tool.properties;
|
||||
|
||||
import java.util.Properties;
|
||||
|
||||
public interface PerfMeasurable {
|
||||
public void reset();
|
||||
public String getClientName();
|
||||
public long getThroughput();
|
||||
public Properties getSettings();
|
||||
public void setPerfEventListener(PerfEventListener listener);
|
||||
public PerfEventListener getPerfEventListener();
|
||||
public interface ReflectionConfigurable {
|
||||
public void configureProperties(Properties props);
|
||||
public Properties retrieveProperties(Properties props);
|
||||
public boolean acceptConfig(String key, String val);
|
||||
}
|
|
@ -1,20 +1,19 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* <p/>
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* <p/>
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* <p/>
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool;
|
||||
package org.apache.activemq.tool.properties;
|
||||
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
|
@ -22,17 +21,25 @@ import org.apache.commons.logging.LogFactory;
|
|||
import java.util.Iterator;
|
||||
import java.util.StringTokenizer;
|
||||
import java.util.Properties;
|
||||
import java.util.List;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collections;
|
||||
import java.lang.reflect.Method;
|
||||
import java.lang.reflect.Field;
|
||||
import java.lang.reflect.InvocationTargetException;
|
||||
|
||||
public final class ReflectionUtil {
|
||||
private static final Log log = LogFactory.getLog(ReflectionUtil.class);
|
||||
|
||||
private ReflectionUtil() {
|
||||
|
||||
}
|
||||
|
||||
public static void configureClass(Object obj, String key, String val) {
|
||||
// Check if we will recognize the property first
|
||||
if (obj instanceof ReflectionConfigurable && !((ReflectionConfigurable)obj).acceptConfig(key, val)) {
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
String debugInfo;
|
||||
|
||||
|
@ -45,16 +52,13 @@ public final class ReflectionUtil {
|
|||
StringTokenizer tokenizer = new StringTokenizer(key, ".");
|
||||
int tokenCount = tokenizer.countTokens();
|
||||
|
||||
// NOTE: Skip the first token, it is assume that this is an indicator for the object itself
|
||||
tokenizer.nextToken();
|
||||
|
||||
// For nested settings, get the object first. -2, do not count the first and last token
|
||||
for (int j=0; j<tokenCount-2; j++) {
|
||||
for (int j=0; j<tokenCount-1; j++) {
|
||||
// Find getter method first
|
||||
String name = tokenizer.nextToken();
|
||||
String getMethod = "get" + name.substring(0,1).toUpperCase() + name.substring(1);
|
||||
Method method = targetClass.getMethod(getMethod, new Class[] {});
|
||||
target = method.invoke(target, (Object[])null);
|
||||
target = method.invoke(target, null);
|
||||
targetClass = target.getClass();
|
||||
|
||||
debugInfo += ("." + getMethod + "()");
|
||||
|
@ -111,10 +115,92 @@ public final class ReflectionUtil {
|
|||
|
||||
public static void configureClass(Object obj, Properties props) {
|
||||
for (Iterator i = props.keySet().iterator(); i.hasNext();) {
|
||||
String key = (String)i.next();
|
||||
String val = props.getProperty(key);
|
||||
try {
|
||||
String key = (String)i.next();
|
||||
String val = props.getProperty(key);
|
||||
|
||||
configureClass(obj, key, val);
|
||||
configureClass(obj, key, val);
|
||||
} catch (Throwable t) {
|
||||
// Let's catch any exception as this could be cause by the foreign class
|
||||
t.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static Properties retrieveObjectProperties(Object obj) {
|
||||
Properties props = new Properties();
|
||||
try {
|
||||
props.putAll(retrieveClassProperties("", obj.getClass(), obj));
|
||||
} catch (Exception e) {
|
||||
log.warn(e);
|
||||
}
|
||||
return props;
|
||||
}
|
||||
|
||||
protected static Properties retrieveClassProperties(String prefix, Class targetClass, Object targetObject) {
|
||||
if (targetClass == null || targetObject == null) {
|
||||
return new Properties();
|
||||
} else {
|
||||
Properties props = new Properties();
|
||||
Field[] fields = getAllFields(targetClass);
|
||||
Method getterMethod;
|
||||
for (int i=0; i<fields.length; i++) {
|
||||
try {
|
||||
if ((getterMethod = isPropertyField(targetClass, fields[i])) != null) {
|
||||
if (fields[i].getType().isPrimitive() || fields[i].getType() == String.class) {
|
||||
Object val = null;
|
||||
try {
|
||||
val = getterMethod.invoke(targetObject, null);
|
||||
} catch (InvocationTargetException e) {
|
||||
e.printStackTrace();
|
||||
} catch (IllegalAccessException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
props.setProperty(prefix + fields[i].getName(), val + "");
|
||||
} else {
|
||||
try {
|
||||
Object val = getterMethod.invoke(targetObject, null);
|
||||
if (val != null) {
|
||||
props.putAll(retrieveClassProperties(fields[i].getName() + ".", val.getClass(), val));
|
||||
}
|
||||
} catch (InvocationTargetException e) {
|
||||
e.printStackTrace();
|
||||
} catch (IllegalAccessException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
} catch (Throwable t) {
|
||||
// Let's catch any exception, cause this could be cause by the foreign class
|
||||
t.printStackTrace();
|
||||
}
|
||||
}
|
||||
return props;
|
||||
}
|
||||
}
|
||||
|
||||
protected static Method isPropertyField(Class targetClass, Field targetField) {
|
||||
String fieldName = targetField.getName();
|
||||
String getMethod = "get" + fieldName.substring(0,1).toUpperCase() + fieldName.substring(1);
|
||||
String isMethod = "is" + fieldName.substring(0,1).toUpperCase() + fieldName.substring(1);
|
||||
String setMethod = "set" + fieldName.substring(0,1).toUpperCase() + fieldName.substring(1);
|
||||
|
||||
// Check setter method
|
||||
try {
|
||||
targetClass.getMethod(setMethod, new Class[]{targetField.getType()});
|
||||
} catch (NoSuchMethodException e) {
|
||||
return null;
|
||||
}
|
||||
|
||||
// Check getter method and return it if it exists
|
||||
try {
|
||||
return targetClass.getMethod(getMethod, null);
|
||||
} catch (NoSuchMethodException e1) {
|
||||
try {
|
||||
return targetClass.getMethod(isMethod, null);
|
||||
} catch (NoSuchMethodException e2) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -128,4 +214,13 @@ public final class ReflectionUtil {
|
|||
}
|
||||
throw new NoSuchFieldException(fieldName);
|
||||
}
|
||||
|
||||
public static Field[] getAllFields(Class targetClass) {
|
||||
List fieldList = new ArrayList();
|
||||
while (targetClass != null) {
|
||||
Collections.addAll(fieldList, targetClass.getDeclaredFields());
|
||||
targetClass = targetClass.getSuperclass();
|
||||
}
|
||||
return (Field[])fieldList.toArray(new Field[0]);
|
||||
}
|
||||
}
|
|
@ -16,178 +16,23 @@
|
|||
*/
|
||||
package org.apache.activemq.tool.reports;
|
||||
|
||||
import org.apache.activemq.tool.ReflectionUtil;
|
||||
import org.apache.activemq.tool.reports.plugins.ReportPlugin;
|
||||
import org.apache.activemq.tool.reports.plugins.ThroughputReportPlugin;
|
||||
import org.apache.activemq.tool.reports.plugins.CpuReportPlugin;
|
||||
|
||||
import java.util.Properties;
|
||||
import java.util.Map;
|
||||
import java.util.HashMap;
|
||||
import java.util.StringTokenizer;
|
||||
import java.util.List;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Set;
|
||||
import java.util.Iterator;
|
||||
|
||||
public abstract class AbstractPerfReportWriter implements PerformanceReportWriter {
|
||||
public static final String KEY_SYS_TOTAL_TP = "SystemTotalTP";
|
||||
public static final String KEY_SYS_TOTAL_CLIENTS = "SystemTotalClients";
|
||||
public static final String KEY_SYS_AVE_TP = "SystemAveTP";
|
||||
public static final String KEY_SYS_AVE_EMM_TP = "SystemAveEMMTP";
|
||||
public static final String KEY_SYS_AVE_CLIENT_TP = "SystemAveClientTP";
|
||||
public static final String KEY_SYS_AVE_CLIENT_EMM_TP = "SystemAveClientEMMTP";
|
||||
public static final String KEY_MIN_CLIENT_TP = "MinClientTP";
|
||||
public static final String KEY_MAX_CLIENT_TP = "MaxClientTP";
|
||||
public static final String KEY_MIN_CLIENT_TOTAL_TP = "MinClientTotalTP";
|
||||
public static final String KEY_MAX_CLIENT_TOTAL_TP = "MaxClientTotalTP";
|
||||
public static final String KEY_MIN_CLIENT_AVE_TP = "MinClientAveTP";
|
||||
public static final String KEY_MAX_CLIENT_AVE_TP = "MaxClientAveTP";
|
||||
public static final String KEY_MIN_CLIENT_AVE_EMM_TP = "MinClientAveEMMTP";
|
||||
public static final String KEY_MAX_CLIENT_AVE_EMM_TP = "MaxClientAveEMMTP";
|
||||
protected ReportPlugin[] plugins = new ReportPlugin[] {
|
||||
new ThroughputReportPlugin(),
|
||||
new CpuReportPlugin()
|
||||
};
|
||||
|
||||
protected Properties settings;
|
||||
protected Map clientThroughputs = new HashMap();
|
||||
|
||||
public void setSettings(Properties settings) {
|
||||
this.settings = settings;
|
||||
ReflectionUtil.configureClass(this, settings);
|
||||
protected void handleCsvData(int pluginType, String csvData) {
|
||||
plugins[pluginType].handleCsvData(csvData);
|
||||
}
|
||||
|
||||
public Properties getSettings() {
|
||||
return settings;
|
||||
}
|
||||
|
||||
protected void parsePerfCsvData(String csvData) {
|
||||
StringTokenizer tokenizer = new StringTokenizer(csvData, ",");
|
||||
String data, key, val, clientName = null;
|
||||
Long throughput = null;
|
||||
while (tokenizer.hasMoreTokens()) {
|
||||
data = tokenizer.nextToken();
|
||||
key = data.substring(0, data.indexOf("="));
|
||||
val = data.substring(data.indexOf("=") + 1);
|
||||
|
||||
if (key.equalsIgnoreCase("clientName")) {
|
||||
clientName = val;
|
||||
} else if (key.equalsIgnoreCase("throughput")) {
|
||||
throughput = Long.valueOf(val);
|
||||
} else {
|
||||
// Ignore unknown token
|
||||
}
|
||||
}
|
||||
addToClientTPList(clientName, throughput);
|
||||
}
|
||||
|
||||
protected void addToClientTPList(String clientName, Long throughput) {
|
||||
// Write to client's throughput list
|
||||
if (clientName == null || throughput == null) {
|
||||
throw new IllegalArgumentException("Invalid Throughput CSV Data: clientName=" + clientName + ", throughput=" + throughput);
|
||||
}
|
||||
|
||||
List clientTPList = (List)clientThroughputs.get(clientName);
|
||||
if (clientTPList == null) {
|
||||
clientTPList = new ArrayList();
|
||||
clientThroughputs.put(clientName, clientTPList);
|
||||
}
|
||||
clientTPList.add(throughput);
|
||||
}
|
||||
|
||||
protected Map createPerfSummary(Map clientTPMap) {
|
||||
long minClientTP = Long.MAX_VALUE, // TP = throughput
|
||||
maxClientTP = Long.MIN_VALUE,
|
||||
minClientTotalTP = Long.MAX_VALUE,
|
||||
maxClientTotalTP = Long.MIN_VALUE,
|
||||
systemTotalTP = 0;
|
||||
|
||||
double minClientAveTP = Double.MAX_VALUE,
|
||||
maxClientAveTP = Double.MIN_VALUE,
|
||||
minClientAveEMMTP = Double.MAX_VALUE, // EMM = Excluding Min/Max
|
||||
maxClientAveEMMTP = Double.MIN_VALUE,
|
||||
systemAveTP = 0.0,
|
||||
systemAveEMMTP = 0.0;
|
||||
|
||||
String nameMinClientTP = "",
|
||||
nameMaxClientTP = "",
|
||||
nameMinClientTotalTP = "",
|
||||
nameMaxClientTotalTP = "",
|
||||
nameMinClientAveTP = "",
|
||||
nameMaxClientAveTP = "",
|
||||
nameMinClientAveEMMTP = "",
|
||||
nameMaxClientAveEMMTP = "";
|
||||
|
||||
Set clientNames = clientTPMap.keySet();
|
||||
String clientName;
|
||||
List clientTPList;
|
||||
long tempLong;
|
||||
double tempDouble;
|
||||
int clientCount = 0;
|
||||
for (Iterator i=clientNames.iterator(); i.hasNext();) {
|
||||
clientName = (String)i.next();
|
||||
clientTPList = (List)clientTPMap.get(clientName);
|
||||
clientCount++;
|
||||
|
||||
tempLong = PerformanceStatisticsUtil.getMinThroughput(clientTPList);
|
||||
if (tempLong < minClientTP) {
|
||||
minClientTP = tempLong;
|
||||
nameMinClientTP = clientName;
|
||||
}
|
||||
|
||||
tempLong = PerformanceStatisticsUtil.getMaxThroughput(clientTPList);
|
||||
if (tempLong > maxClientTP) {
|
||||
maxClientTP = tempLong;
|
||||
nameMaxClientTP = clientName;
|
||||
}
|
||||
|
||||
tempLong = PerformanceStatisticsUtil.getTotalThroughput(clientTPList);
|
||||
systemTotalTP += tempLong; // Accumulate total TP
|
||||
if (tempLong < minClientTotalTP) {
|
||||
minClientTotalTP = tempLong;
|
||||
nameMinClientTotalTP = clientName;
|
||||
}
|
||||
|
||||
if (tempLong > maxClientTotalTP) {
|
||||
maxClientTotalTP = tempLong;
|
||||
nameMaxClientTotalTP = clientName;
|
||||
}
|
||||
|
||||
tempDouble = PerformanceStatisticsUtil.getAveThroughput(clientTPList);
|
||||
systemAveTP += tempDouble; // Accumulate ave throughput
|
||||
if (tempDouble < minClientAveTP) {
|
||||
minClientAveTP = tempDouble;
|
||||
nameMinClientAveTP = clientName;
|
||||
}
|
||||
|
||||
if (tempDouble > maxClientAveTP) {
|
||||
maxClientAveTP = tempDouble;
|
||||
nameMaxClientAveTP = clientName;
|
||||
}
|
||||
|
||||
tempDouble = PerformanceStatisticsUtil.getAveThroughputExcludingMinMax(clientTPList);
|
||||
systemAveEMMTP += tempDouble; // Accumulate ave throughput excluding min/max
|
||||
if (tempDouble < minClientAveEMMTP) {
|
||||
minClientAveEMMTP = tempDouble;
|
||||
nameMinClientAveEMMTP = clientName;
|
||||
}
|
||||
|
||||
if (tempDouble > maxClientAveEMMTP) {
|
||||
maxClientAveEMMTP = tempDouble;
|
||||
nameMaxClientAveEMMTP = clientName;
|
||||
}
|
||||
}
|
||||
|
||||
Map summary = new HashMap();
|
||||
summary.put(KEY_SYS_TOTAL_TP, String.valueOf(systemTotalTP));
|
||||
summary.put(KEY_SYS_TOTAL_CLIENTS, String.valueOf(clientCount));
|
||||
summary.put(KEY_SYS_AVE_TP, String.valueOf(systemAveTP));
|
||||
summary.put(KEY_SYS_AVE_EMM_TP, String.valueOf(systemAveEMMTP));
|
||||
summary.put(KEY_SYS_AVE_CLIENT_TP, String.valueOf(systemAveTP / clientCount));
|
||||
summary.put(KEY_SYS_AVE_CLIENT_EMM_TP, String.valueOf(systemAveEMMTP / clientCount));
|
||||
summary.put(KEY_MIN_CLIENT_TP, nameMinClientTP + "=" + minClientTP);
|
||||
summary.put(KEY_MAX_CLIENT_TP, nameMaxClientTP + "=" + maxClientTP);
|
||||
summary.put(KEY_MIN_CLIENT_TOTAL_TP, nameMinClientTotalTP + "=" + minClientTotalTP);
|
||||
summary.put(KEY_MAX_CLIENT_TOTAL_TP, nameMaxClientTotalTP + "=" + maxClientTotalTP);
|
||||
summary.put(KEY_MIN_CLIENT_AVE_TP, nameMinClientAveTP + "=" + minClientAveTP);
|
||||
summary.put(KEY_MAX_CLIENT_AVE_TP, nameMaxClientAveTP + "=" + maxClientAveTP);
|
||||
summary.put(KEY_MIN_CLIENT_AVE_EMM_TP, nameMinClientAveEMMTP + "=" + minClientAveEMMTP);
|
||||
summary.put(KEY_MAX_CLIENT_AVE_EMM_TP, nameMaxClientAveEMMTP + "=" + maxClientAveEMMTP);
|
||||
|
||||
return summary;
|
||||
protected Map getSummary(int pluginType) {
|
||||
return plugins[pluginType].getSummary();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -19,12 +19,10 @@ package org.apache.activemq.tool.reports;
|
|||
import java.util.Properties;
|
||||
|
||||
public interface PerformanceReportWriter {
|
||||
public void setSettings(Properties settings);
|
||||
public Properties getSettings();
|
||||
public void openReportWriter();
|
||||
public void closeReportWriter();
|
||||
public void writeInfo(String info);
|
||||
public void writePerfData(String data);
|
||||
public void writeCsvData(int csvType, String csvData);
|
||||
public void writeProperties(String header, Properties props);
|
||||
public void writeProperties(Properties props);
|
||||
}
|
||||
|
|
|
@ -16,6 +16,9 @@
|
|||
*/
|
||||
package org.apache.activemq.tool.reports;
|
||||
|
||||
import org.apache.activemq.tool.reports.plugins.ReportPlugin;
|
||||
import org.apache.activemq.tool.reports.plugins.ThroughputReportPlugin;
|
||||
|
||||
import java.util.Properties;
|
||||
import java.util.Iterator;
|
||||
import java.util.Map;
|
||||
|
@ -24,7 +27,7 @@ import java.util.Arrays;
|
|||
public class VerbosePerfReportWriter extends AbstractPerfReportWriter {
|
||||
|
||||
public void openReportWriter() {
|
||||
writeProperties("System Properties", System.getProperties());
|
||||
// Do nothing
|
||||
}
|
||||
|
||||
public void closeReportWriter() {
|
||||
|
@ -36,20 +39,13 @@ public class VerbosePerfReportWriter extends AbstractPerfReportWriter {
|
|||
System.out.println("[PERF-INFO]: " + info);
|
||||
}
|
||||
|
||||
public void writeHeader(String header) {
|
||||
char[] border = new char[header.length() + 8]; // +8 for spacing
|
||||
Arrays.fill(border, '#');
|
||||
String borderStr = new String(border);
|
||||
|
||||
System.out.println(borderStr);
|
||||
System.out.println("# " + header + " #");
|
||||
System.out.println(borderStr);
|
||||
}
|
||||
|
||||
public void writePerfData(String data) {
|
||||
System.out.println("[PERF-DATA]: " + data);
|
||||
// Assume data is a CSV of key-value pair
|
||||
parsePerfCsvData(data);
|
||||
public void writeCsvData(int csvType, String csvData) {
|
||||
if (csvType == ReportPlugin.REPORT_PLUGIN_THROUGHPUT) {
|
||||
System.out.println("[PERF-TP]: " + csvData);
|
||||
} else if (csvType == ReportPlugin.REPORT_PLUGIN_CPU) {
|
||||
System.out.println("[PERF-CPU]: " + csvData);
|
||||
}
|
||||
handleCsvData(csvType, csvData);
|
||||
}
|
||||
|
||||
public void writeProperties(String header, Properties props) {
|
||||
|
@ -66,22 +62,32 @@ public class VerbosePerfReportWriter extends AbstractPerfReportWriter {
|
|||
}
|
||||
|
||||
public void writePerfSummary() {
|
||||
Map summary = createPerfSummary(clientThroughputs);
|
||||
Map summary = getSummary(ReportPlugin.REPORT_PLUGIN_THROUGHPUT);
|
||||
|
||||
System.out.println("[PERF-SUMMARY] System Total Throughput: " + summary.get(KEY_SYS_TOTAL_TP));
|
||||
System.out.println("[PERF-SUMMARY] System Total Clients: " + summary.get(KEY_SYS_TOTAL_CLIENTS));
|
||||
System.out.println("[PERF-SUMMARY] System Average Throughput: " + summary.get(KEY_SYS_AVE_TP));
|
||||
System.out.println("[PERF-SUMMARY] System Average Throughput Excluding Min/Max: " + summary.get(KEY_SYS_AVE_EMM_TP));
|
||||
System.out.println("[PERF-SUMMARY] System Average Client Throughput: " + summary.get(KEY_SYS_AVE_CLIENT_TP));
|
||||
System.out.println("[PERF-SUMMARY] System Average Client Throughput Excluding Min/Max: " + summary.get(KEY_SYS_AVE_CLIENT_EMM_TP));
|
||||
System.out.println("[PERF-SUMMARY] Min Client Throughput Per Sample: " + summary.get(KEY_MIN_CLIENT_TP));
|
||||
System.out.println("[PERF-SUMMARY] Max Client Throughput Per Sample: " + summary.get(KEY_MAX_CLIENT_TP));
|
||||
System.out.println("[PERF-SUMMARY] Min Client Total Throughput: " + summary.get(KEY_MIN_CLIENT_TOTAL_TP));
|
||||
System.out.println("[PERF-SUMMARY] Max Client Total Throughput: " + summary.get(KEY_MAX_CLIENT_TOTAL_TP));
|
||||
System.out.println("[PERF-SUMMARY] Min Client Average Throughput: " + summary.get(KEY_MIN_CLIENT_AVE_TP));
|
||||
System.out.println("[PERF-SUMMARY] Max Client Average Throughput: " + summary.get(KEY_MAX_CLIENT_AVE_TP));
|
||||
System.out.println("[PERF-SUMMARY] Min Client Average Throughput Excluding Min/Max: " + summary.get(KEY_MIN_CLIENT_AVE_EMM_TP));
|
||||
System.out.println("[PERF-SUMMARY] Max Client Average Throughput Excluding Min/Max: " + summary.get(KEY_MAX_CLIENT_AVE_EMM_TP));
|
||||
System.out.println("[PERF-TP-SUMMARY] System Total Throughput: " + summary.get(ThroughputReportPlugin.KEY_SYS_TOTAL_TP));
|
||||
System.out.println("[PERF-TP-SUMMARY] System Total Clients: " + summary.get(ThroughputReportPlugin.KEY_SYS_TOTAL_CLIENTS));
|
||||
System.out.println("[PERF-TP-SUMMARY] System Average Throughput: " + summary.get(ThroughputReportPlugin.KEY_SYS_AVE_TP));
|
||||
System.out.println("[PERF-TP-SUMMARY] System Average Throughput Excluding Min/Max: " + summary.get(ThroughputReportPlugin.KEY_SYS_AVE_EMM_TP));
|
||||
System.out.println("[PERF-TP-SUMMARY] System Average Client Throughput: " + summary.get(ThroughputReportPlugin.KEY_SYS_AVE_CLIENT_TP));
|
||||
System.out.println("[PERF-TP-SUMMARY] System Average Client Throughput Excluding Min/Max: " + summary.get(ThroughputReportPlugin.KEY_SYS_AVE_CLIENT_EMM_TP));
|
||||
System.out.println("[PERF-TP-SUMMARY] Min Client Throughput Per Sample: " + summary.get(ThroughputReportPlugin.KEY_MIN_CLIENT_TP));
|
||||
System.out.println("[PERF-TP-SUMMARY] Max Client Throughput Per Sample: " + summary.get(ThroughputReportPlugin.KEY_MAX_CLIENT_TP));
|
||||
System.out.println("[PERF-TP-SUMMARY] Min Client Total Throughput: " + summary.get(ThroughputReportPlugin.KEY_MIN_CLIENT_TOTAL_TP));
|
||||
System.out.println("[PERF-TP-SUMMARY] Max Client Total Throughput: " + summary.get(ThroughputReportPlugin.KEY_MAX_CLIENT_TOTAL_TP));
|
||||
System.out.println("[PERF-TP-SUMMARY] Min Client Average Throughput: " + summary.get(ThroughputReportPlugin.KEY_MIN_CLIENT_AVE_TP));
|
||||
System.out.println("[PERF-TP-SUMMARY] Max Client Average Throughput: " + summary.get(ThroughputReportPlugin.KEY_MAX_CLIENT_AVE_TP));
|
||||
System.out.println("[PERF-TP-SUMMARY] Min Client Average Throughput Excluding Min/Max: " + summary.get(ThroughputReportPlugin.KEY_MIN_CLIENT_AVE_EMM_TP));
|
||||
System.out.println("[PERF-TP-SUMMARY] Max Client Average Throughput Excluding Min/Max: " + summary.get(ThroughputReportPlugin.KEY_MAX_CLIENT_AVE_EMM_TP));
|
||||
}
|
||||
|
||||
protected void writeHeader(String header) {
|
||||
char[] border = new char[header.length() + 8]; // +8 for spacing
|
||||
Arrays.fill(border, '#');
|
||||
String borderStr = new String(border);
|
||||
|
||||
System.out.println(borderStr);
|
||||
System.out.println("# " + header + " #");
|
||||
System.out.println(borderStr);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -18,6 +18,8 @@ package org.apache.activemq.tool.reports;
|
|||
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
import org.apache.activemq.tool.reports.plugins.ReportPlugin;
|
||||
import org.apache.activemq.tool.reports.plugins.ThroughputReportPlugin;
|
||||
|
||||
import java.util.Properties;
|
||||
import java.util.List;
|
||||
|
@ -99,12 +101,24 @@ public class XmlFilePerfReportWriter extends AbstractPerfReportWriter {
|
|||
this.reportName = reportName;
|
||||
}
|
||||
|
||||
public File getXmlFile() {
|
||||
return xmlFile;
|
||||
}
|
||||
|
||||
public void setXmlFile(File xmlFile) {
|
||||
this.xmlFile = xmlFile;
|
||||
}
|
||||
|
||||
public void writeInfo(String info) {
|
||||
tempLogFileWriter.println("[INFO]" + info);
|
||||
}
|
||||
|
||||
public void writePerfData(String data) {
|
||||
tempLogFileWriter.println("[DATA]" + data);
|
||||
public void writeCsvData(int csvType, String csvData) {
|
||||
if (csvType == ReportPlugin.REPORT_PLUGIN_THROUGHPUT) {
|
||||
tempLogFileWriter.println("[TP-DATA]" + csvData);
|
||||
} else if (csvType == ReportPlugin.REPORT_PLUGIN_CPU) {
|
||||
tempLogFileWriter.println("[CPU-DATA]" + csvData);
|
||||
}
|
||||
}
|
||||
|
||||
public void writeProperties(String header, Properties props) {
|
||||
|
@ -116,7 +130,7 @@ public class XmlFilePerfReportWriter extends AbstractPerfReportWriter {
|
|||
}
|
||||
|
||||
protected File createTempLogFile() {
|
||||
File f = null;
|
||||
File f;
|
||||
try {
|
||||
f = File.createTempFile("tmpPL", null);
|
||||
} catch (IOException e) {
|
||||
|
@ -130,8 +144,7 @@ public class XmlFilePerfReportWriter extends AbstractPerfReportWriter {
|
|||
String filename = (getReportName().endsWith(".xml") ? getReportName() : (getReportName() + ".xml"));
|
||||
String path = (getReportDir() == null) ? "" : getReportDir();
|
||||
|
||||
File f = new File(path + filename);
|
||||
return f;
|
||||
return new File(path + filename);
|
||||
}
|
||||
|
||||
protected void writeToXml() {
|
||||
|
@ -145,7 +158,7 @@ public class XmlFilePerfReportWriter extends AbstractPerfReportWriter {
|
|||
writeXmlFooter();
|
||||
xmlFileWriter.close();
|
||||
|
||||
System.out.println("Created performance report: " + xmlFile.getAbsolutePath());
|
||||
log.info("Created performance report: " + xmlFile.getAbsolutePath());
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
@ -161,8 +174,6 @@ public class XmlFilePerfReportWriter extends AbstractPerfReportWriter {
|
|||
|
||||
protected void writeXmlTestSettings() {
|
||||
Properties props;
|
||||
// Write system settings
|
||||
writeMap("systemSettings", System.getProperties());
|
||||
|
||||
// Write test settings
|
||||
for (Iterator i=testPropsMap.keySet().iterator(); i.hasNext();) {
|
||||
|
@ -186,12 +197,16 @@ public class XmlFilePerfReportWriter extends AbstractPerfReportWriter {
|
|||
BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(tempLogFile)));
|
||||
String line;
|
||||
while ((line = reader.readLine()) != null) {
|
||||
if (line.startsWith("[DATA]")) {
|
||||
parsePerfCsvData(line.substring("[DATA]".length()));
|
||||
if (line.startsWith("[TP-DATA]")) {
|
||||
handleCsvData(ReportPlugin.REPORT_PLUGIN_THROUGHPUT, line.substring("[TP-DATA]".length()));
|
||||
parsePerfCsvData("tpdata", line.substring("[TP-DATA]".length()));
|
||||
} else if (line.startsWith("[CPU-DATA]")) {
|
||||
handleCsvData(ReportPlugin.REPORT_PLUGIN_CPU, line.substring("[CPU-DATA]".length()));
|
||||
parsePerfCsvData("cpudata", line.substring("[CPU-DATA]".length()));
|
||||
} else if (line.startsWith("[INFO]")) {
|
||||
xmlFileWriter.println("<value>" + line + "</value>");
|
||||
xmlFileWriter.println("<info>" + line + "</info>");
|
||||
} else {
|
||||
xmlFileWriter.println("<value>[ERROR]" + line + "</value>");
|
||||
xmlFileWriter.println("<error>" + line + "</error>");
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -200,84 +215,85 @@ public class XmlFilePerfReportWriter extends AbstractPerfReportWriter {
|
|||
}
|
||||
|
||||
protected void writeXmlPerfSummary() {
|
||||
Map summary = createPerfSummary(clientThroughputs);
|
||||
// Write throughput summary
|
||||
Map summary = getSummary(ReportPlugin.REPORT_PLUGIN_THROUGHPUT);
|
||||
|
||||
xmlFileWriter.println("<property name='perfSummary'>");
|
||||
xmlFileWriter.println("<props>");
|
||||
|
||||
String val, clientName, clientVal;
|
||||
|
||||
val = (String)summary.get(KEY_SYS_TOTAL_TP);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_SYS_TOTAL_TP);
|
||||
System.out.println("System Total Throughput: " + val);
|
||||
xmlFileWriter.println("<prop key='" + KEY_SYS_TOTAL_TP + "'>" + val + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_SYS_TOTAL_TP + "'>" + val + "</prop>");
|
||||
|
||||
val = (String)summary.get(KEY_SYS_TOTAL_CLIENTS);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_SYS_TOTAL_CLIENTS);
|
||||
System.out.println("System Total Clients: " + val);
|
||||
xmlFileWriter.println("<prop key='" + KEY_SYS_TOTAL_CLIENTS + "'>" + val + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_SYS_TOTAL_CLIENTS + "'>" + val + "</prop>");
|
||||
|
||||
val = (String)summary.get(KEY_SYS_AVE_TP);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_SYS_AVE_TP);
|
||||
System.out.println("System Average Throughput: " + val);
|
||||
xmlFileWriter.println("<prop key='" + KEY_SYS_AVE_TP + "'>" + val + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_SYS_AVE_TP + "'>" + val + "</prop>");
|
||||
|
||||
val = (String)summary.get(KEY_SYS_AVE_EMM_TP);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_SYS_AVE_EMM_TP);
|
||||
System.out.println("System Average Throughput Excluding Min/Max: " + val);
|
||||
xmlFileWriter.println("<prop key='" + KEY_SYS_AVE_EMM_TP + "'>" + val + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_SYS_AVE_EMM_TP + "'>" + val + "</prop>");
|
||||
|
||||
val = (String)summary.get(KEY_SYS_AVE_CLIENT_TP);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_SYS_AVE_CLIENT_TP);
|
||||
System.out.println("System Average Client Throughput: " + val);
|
||||
xmlFileWriter.println("<prop key='" + KEY_SYS_AVE_CLIENT_TP + "'>" + val + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_SYS_AVE_CLIENT_TP + "'>" + val + "</prop>");
|
||||
|
||||
val = (String)summary.get(KEY_SYS_AVE_CLIENT_EMM_TP);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_SYS_AVE_CLIENT_EMM_TP);
|
||||
System.out.println("System Average Client Throughput Excluding Min/Max: " + val);
|
||||
xmlFileWriter.println("<prop key='" + KEY_SYS_AVE_CLIENT_EMM_TP + "'>" + val + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_SYS_AVE_CLIENT_EMM_TP + "'>" + val + "</prop>");
|
||||
|
||||
val = (String)summary.get(KEY_MIN_CLIENT_TP);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_MIN_CLIENT_TP);
|
||||
clientName = val.substring(0, val.indexOf("="));
|
||||
clientVal = val.substring(val.indexOf("=") + 1);
|
||||
System.out.println("Min Client Throughput Per Sample: clientName=" + clientName + ", value=" + clientVal);
|
||||
xmlFileWriter.println("<prop key='" + KEY_MIN_CLIENT_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_MIN_CLIENT_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
|
||||
val = (String)summary.get(KEY_MAX_CLIENT_TP);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_MAX_CLIENT_TP);
|
||||
clientName = val.substring(0, val.indexOf("="));
|
||||
clientVal = val.substring(val.indexOf("=") + 1);
|
||||
System.out.println("Max Client Throughput Per Sample: clientName=" + clientName + ", value=" + clientVal);
|
||||
xmlFileWriter.println("<prop key='" + KEY_MAX_CLIENT_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_MAX_CLIENT_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
|
||||
val = (String)summary.get(KEY_MIN_CLIENT_TOTAL_TP);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_MIN_CLIENT_TOTAL_TP);
|
||||
clientName = val.substring(0, val.indexOf("="));
|
||||
clientVal = val.substring(val.indexOf("=") + 1);
|
||||
System.out.println("Min Client Total Throughput: clientName=" + clientName + ", value=" + clientVal);
|
||||
xmlFileWriter.println("<prop key='" + KEY_MIN_CLIENT_TOTAL_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_MIN_CLIENT_TOTAL_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
|
||||
val = (String)summary.get(KEY_MAX_CLIENT_TOTAL_TP);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_MAX_CLIENT_TOTAL_TP);
|
||||
clientName = val.substring(0, val.indexOf("="));
|
||||
clientVal = val.substring(val.indexOf("=") + 1);
|
||||
System.out.println("Max Client Total Throughput: clientName=" + clientName + ", value=" + clientVal);
|
||||
xmlFileWriter.println("<prop key='" + KEY_MAX_CLIENT_TOTAL_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_MAX_CLIENT_TOTAL_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
|
||||
val = (String)summary.get(KEY_MIN_CLIENT_AVE_TP);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_MIN_CLIENT_AVE_TP);
|
||||
clientName = val.substring(0, val.indexOf("="));
|
||||
clientVal = val.substring(val.indexOf("=") + 1);
|
||||
System.out.println("Min Average Client Throughput: clientName=" + clientName + ", value=" + clientVal);
|
||||
xmlFileWriter.println("<prop key='" + KEY_MIN_CLIENT_AVE_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_MIN_CLIENT_AVE_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
|
||||
val = (String)summary.get(KEY_MAX_CLIENT_AVE_TP);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_MAX_CLIENT_AVE_TP);
|
||||
clientName = val.substring(0, val.indexOf("="));
|
||||
clientVal = val.substring(val.indexOf("=") + 1);
|
||||
System.out.println("Max Average Client Throughput: clientName=" + clientName + ", value=" + clientVal);
|
||||
xmlFileWriter.println("<prop key='" + KEY_MAX_CLIENT_AVE_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_MAX_CLIENT_AVE_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
|
||||
val = (String)summary.get(KEY_MIN_CLIENT_AVE_EMM_TP);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_MIN_CLIENT_AVE_EMM_TP);
|
||||
clientName = val.substring(0, val.indexOf("="));
|
||||
clientVal = val.substring(val.indexOf("=") + 1);
|
||||
System.out.println("Min Average Client Throughput Excluding Min/Max: clientName=" + clientName + ", value=" + clientVal);
|
||||
xmlFileWriter.println("<prop key='" + KEY_MIN_CLIENT_AVE_EMM_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_MIN_CLIENT_AVE_EMM_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
|
||||
val = (String)summary.get(KEY_MAX_CLIENT_AVE_EMM_TP);
|
||||
val = (String)summary.get(ThroughputReportPlugin.KEY_MAX_CLIENT_AVE_EMM_TP);
|
||||
clientName = val.substring(0, val.indexOf("="));
|
||||
clientVal = val.substring(val.indexOf("=") + 1);
|
||||
System.out.println("Max Average Client Throughput Excluding Min/Max: clientName=" + clientName + ", value=" + clientVal);
|
||||
xmlFileWriter.println("<prop key='" + KEY_MAX_CLIENT_AVE_EMM_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
xmlFileWriter.println("<prop key='" + ThroughputReportPlugin.KEY_MAX_CLIENT_AVE_EMM_TP + "'>clientName=" + clientName + ",value=" + clientVal + "</prop>");
|
||||
|
||||
xmlFileWriter.println("</props>");
|
||||
xmlFileWriter.println("</property>");
|
||||
|
@ -295,26 +311,19 @@ public class XmlFilePerfReportWriter extends AbstractPerfReportWriter {
|
|||
xmlFileWriter.println("</property>");
|
||||
}
|
||||
|
||||
protected void parsePerfCsvData(String csvData) {
|
||||
protected void parsePerfCsvData(String elementName, String csvData) {
|
||||
StringTokenizer tokenizer = new StringTokenizer(csvData, ",");
|
||||
String data, key, val, clientName = null;
|
||||
Long throughput = null;
|
||||
int index = -1;
|
||||
String xmlElement;
|
||||
|
||||
xmlElement = "<" + elementName;
|
||||
String data, key, val;
|
||||
while (tokenizer.hasMoreTokens()) {
|
||||
data = tokenizer.nextToken();
|
||||
key = data.substring(0, data.indexOf("="));
|
||||
val = data.substring(data.indexOf("=") + 1);
|
||||
|
||||
if (key.equalsIgnoreCase("clientName")) {
|
||||
clientName = val;
|
||||
} else if (key.equalsIgnoreCase("throughput")) {
|
||||
throughput = Long.valueOf(val);
|
||||
} else if (key.equalsIgnoreCase("index")) {
|
||||
index = Integer.parseInt(val);
|
||||
}
|
||||
xmlElement += (" " + key + "='" + val + "'");
|
||||
}
|
||||
addToClientTPList(clientName, throughput);
|
||||
xmlFileWriter.println("<value index='" + index + "' clientName='" + clientName +
|
||||
"'>" + throughput.longValue() + "</value>");
|
||||
xmlElement += " />";
|
||||
xmlFileWriter.println(xmlElement);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -0,0 +1,29 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool.reports.plugins;
|
||||
|
||||
import java.util.Map;
|
||||
|
||||
public class CpuReportPlugin implements ReportPlugin {
|
||||
public void handleCsvData(String csvData) {
|
||||
// Do nothing
|
||||
}
|
||||
|
||||
public Map getSummary() {
|
||||
return null; // Do nothing
|
||||
}
|
||||
}
|
|
@ -0,0 +1,27 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool.reports.plugins;
|
||||
|
||||
import java.util.Map;
|
||||
|
||||
public interface ReportPlugin {
|
||||
public static final int REPORT_PLUGIN_THROUGHPUT = 0;
|
||||
public static final int REPORT_PLUGIN_CPU = 1;
|
||||
|
||||
public void handleCsvData(String csvData);
|
||||
public Map getSummary();
|
||||
}
|
|
@ -0,0 +1,182 @@
|
|||
/**
|
||||
*
|
||||
* Copyright 2005-2006 The Apache Software Foundation
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
package org.apache.activemq.tool.reports.plugins;
|
||||
|
||||
import org.apache.activemq.tool.reports.PerformanceStatisticsUtil;
|
||||
|
||||
import java.util.Map;
|
||||
import java.util.HashMap;
|
||||
import java.util.StringTokenizer;
|
||||
import java.util.List;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Set;
|
||||
import java.util.Iterator;
|
||||
|
||||
public class ThroughputReportPlugin implements ReportPlugin {
|
||||
public static final String KEY_SYS_TOTAL_TP = "SystemTotalTP";
|
||||
public static final String KEY_SYS_TOTAL_CLIENTS = "SystemTotalClients";
|
||||
public static final String KEY_SYS_AVE_TP = "SystemAveTP";
|
||||
public static final String KEY_SYS_AVE_EMM_TP = "SystemAveEMMTP";
|
||||
public static final String KEY_SYS_AVE_CLIENT_TP = "SystemAveClientTP";
|
||||
public static final String KEY_SYS_AVE_CLIENT_EMM_TP = "SystemAveClientEMMTP";
|
||||
public static final String KEY_MIN_CLIENT_TP = "MinClientTP";
|
||||
public static final String KEY_MAX_CLIENT_TP = "MaxClientTP";
|
||||
public static final String KEY_MIN_CLIENT_TOTAL_TP = "MinClientTotalTP";
|
||||
public static final String KEY_MAX_CLIENT_TOTAL_TP = "MaxClientTotalTP";
|
||||
public static final String KEY_MIN_CLIENT_AVE_TP = "MinClientAveTP";
|
||||
public static final String KEY_MAX_CLIENT_AVE_TP = "MaxClientAveTP";
|
||||
public static final String KEY_MIN_CLIENT_AVE_EMM_TP = "MinClientAveEMMTP";
|
||||
public static final String KEY_MAX_CLIENT_AVE_EMM_TP = "MaxClientAveEMMTP";
|
||||
|
||||
protected Map clientThroughputs = new HashMap();
|
||||
|
||||
public void handleCsvData(String csvData) {
|
||||
StringTokenizer tokenizer = new StringTokenizer(csvData, ",");
|
||||
String data, key, val, clientName = null;
|
||||
Long throughput = null;
|
||||
while (tokenizer.hasMoreTokens()) {
|
||||
data = tokenizer.nextToken();
|
||||
key = data.substring(0, data.indexOf("="));
|
||||
val = data.substring(data.indexOf("=") + 1);
|
||||
|
||||
if (key.equalsIgnoreCase("clientName")) {
|
||||
clientName = val;
|
||||
} else if (key.equalsIgnoreCase("throughput")) {
|
||||
throughput = Long.valueOf(val);
|
||||
} else {
|
||||
// Ignore unknown token
|
||||
}
|
||||
}
|
||||
addToClientTPList(clientName, throughput);
|
||||
}
|
||||
|
||||
public Map getSummary() {
|
||||
long minClientTP = Long.MAX_VALUE, // TP = throughput
|
||||
maxClientTP = Long.MIN_VALUE,
|
||||
minClientTotalTP = Long.MAX_VALUE,
|
||||
maxClientTotalTP = Long.MIN_VALUE,
|
||||
systemTotalTP = 0;
|
||||
|
||||
double minClientAveTP = Double.MAX_VALUE,
|
||||
maxClientAveTP = Double.MIN_VALUE,
|
||||
minClientAveEMMTP = Double.MAX_VALUE, // EMM = Excluding Min/Max
|
||||
maxClientAveEMMTP = Double.MIN_VALUE,
|
||||
systemAveTP = 0.0,
|
||||
systemAveEMMTP = 0.0;
|
||||
|
||||
String nameMinClientTP = "",
|
||||
nameMaxClientTP = "",
|
||||
nameMinClientTotalTP = "",
|
||||
nameMaxClientTotalTP = "",
|
||||
nameMinClientAveTP = "",
|
||||
nameMaxClientAveTP = "",
|
||||
nameMinClientAveEMMTP = "",
|
||||
nameMaxClientAveEMMTP = "";
|
||||
|
||||
Set clientNames = clientThroughputs.keySet();
|
||||
String clientName;
|
||||
List clientTPList;
|
||||
long tempLong;
|
||||
double tempDouble;
|
||||
int clientCount = 0;
|
||||
for (Iterator i=clientNames.iterator(); i.hasNext();) {
|
||||
clientName = (String)i.next();
|
||||
clientTPList = (List)clientThroughputs.get(clientName);
|
||||
clientCount++;
|
||||
|
||||
tempLong = PerformanceStatisticsUtil.getMinThroughput(clientTPList);
|
||||
if (tempLong < minClientTP) {
|
||||
minClientTP = tempLong;
|
||||
nameMinClientTP = clientName;
|
||||
}
|
||||
|
||||
tempLong = PerformanceStatisticsUtil.getMaxThroughput(clientTPList);
|
||||
if (tempLong > maxClientTP) {
|
||||
maxClientTP = tempLong;
|
||||
nameMaxClientTP = clientName;
|
||||
}
|
||||
|
||||
tempLong = PerformanceStatisticsUtil.getTotalThroughput(clientTPList);
|
||||
systemTotalTP += tempLong; // Accumulate total TP
|
||||
if (tempLong < minClientTotalTP) {
|
||||
minClientTotalTP = tempLong;
|
||||
nameMinClientTotalTP = clientName;
|
||||
}
|
||||
|
||||
if (tempLong > maxClientTotalTP) {
|
||||
maxClientTotalTP = tempLong;
|
||||
nameMaxClientTotalTP = clientName;
|
||||
}
|
||||
|
||||
tempDouble = PerformanceStatisticsUtil.getAveThroughput(clientTPList);
|
||||
systemAveTP += tempDouble; // Accumulate ave throughput
|
||||
if (tempDouble < minClientAveTP) {
|
||||
minClientAveTP = tempDouble;
|
||||
nameMinClientAveTP = clientName;
|
||||
}
|
||||
|
||||
if (tempDouble > maxClientAveTP) {
|
||||
maxClientAveTP = tempDouble;
|
||||
nameMaxClientAveTP = clientName;
|
||||
}
|
||||
|
||||
tempDouble = PerformanceStatisticsUtil.getAveThroughputExcludingMinMax(clientTPList);
|
||||
systemAveEMMTP += tempDouble; // Accumulate ave throughput excluding min/max
|
||||
if (tempDouble < minClientAveEMMTP) {
|
||||
minClientAveEMMTP = tempDouble;
|
||||
nameMinClientAveEMMTP = clientName;
|
||||
}
|
||||
|
||||
if (tempDouble > maxClientAveEMMTP) {
|
||||
maxClientAveEMMTP = tempDouble;
|
||||
nameMaxClientAveEMMTP = clientName;
|
||||
}
|
||||
}
|
||||
|
||||
Map summary = new HashMap();
|
||||
summary.put(KEY_SYS_TOTAL_TP, String.valueOf(systemTotalTP));
|
||||
summary.put(KEY_SYS_TOTAL_CLIENTS, String.valueOf(clientCount));
|
||||
summary.put(KEY_SYS_AVE_TP, String.valueOf(systemAveTP));
|
||||
summary.put(KEY_SYS_AVE_EMM_TP, String.valueOf(systemAveEMMTP));
|
||||
summary.put(KEY_SYS_AVE_CLIENT_TP, String.valueOf(systemAveTP / clientCount));
|
||||
summary.put(KEY_SYS_AVE_CLIENT_EMM_TP, String.valueOf(systemAveEMMTP / clientCount));
|
||||
summary.put(KEY_MIN_CLIENT_TP, nameMinClientTP + "=" + minClientTP);
|
||||
summary.put(KEY_MAX_CLIENT_TP, nameMaxClientTP + "=" + maxClientTP);
|
||||
summary.put(KEY_MIN_CLIENT_TOTAL_TP, nameMinClientTotalTP + "=" + minClientTotalTP);
|
||||
summary.put(KEY_MAX_CLIENT_TOTAL_TP, nameMaxClientTotalTP + "=" + maxClientTotalTP);
|
||||
summary.put(KEY_MIN_CLIENT_AVE_TP, nameMinClientAveTP + "=" + minClientAveTP);
|
||||
summary.put(KEY_MAX_CLIENT_AVE_TP, nameMaxClientAveTP + "=" + maxClientAveTP);
|
||||
summary.put(KEY_MIN_CLIENT_AVE_EMM_TP, nameMinClientAveEMMTP + "=" + minClientAveEMMTP);
|
||||
summary.put(KEY_MAX_CLIENT_AVE_EMM_TP, nameMaxClientAveEMMTP + "=" + maxClientAveEMMTP);
|
||||
|
||||
return summary;
|
||||
}
|
||||
|
||||
protected void addToClientTPList(String clientName, Long throughput) {
|
||||
// Write to client's throughput list
|
||||
if (clientName == null || throughput == null) {
|
||||
throw new IllegalArgumentException("Invalid Throughput CSV Data: clientName=" + clientName + ", throughput=" + throughput);
|
||||
}
|
||||
|
||||
List clientTPList = (List)clientThroughputs.get(clientName);
|
||||
if (clientTPList == null) {
|
||||
clientTPList = new ArrayList();
|
||||
clientThroughputs.put(clientName, clientTPList);
|
||||
}
|
||||
clientTPList.add(throughput);
|
||||
}
|
||||
}
|
|
@ -16,7 +16,7 @@
|
|||
*/
|
||||
package org.apache.activemq.tool.spi;
|
||||
|
||||
import org.apache.activemq.tool.ReflectionUtil;
|
||||
import org.apache.activemq.tool.properties.ReflectionUtil;
|
||||
|
||||
import javax.jms.ConnectionFactory;
|
||||
import java.util.Properties;
|
||||
|
|
|
@ -20,157 +20,137 @@ import junit.framework.TestCase;
|
|||
|
||||
import java.util.Properties;
|
||||
|
||||
import org.apache.activemq.tool.properties.ReflectionUtil;
|
||||
|
||||
public class ReflectionUtilTest extends TestCase {
|
||||
private boolean booleanData;
|
||||
private int intData;
|
||||
private long longData;
|
||||
private short shortData;
|
||||
private double doubleData;
|
||||
private float floatData;
|
||||
private byte byteData;
|
||||
private char charData;
|
||||
private String stringData;
|
||||
private ReflectionUtilTest testData;
|
||||
private String data;
|
||||
|
||||
public void testDataTypeConfig() {
|
||||
// Initialize variables;
|
||||
booleanData = false;
|
||||
intData = 0;
|
||||
longData = 0;
|
||||
shortData = 0;
|
||||
doubleData = 0.0;
|
||||
floatData = 0.0F;
|
||||
byteData = 0;
|
||||
charData = '0';
|
||||
stringData = "false";
|
||||
TestClass3 targetObj = new TestClass3();
|
||||
|
||||
Object targetObj = new ReflectionUtilTest();
|
||||
// Initialize variables;
|
||||
targetObj.setBooleanData(false);
|
||||
targetObj.setIntData(0);
|
||||
targetObj.setLongData(0);
|
||||
targetObj.setShortData((short)0);
|
||||
targetObj.setDoubleData(0.0);
|
||||
targetObj.setFloatData(0.0F);
|
||||
targetObj.setByteData((byte)0);
|
||||
targetObj.setCharData('0');
|
||||
targetObj.setStringData("false");
|
||||
|
||||
// Set properties
|
||||
Properties props = new Properties();
|
||||
props.setProperty("test.booleanData", "true");
|
||||
props.setProperty("test.intData", "1000");
|
||||
props.setProperty("test.longData", "2000");
|
||||
props.setProperty("test.shortData", "3000");
|
||||
props.setProperty("test.doubleData", "1234.567");
|
||||
props.setProperty("test.floatData", "9876.543");
|
||||
props.setProperty("test.byteData", "127");
|
||||
props.setProperty("test.charData", "A");
|
||||
props.setProperty("test.stringData", "true");
|
||||
props.setProperty("test.testData", "TEST.FOO.BAR");
|
||||
props.setProperty("booleanData", "true");
|
||||
props.setProperty("intData", "1000");
|
||||
props.setProperty("longData", "2000");
|
||||
props.setProperty("shortData", "3000");
|
||||
props.setProperty("doubleData", "1234.567");
|
||||
props.setProperty("floatData", "9876.543");
|
||||
props.setProperty("byteData", "127");
|
||||
props.setProperty("charData", "A");
|
||||
props.setProperty("stringData", "true");
|
||||
|
||||
ReflectionUtil.configureClass(targetObj, props);
|
||||
|
||||
// Check config
|
||||
assertEquals(true, ((ReflectionUtilTest)targetObj).isBooleanData());
|
||||
assertEquals(1000, ((ReflectionUtilTest)targetObj).getIntData());
|
||||
assertEquals(2000, ((ReflectionUtilTest)targetObj).getLongData());
|
||||
assertEquals(3000, ((ReflectionUtilTest)targetObj).getShortData());
|
||||
assertEquals(1234.567, ((ReflectionUtilTest)targetObj).getDoubleData(), 0.0001);
|
||||
assertEquals(9876.543, ((ReflectionUtilTest)targetObj).getFloatData(), 0.0001);
|
||||
assertEquals(127, ((ReflectionUtilTest)targetObj).getByteData());
|
||||
assertEquals('A', ((ReflectionUtilTest)targetObj).getCharData());
|
||||
assertEquals("true", ((ReflectionUtilTest)targetObj).getStringData());
|
||||
assertEquals("TEST.FOO.BAR", ((ReflectionUtilTest)targetObj).getTestData().getStringData());
|
||||
assertEquals(true, targetObj.isBooleanData());
|
||||
assertEquals(1000, targetObj.getIntData());
|
||||
assertEquals(2000, targetObj.getLongData());
|
||||
assertEquals(3000, targetObj.getShortData());
|
||||
assertEquals(1234.567, targetObj.getDoubleData(), 0.0001);
|
||||
assertEquals(9876.543, targetObj.getFloatData(), 0.0001);
|
||||
assertEquals(127, targetObj.getByteData());
|
||||
assertEquals('A', targetObj.getCharData());
|
||||
assertEquals("true", targetObj.getStringData());
|
||||
}
|
||||
|
||||
public void testValueOfMethod() {
|
||||
ReflectionUtilTest targetObj = new ReflectionUtilTest();
|
||||
|
||||
ReflectionUtil.configureClass(targetObj, "testData", "TEST.FOO.BAR");
|
||||
|
||||
assertEquals("TEST.FOO.BAR", targetObj.testData.data);
|
||||
}
|
||||
|
||||
public void testGetProperties() {
|
||||
|
||||
TestClass3 testData = new TestClass3();
|
||||
testData.setBooleanData(false);
|
||||
testData.setByteData((byte)15);
|
||||
testData.setCharData('G');
|
||||
testData.setDoubleData(765.43);
|
||||
testData.setFloatData(543.21F);
|
||||
testData.setIntData(654321);
|
||||
testData.setLongData(987654321);
|
||||
testData.setShortData((short)4321);
|
||||
testData.setStringData("BAR.TEST.FOO");
|
||||
|
||||
TestClass3 targetObj = new TestClass3();
|
||||
targetObj.setBooleanData(true);
|
||||
targetObj.setByteData((byte)10);
|
||||
targetObj.setCharData('D');
|
||||
targetObj.setDoubleData(1234.567);
|
||||
targetObj.setFloatData(4567.89F);
|
||||
targetObj.setIntData(123456);
|
||||
targetObj.setLongData(1234567890);
|
||||
targetObj.setShortData((short)1234);
|
||||
targetObj.setStringData("Test.FOO.BAR");
|
||||
targetObj.setTestData(testData);
|
||||
|
||||
Properties p = ReflectionUtil.retrieveObjectProperties(targetObj);
|
||||
assertEquals("false", p.getProperty("testData.booleanData"));
|
||||
assertEquals("15", p.getProperty("testData.byteData"));
|
||||
assertEquals("G", p.getProperty("testData.charData"));
|
||||
assertEquals("765.43", p.getProperty("testData.doubleData"));
|
||||
assertEquals("543.21", p.getProperty("testData.floatData"));
|
||||
assertEquals("654321", p.getProperty("testData.intData"));
|
||||
assertEquals("987654321", p.getProperty("testData.longData"));
|
||||
assertEquals("4321", p.getProperty("testData.shortData"));
|
||||
assertEquals("BAR.TEST.FOO", p.getProperty("testData.stringData"));
|
||||
assertEquals("true", p.getProperty("booleanData"));
|
||||
assertEquals("10", p.getProperty("byteData"));
|
||||
assertEquals("D", p.getProperty("charData"));
|
||||
assertEquals("1234.567", p.getProperty("doubleData"));
|
||||
assertEquals("4567.89", p.getProperty("floatData"));
|
||||
assertEquals("123456", p.getProperty("intData"));
|
||||
assertEquals("1234567890", p.getProperty("longData"));
|
||||
assertEquals("1234", p.getProperty("shortData"));
|
||||
assertEquals("Test.FOO.BAR", p.getProperty("stringData"));
|
||||
}
|
||||
|
||||
public void testNestedConfig() {
|
||||
ReflectionUtilTest t1 = new ReflectionUtilTest();
|
||||
ReflectionUtilTest t2 = new ReflectionUtilTest();
|
||||
ReflectionUtilTest t3 = new ReflectionUtilTest();
|
||||
ReflectionUtilTest t4 = new ReflectionUtilTest();
|
||||
ReflectionUtilTest t5 = new ReflectionUtilTest();
|
||||
TestClass3 t1 = new TestClass3();
|
||||
TestClass3 t2 = new TestClass3();
|
||||
TestClass3 t3 = new TestClass3();
|
||||
TestClass3 t4 = new TestClass3();
|
||||
TestClass3 t5 = new TestClass3();
|
||||
|
||||
ReflectionUtil.configureClass(t1, "test.stringData", "t1");
|
||||
ReflectionUtil.configureClass(t1, "stringData", "t1");
|
||||
assertEquals("t1", t1.getStringData());
|
||||
|
||||
t1.setTestData(t2);
|
||||
ReflectionUtil.configureClass(t1, "test.testData.stringData", "t2");
|
||||
ReflectionUtil.configureClass(t1, "testData.stringData", "t2");
|
||||
assertEquals("t2", t2.getStringData());
|
||||
|
||||
t2.setTestData(t3);
|
||||
ReflectionUtil.configureClass(t1, "test.testData.testData.stringData", "t3");
|
||||
ReflectionUtil.configureClass(t1, "testData.testData.stringData", "t3");
|
||||
assertEquals("t3", t3.getStringData());
|
||||
|
||||
t3.setTestData(t4);
|
||||
ReflectionUtil.configureClass(t1, "test.testData.testData.testData.stringData", "t4");
|
||||
ReflectionUtil.configureClass(t1, "testData.testData.testData.stringData", "t4");
|
||||
assertEquals("t4", t4.getStringData());
|
||||
|
||||
t4.setTestData(t5);
|
||||
ReflectionUtil.configureClass(t1, "test.testData.testData.testData.testData.stringData", "t5");
|
||||
ReflectionUtil.configureClass(t1, "testData.testData.testData.testData.stringData", "t5");
|
||||
assertEquals("t5", t5.getStringData());
|
||||
}
|
||||
|
||||
public boolean isBooleanData() {
|
||||
return booleanData;
|
||||
}
|
||||
|
||||
public void setBooleanData(boolean booleanData) {
|
||||
this.booleanData = booleanData;
|
||||
}
|
||||
|
||||
public int getIntData() {
|
||||
return intData;
|
||||
}
|
||||
|
||||
public void setIntData(int intData) {
|
||||
this.intData = intData;
|
||||
}
|
||||
|
||||
public long getLongData() {
|
||||
return longData;
|
||||
}
|
||||
|
||||
public void setLongData(long longData) {
|
||||
this.longData = longData;
|
||||
}
|
||||
|
||||
public short getShortData() {
|
||||
return shortData;
|
||||
}
|
||||
|
||||
public void setShortData(short shortData) {
|
||||
this.shortData = shortData;
|
||||
}
|
||||
|
||||
public double getDoubleData() {
|
||||
return doubleData;
|
||||
}
|
||||
|
||||
public void setDoubleData(double doubleData) {
|
||||
this.doubleData = doubleData;
|
||||
}
|
||||
|
||||
public float getFloatData() {
|
||||
return floatData;
|
||||
}
|
||||
|
||||
public void setFloatData(float floatData) {
|
||||
this.floatData = floatData;
|
||||
}
|
||||
|
||||
public byte getByteData() {
|
||||
return byteData;
|
||||
}
|
||||
|
||||
public void setByteData(byte byteData) {
|
||||
this.byteData = byteData;
|
||||
}
|
||||
|
||||
public char getCharData() {
|
||||
return charData;
|
||||
}
|
||||
|
||||
public void setCharData(char charData) {
|
||||
this.charData = charData;
|
||||
}
|
||||
|
||||
public String getStringData() {
|
||||
return stringData;
|
||||
}
|
||||
|
||||
public void setStringData(String stringData) {
|
||||
this.stringData = stringData;
|
||||
public static ReflectionUtilTest valueOf(String data) {
|
||||
ReflectionUtilTest test = new ReflectionUtilTest();
|
||||
test.data = data;
|
||||
return test;
|
||||
}
|
||||
|
||||
public ReflectionUtilTest getTestData() {
|
||||
|
@ -181,9 +161,110 @@ public class ReflectionUtilTest extends TestCase {
|
|||
this.testData = testData;
|
||||
}
|
||||
|
||||
public static ReflectionUtilTest valueOf(String data) {
|
||||
ReflectionUtilTest obj = new ReflectionUtilTest();
|
||||
obj.setStringData(data);
|
||||
return obj;
|
||||
public String getData() {
|
||||
return data;
|
||||
}
|
||||
|
||||
public void setData(String data) {
|
||||
this.data = data;
|
||||
}
|
||||
|
||||
public class TestClass1 {
|
||||
private boolean booleanData;
|
||||
private int intData;
|
||||
private long longData;
|
||||
|
||||
public boolean isBooleanData() {
|
||||
return booleanData;
|
||||
}
|
||||
|
||||
public void setBooleanData(boolean booleanData) {
|
||||
this.booleanData = booleanData;
|
||||
}
|
||||
|
||||
public int getIntData() {
|
||||
return intData;
|
||||
}
|
||||
|
||||
public void setIntData(int intData) {
|
||||
this.intData = intData;
|
||||
}
|
||||
|
||||
public long getLongData() {
|
||||
return longData;
|
||||
}
|
||||
|
||||
public void setLongData(long longData) {
|
||||
this.longData = longData;
|
||||
}
|
||||
}
|
||||
|
||||
public class TestClass2 extends TestClass1 {
|
||||
private float floatData;
|
||||
private byte byteData;
|
||||
private char charData;
|
||||
|
||||
public float getFloatData() {
|
||||
return floatData;
|
||||
}
|
||||
|
||||
public void setFloatData(float floatData) {
|
||||
this.floatData = floatData;
|
||||
}
|
||||
|
||||
public byte getByteData() {
|
||||
return byteData;
|
||||
}
|
||||
|
||||
public void setByteData(byte byteData) {
|
||||
this.byteData = byteData;
|
||||
}
|
||||
|
||||
public char getCharData() {
|
||||
return charData;
|
||||
}
|
||||
|
||||
public void setCharData(char charData) {
|
||||
this.charData = charData;
|
||||
}
|
||||
}
|
||||
|
||||
public class TestClass3 extends TestClass2 {
|
||||
private short shortData;
|
||||
private double doubleData;
|
||||
private String stringData;
|
||||
private TestClass3 testData;
|
||||
|
||||
public short getShortData() {
|
||||
return shortData;
|
||||
}
|
||||
|
||||
public void setShortData(short shortData) {
|
||||
this.shortData = shortData;
|
||||
}
|
||||
|
||||
public double getDoubleData() {
|
||||
return doubleData;
|
||||
}
|
||||
|
||||
public void setDoubleData(double doubleData) {
|
||||
this.doubleData = doubleData;
|
||||
}
|
||||
|
||||
public String getStringData() {
|
||||
return stringData;
|
||||
}
|
||||
|
||||
public void setStringData(String stringData) {
|
||||
this.stringData = stringData;
|
||||
}
|
||||
|
||||
public TestClass3 getTestData() {
|
||||
return testData;
|
||||
}
|
||||
|
||||
public void setTestData(TestClass3 testData) {
|
||||
this.testData = testData;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue