com.rabbitmq.client.amqp.impl.EventLoop Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of amqp-client Show documentation
Show all versions of amqp-client Show documentation
The RabbitMQ AMQP 1.0 Java client library defines an API to access RabbitMQ
with the AMQP 1.0 protocol.
// Copyright (c) 2024 Broadcom. All Rights Reserved.
// The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries.
//
// 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.
//
// If you have any questions regarding licensing, please contact us at
// [email protected].
package com.rabbitmq.client.amqp.impl;
import com.rabbitmq.client.amqp.AmqpException;
import java.time.Duration;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.*;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.atomic.AtomicLong;
import java.util.concurrent.atomic.AtomicReference;
import java.util.function.Consumer;
import java.util.function.Supplier;
import java.util.function.UnaryOperator;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
final class EventLoop implements AutoCloseable {
private static final Duration TIMEOUT = Duration.ofSeconds(60);
private static final Logger LOGGER = LoggerFactory.getLogger(EventLoop.class);
private final AtomicBoolean closed = new AtomicBoolean(false);
private final Future> loop;
private final AtomicReference loopThread = new AtomicReference<>();
private final BlockingQueue> taskQueue =
new LinkedBlockingQueue<>(1000);
EventLoop(ExecutorService executorService) {
CountDownLatch loopThreadSetLatch = new CountDownLatch(1);
this.loop =
executorService.submit(
() -> {
loopThread.set(Thread.currentThread());
loopThreadSetLatch.countDown();
Map states = new HashMap<>();
while (!Thread.currentThread().isInterrupted()) {
try {
ClientTaskContext