mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-15 19:02:04 +00:00
76 lines
2.2 KiB
C++
76 lines
2.2 KiB
C++
#pragma once
|
|
|
|
#pragma once
|
|
|
|
#include <Processors/Sinks/SinkToStorage.h>
|
|
#include <Interpreters/Context.h>
|
|
#include <Core/BackgroundSchedulePool.h>
|
|
|
|
namespace Poco { class Logger; }
|
|
|
|
namespace DB
|
|
{
|
|
|
|
/// Interface for producing messages in streaming storages.
|
|
/// It's used in MessageQueueSink.
|
|
class IMessageProducer
|
|
{
|
|
public:
|
|
explicit IMessageProducer(Poco::Logger * log_);
|
|
|
|
/// Do some preparations.
|
|
virtual void start(const ContextPtr & context) = 0;
|
|
|
|
/// Produce single message.
|
|
virtual void produce(const String & message, size_t rows_in_message, const Columns & columns, size_t last_row) = 0;
|
|
|
|
/// Finalize producer.
|
|
virtual void finish() = 0;
|
|
|
|
virtual ~IMessageProducer() = default;
|
|
|
|
protected:
|
|
Poco::Logger * log;
|
|
};
|
|
|
|
/// Implements interface for concurrent message producing.
|
|
class AsynchronousMessageProducer : public IMessageProducer
|
|
{
|
|
public:
|
|
explicit AsynchronousMessageProducer(Poco::Logger * log_) : IMessageProducer(log_) {}
|
|
|
|
/// Create and schedule task in BackgroundSchedulePool that will produce messages.
|
|
void start(const ContextPtr & context) override;
|
|
|
|
/// Stop producing task, wait for ot to finish and finalize.
|
|
void finish() override;
|
|
|
|
/// In this method producer should not do any hard work and send message
|
|
/// to producing task, for example, by using ConcurrentBoundedQueue.
|
|
void produce(const String & message, size_t rows_in_message, const Columns & columns, size_t last_row) override = 0;
|
|
|
|
protected:
|
|
/// Do some initialization before scheduling producing task.
|
|
virtual void initialize() {}
|
|
/// Tell producer to finish all work and stop producing task
|
|
virtual void stopProducingTask() = 0;
|
|
/// Do some finalization after producing task is stopped.
|
|
virtual void finishImpl() {}
|
|
|
|
virtual String getProducingTaskName() const = 0;
|
|
/// Method that is called inside producing task, all producing work should be done here.
|
|
virtual void startProducingTaskLoop() = 0;
|
|
|
|
private:
|
|
/// Flag, indicated that finish() method was called.
|
|
/// It's used to prevent doing finish logic more than once.
|
|
std::atomic<bool> finished = false;
|
|
|
|
BackgroundSchedulePool::TaskHolder producing_task;
|
|
|
|
std::atomic<bool> scheduled;
|
|
};
|
|
|
|
|
|
}
|