2021-09-10 10:28:09 +00:00
|
|
|
#pragma once
|
|
|
|
|
2022-05-16 13:35:17 +00:00
|
|
|
#include <Storages/UVLoop.h>
|
2021-09-10 10:28:09 +00:00
|
|
|
#include <Storages/RabbitMQ/RabbitMQHandler.h>
|
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
|
|
|
struct RabbitMQConfiguration
|
|
|
|
{
|
|
|
|
String host;
|
|
|
|
UInt16 port;
|
|
|
|
String username;
|
|
|
|
String password;
|
|
|
|
String vhost;
|
|
|
|
|
|
|
|
bool secure;
|
|
|
|
String connection_string;
|
|
|
|
};
|
|
|
|
|
|
|
|
class RabbitMQConnection
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
RabbitMQConnection(const RabbitMQConfiguration & configuration_, Poco::Logger * log_);
|
|
|
|
|
|
|
|
bool isConnected();
|
|
|
|
|
|
|
|
bool connect();
|
|
|
|
|
|
|
|
bool reconnect();
|
|
|
|
|
|
|
|
void disconnect(bool immediately = false);
|
|
|
|
|
2021-09-11 17:38:55 +00:00
|
|
|
void heartbeat();
|
2021-09-10 10:28:09 +00:00
|
|
|
|
2021-09-11 17:38:55 +00:00
|
|
|
bool closed();
|
2021-09-10 10:28:09 +00:00
|
|
|
|
|
|
|
ChannelPtr createChannel();
|
|
|
|
|
|
|
|
/// RabbitMQHandler is thread safe. Any public methods can be called concurrently.
|
|
|
|
RabbitMQHandler & getHandler() { return event_handler; }
|
|
|
|
|
|
|
|
String connectionInfoForLog() const;
|
|
|
|
|
|
|
|
private:
|
2021-09-11 17:38:55 +00:00
|
|
|
bool isConnectedImpl() const;
|
|
|
|
|
|
|
|
void connectImpl();
|
|
|
|
|
|
|
|
void disconnectImpl(bool immediately = false);
|
|
|
|
|
2021-09-10 10:28:09 +00:00
|
|
|
RabbitMQConfiguration configuration;
|
|
|
|
Poco::Logger * log;
|
|
|
|
|
|
|
|
UVLoop loop;
|
2023-01-04 12:43:33 +00:00
|
|
|
/// Preserve order of destruction here:
|
|
|
|
/// destruct connection and handler before the loop above.
|
2021-09-10 10:28:09 +00:00
|
|
|
RabbitMQHandler event_handler;
|
|
|
|
std::unique_ptr<AMQP::TcpConnection> connection;
|
2023-01-04 12:43:33 +00:00
|
|
|
|
2021-09-10 10:28:09 +00:00
|
|
|
std::mutex mutex;
|
|
|
|
};
|
|
|
|
|
|
|
|
using RabbitMQConnectionPtr = std::unique_ptr<RabbitMQConnection>;
|
|
|
|
|
|
|
|
}
|