i created a simple producer consumer simulation based on spring, jms and activemq, i\'m trying to reach high performance from both sides, producers and consumers,
Connec
JMSTemplate does a walk of ConnectionFactiory -> Connection -> Session -> MessageProducer, closing each object after each send. To get around this, wrap your amqConnectionFactory bean with a org.apache.activemq.pool.PooledConnectionFactory, and use that under the template rather than a CachingConnectionFactory.
Try to change acknowledge method to from AUTO to CLIENT_ACKNOWLEDGE. For more information look to the Specification.
What is the default delivery mode for ActiveMQ? is it a persistent queue? if so, how is it configured? how remote is the broker? These answers will determine the basic cost of sending to queue by answering how long it takes the server to ack the send (i.e. network RTT + potential cost of persisting the message to disk synchronously).
The other possibility is that you're actually creating a new connection, session and messageproducer on every send. This is pretty costly to say the least. It will be worth confirming whether this is happening (e.g. add debug logging to spring, check amq admin console for connection churn) or not as a basic sanity check. By the looks of it CachingConnectionFactory
should cache a single session and messageproducer by default and convertAndSend
should close the session it obtains after sending which results in a returning that cached session to the pool. This should mean it is relatively quick (spring jms goes through an awful lot of code just to send a message) to get the cached session on the next send.
Sorry if this answer comes to late to help the original poster. I recently investigated JmsTemplate
performance. Even with the same delivery and acknowledgment modes, native JMS
code seemed much faster than JmsTemplate
. The problem turned out to be that ActiveMQ
normally defaults to async sending, but when you use JmsTemplate
it instead uses sync sending. This dramatically reduces performance. You can set ActiveMQConnectionFactory
's useAsyncSend
property to true
to force async sending. More details here: JmsTemplate is not evil