Я использую JBoss EAP 7, адаптер ресурсов WMQ для подключения к WMQ и адаптер ресурсов AMQ для AMQ. Я должен получить сообщение от AMQ, сделать некоторую логику и поместить его в WMQ. Всякий раз, когда JMSProducer отправляет сообщение на WMQ, это занимает около 3-5 секунд.
Моя конфигурация адаптера ресурса:
<resource-adapter id="com.wmq.jmsra.main">
<archive>
com.wmq.jmsra.rar
</archive>
<transaction-support>XATransaction</transaction-support>
<config-property name="connectionConcurrency">
2
</config-property>
<connection-definitions>
<connection-definition class-name="com.ibm.mq.connector.outbound.ManagedQueueConnectionFactoryImpl" jndi-name="${wmq.jndi.factory}" enabled="true" tracking="false" use-java-context="true" pool-name="WMQConnectionFactory">
<config-property name="hostName">
${mq.wmq.host}
</config-property>
<config-property name="password">
${mq.wmq.input.password}
</config-property>
<config-property name="queueManager">
${mq.wmq.manager}
</config-property>
<config-property name="port">
${mq.wmq.port}
</config-property>
<config-property name="channel">
${mq.wmq.channel}
</config-property>
<config-property name="transportType">
CLIENT
</config-property>
<config-property name="sslCipherSuite">
TLS_RSA_WITH_AES_128_CBC_SHA
</config-property>
<config-property name="username">
${mq.wmq.input.user}
</config-property>
<xa-pool>
<min-pool-size>1</min-pool-size>
<initial-pool-size>1</initial-pool-size>
<max-pool-size>50</max-pool-size>
<fair>false</fair>
<no-tx-separate-pools>false</no-tx-separate-pools>
</xa-pool>
<recovery>
<recover-credential>
<user-name>${mq.wmq.input.user}</user-name>
<password>${mq.wmq.input.password}</password>
</recover-credential>
</recovery>
</connection-definition>
</connection-definitions>
<admin-objects>
<admin-object class-name="com.ibm.mq.connector.outbound.MQQueueProxy" jndi-name="${wmq.jndi.destination}" use-java-context="true" pool-name="wmq_queue_out">
<config-property name="baseQueueName">
${mq.wmq.output}
</config-property>
<config-property name="baseQueueManagerName">
${mq.wmq.manager}
</config-property>
</admin-object>
</admin-objects>
</resource-adapter>
Мой AMQ MDB:
@MessageDriven(activationConfig = {
@ActivationConfigProperty(propertyName = "destination", propertyValue = "${mq.amq.main.input}"),
@ActivationConfigProperty(propertyName = "destinationType", propertyValue = "javax.jms.Queue"),
})
@ResourceAdapter("com.amq.jmsra.main")
public class MessageOnCryptServerToBank implements MessageListener {
@Inject
@JMSConnectionFactory("${wmq.jndi.factory}")
private JMSContext context;
@Resource(mappedName = "${wmq.jndi.destination}")
private Destination queue;
@Override
public void onMessage(Message message) {
String msgFromAmq = getTextFromMessage(message);
// some logic
TextMessage textMessage = context.createTextMessage(msgToWMQ);
JMSProducer producer = context.createProducer();
producer.send(queue, textMessage);
}
}
Я добавляю бенчмарк для каждой строки, чтобы определить, какие из них заморозили мое приложение. Как оказалось, это было producer.send()
. Подскажите что я делаю не так?