io.gatling.jms.client.JmsTrackerPool.scala Maven / Gradle / Ivy
/*
* Copyright 2011-2020 GatlingCorp (https://gatling.io)
*
* 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 io.gatling.jms.client
import java.util.concurrent.ConcurrentHashMap
import javax.jms.Destination
import io.gatling.commons.util.Clock
import io.gatling.core.config.GatlingConfiguration
import io.gatling.core.stats.StatsEngine
import io.gatling.core.util.NameGen
import io.gatling.jms.action.JmsLogging
import io.gatling.jms.protocol.JmsMessageMatcher
import akka.actor.ActorSystem
import io.netty.util.concurrent.DefaultThreadFactory
object JmsTrackerPool {
private val JmsConsumerThreadFactory = new DefaultThreadFactory("gatling-jms-consumer")
}
class JmsTrackerPool(
sessionPool: JmsSessionPool,
system: ActorSystem,
statsEngine: StatsEngine,
clock: Clock,
configuration: GatlingConfiguration
) extends JmsLogging
with NameGen {
private val trackers = new ConcurrentHashMap[(Destination, Option[String]), JmsTracker]
def tracker(destination: Destination, selector: Option[String], listenerThreadCount: Int, messageMatcher: JmsMessageMatcher): JmsTracker =
trackers.computeIfAbsent(
(destination, selector),
_ => {
val actor = system.actorOf(Tracker.props(statsEngine, clock, configuration), genName("jmsTrackerActor"))
for (_ <- 1 to listenerThreadCount) {
// jms session pool logic creates a session per thread and stores it in thread local.
// After that the thread can be thrown away. The jms provider takes care of receiving and dispatching
val thread = JmsTrackerPool.JmsConsumerThreadFactory.newThread(() => {
val consumer = sessionPool.jmsSession().createConsumer(destination, selector.orNull)
consumer.setMessageListener(message => {
val matchId = messageMatcher.responseMatchId(message)
logMessage(s"Message received JMSMessageID=${message.getJMSMessageID} matchId=$matchId", message)
actor ! MessageReceived(matchId, clock.nowMillis, message)
})
})
thread.start()
}
new JmsTracker(actor)
}
)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy