ClickHouse/base/loggers/OwnSplitChannel.h

48 lines
1.3 KiB
C++
Raw Normal View History

#pragma once
2019-07-19 07:44:18 +00:00
#include <atomic>
#include <vector>
2022-01-17 04:33:47 +00:00
#include <map>
#include <mutex>
#include <Poco/AutoPtr.h>
#include <Poco/Channel.h>
#include "ExtendedLogChannel.h"
2022-01-17 04:33:47 +00:00
namespace DB
{
class TextLog;
}
namespace DB
{
/// Works as Poco::SplitterChannel, but performs additional work:
/// passes logs to Client via TCP interface
/// tries to use extended logging interface of child for more comprehensive logging
class OwnSplitChannel : public Poco::Channel
{
public:
/// Makes an extended message from msg and passes it to the client logs queue and child (if possible)
void log(const Poco::Message & msg) override;
/// Adds a child channel
2021-09-30 19:46:12 +00:00
void addChannel(Poco::AutoPtr<Poco::Channel> channel, const std::string & name);
void addTextLog(std::shared_ptr<DB::TextLog> log, int max_priority);
2019-07-30 14:04:18 +00:00
2021-09-30 19:46:12 +00:00
void setLevel(const std::string & name, int level);
private:
2019-06-20 07:17:21 +00:00
void logSplit(const Poco::Message & msg);
void tryLogSplit(const Poco::Message & msg);
2019-06-20 07:17:21 +00:00
using ChannelPtr = Poco::AutoPtr<Poco::Channel>;
/// Handler and its pointer casted to extended interface
using ExtendedChannelPtrPair = std::pair<ChannelPtr, ExtendedLogChannel *>;
2021-09-30 19:46:12 +00:00
std::map<std::string, ExtendedChannelPtrPair> channels;
2019-07-30 14:04:18 +00:00
2019-07-31 14:42:23 +00:00
std::mutex text_log_mutex;
2019-07-30 14:04:18 +00:00
std::weak_ptr<DB::TextLog> text_log;
2020-03-18 11:59:40 +00:00
std::atomic<int> text_log_max_priority = -1;
};
}