mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-15 02:41:59 +00:00
62 lines
1.7 KiB
C++
62 lines
1.7 KiB
C++
#pragma once
|
|
|
|
#if !defined(ARCADIA_BUILD)
|
|
#include <Common/config.h>
|
|
#endif
|
|
|
|
#include <memory>
|
|
#include <string>
|
|
|
|
namespace Poco::Net { class TCPServer; }
|
|
|
|
namespace DB
|
|
{
|
|
class GRPCServer;
|
|
|
|
/// Provides an unified interface to access a protocol implementing server
|
|
/// no matter what type it has (HTTPServer, TCPServer, MySQLServer, GRPCServer, ...).
|
|
class ProtocolServerAdapter
|
|
{
|
|
friend class ProtocolServers;
|
|
public:
|
|
ProtocolServerAdapter(ProtocolServerAdapter && src) = default;
|
|
ProtocolServerAdapter & operator =(ProtocolServerAdapter && src) = default;
|
|
ProtocolServerAdapter(const char * port_name_, std::unique_ptr<Poco::Net::TCPServer> tcp_server_);
|
|
|
|
#if USE_GRPC
|
|
ProtocolServerAdapter(const char * port_name_, std::unique_ptr<GRPCServer> grpc_server_);
|
|
#endif
|
|
|
|
/// Starts the server. A new thread will be created that waits for and accepts incoming connections.
|
|
void start() { impl->start(); }
|
|
|
|
/// Stops the server. No new connections will be accepted.
|
|
void stop() { impl->stop(); }
|
|
|
|
/// Returns the number of currently handled connections.
|
|
size_t currentConnections() const { return impl->currentConnections(); }
|
|
|
|
/// Returns the number of current threads.
|
|
size_t currentThreads() const { return impl->currentThreads(); }
|
|
|
|
const std::string & getPortName() const { return port_name; }
|
|
|
|
private:
|
|
class Impl
|
|
{
|
|
public:
|
|
virtual ~Impl() {}
|
|
virtual void start() = 0;
|
|
virtual void stop() = 0;
|
|
virtual size_t currentConnections() const = 0;
|
|
virtual size_t currentThreads() const = 0;
|
|
};
|
|
class TCPServerAdapterImpl;
|
|
class GRPCServerAdapterImpl;
|
|
|
|
std::string port_name;
|
|
std::unique_ptr<Impl> impl;
|
|
};
|
|
|
|
}
|