org.apache.camel.component.pulsar.PulsarConsumer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of camel-pulsar Show documentation
Show all versions of camel-pulsar Show documentation
Camel Apache Pulsar Component
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.camel.component.pulsar;
import java.util.Collection;
import java.util.Queue;
import java.util.concurrent.ConcurrentLinkedQueue;
import java.util.concurrent.ExecutorService;
import java.util.stream.Collectors;
import org.apache.camel.Processor;
import org.apache.camel.Suspendable;
import org.apache.camel.component.pulsar.utils.consumers.ConsumerCreationStrategy;
import org.apache.camel.component.pulsar.utils.consumers.ConsumerCreationStrategyFactory;
import org.apache.camel.support.DefaultConsumer;
import org.apache.pulsar.client.api.Consumer;
import org.apache.pulsar.client.api.Message;
import org.apache.pulsar.client.api.PulsarClientException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import static org.apache.camel.component.pulsar.utils.PulsarUtils.pauseConsumers;
import static org.apache.camel.component.pulsar.utils.PulsarUtils.resumeConsumers;
import static org.apache.camel.component.pulsar.utils.PulsarUtils.stopConsumers;
import static org.apache.camel.component.pulsar.utils.PulsarUtils.stopExecutors;
public class PulsarConsumer extends DefaultConsumer implements Suspendable {
private static final Logger LOGGER = LoggerFactory.getLogger(PulsarConsumer.class);
private final PulsarEndpoint pulsarEndpoint;
private final ConsumerCreationStrategyFactory consumerCreationStrategyFactory;
private Queue> pulsarConsumers;
private Queue executors;
public PulsarConsumer(PulsarEndpoint pulsarEndpoint, Processor processor) {
super(pulsarEndpoint, processor);
this.pulsarEndpoint = pulsarEndpoint;
this.pulsarConsumers = new ConcurrentLinkedQueue<>();
this.consumerCreationStrategyFactory = ConsumerCreationStrategyFactory.create(this);
this.executors = new ConcurrentLinkedQueue<>();
}
@Override
protected void doStart() throws Exception {
pulsarConsumers = stopConsumers(pulsarConsumers);
Collection> consumers = createConsumers(pulsarEndpoint, consumerCreationStrategyFactory);
if (!pulsarEndpoint.getPulsarConfiguration().isMessageListener()) {
executors.addAll(subscribeWithThreadPool(consumers, pulsarEndpoint));
}
pulsarConsumers.addAll(consumers);
}
@Override
protected void doStop() throws PulsarClientException {
executors = stopExecutors(pulsarEndpoint.getCamelContext().getExecutorServiceManager(), executors);
pulsarConsumers = stopConsumers(pulsarConsumers);
}
/**
* Pauses the Pulsar consumers.
*
* Once paused, a Pulsar consumer does not request any more messages from the broker. However, it will still receive
* as many messages as it had already requested, which is equal to at most `consumerQueueSize`.
*/
@Override
protected void doSuspend() {
pauseConsumers(pulsarConsumers);
}
@Override
protected void doResume() throws Exception {
resumeConsumers(pulsarConsumers);
}
private Collection> createConsumers(
final PulsarEndpoint endpoint, final ConsumerCreationStrategyFactory factory)
throws Exception {
ConsumerCreationStrategy strategy = factory.getStrategy(endpoint.getPulsarConfiguration().getSubscriptionType());
return strategy.create(endpoint);
}
private Collection subscribeWithThreadPool(
Collection> consumers, PulsarEndpoint endpoint) {
int numThreads = endpoint.getPulsarConfiguration().getNumberOfConsumerThreads();
return consumers.stream().map(consumer -> {
ExecutorService executor = endpoint.getCamelContext().getExecutorServiceManager().newFixedThreadPool(this,
"pulsar-consumer", numThreads);
for (int i = 0; i < numThreads; i++) {
executor.submit(new PulsarConsumerLoop(endpoint, consumer));
}
return executor;
}).collect(Collectors.toList());
}
private class PulsarConsumerLoop implements Runnable {
private final PulsarEndpoint endpoint;
private final Consumer consumer;
public PulsarConsumerLoop(PulsarEndpoint endpoint, Consumer consumer) {
this.endpoint = endpoint;
this.consumer = consumer;
}
@Override
public void run() {
PulsarMessageListener listener = new PulsarMessageListener(endpoint, PulsarConsumer.this);
while (true) {
try {
Message msg = consumer.receive();
listener.received(consumer, msg);
} catch (PulsarClientException e) {
if (e.getCause() instanceof InterruptedException) {
// this means that our executor is shutting down
LOGGER.info("Received shutdown signal, exiting");
break;
}
endpoint.getExceptionHandler().handleException(e);
} catch (Exception e) {
endpoint.getExceptionHandler().handleException(e);
}
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy