2021-07-15 16:15:16 +00:00
|
|
|
#pragma once
|
|
|
|
#include <Processors/QueryPlan/ISourceStep.h>
|
|
|
|
#include <Core/QueryProcessingStage.h>
|
|
|
|
#include <Storages/IStorage_fwd.h>
|
|
|
|
#include <Interpreters/StorageID.h>
|
|
|
|
#include <Interpreters/ClusterProxy/IStreamFactory.h>
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
|
|
|
class ConnectionPoolWithFailover;
|
|
|
|
using ConnectionPoolWithFailoverPtr = std::shared_ptr<ConnectionPoolWithFailover>;
|
|
|
|
|
|
|
|
class Throttler;
|
|
|
|
using ThrottlerPtr = std::shared_ptr<Throttler>;
|
|
|
|
|
2021-07-16 10:56:13 +00:00
|
|
|
/// Reading step from remote servers.
|
|
|
|
/// Unite query results from several shards.
|
2021-07-15 16:15:16 +00:00
|
|
|
class ReadFromRemote final : public ISourceStep
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
ReadFromRemote(
|
|
|
|
ClusterProxy::IStreamFactory::Shards shards_,
|
|
|
|
Block header_,
|
|
|
|
QueryProcessingStage::Enum stage_,
|
|
|
|
StorageID main_table_,
|
|
|
|
ASTPtr table_func_ptr_,
|
|
|
|
ContextPtr context_,
|
|
|
|
ThrottlerPtr throttler_,
|
|
|
|
Scalars scalars_,
|
|
|
|
Tables external_tables_,
|
2021-07-31 07:45:26 +00:00
|
|
|
Poco::Logger * log_,
|
|
|
|
UInt32 shard_count_);
|
2021-07-15 16:15:16 +00:00
|
|
|
|
|
|
|
String getName() const override { return "ReadFromRemote"; }
|
|
|
|
|
|
|
|
void initializePipeline(QueryPipeline & pipeline, const BuildQueryPipelineSettings &) override;
|
|
|
|
|
|
|
|
private:
|
|
|
|
ClusterProxy::IStreamFactory::Shards shards;
|
|
|
|
QueryProcessingStage::Enum stage;
|
|
|
|
|
|
|
|
StorageID main_table;
|
|
|
|
ASTPtr table_func_ptr;
|
|
|
|
|
|
|
|
ContextPtr context;
|
|
|
|
|
|
|
|
ThrottlerPtr throttler;
|
|
|
|
Scalars scalars;
|
|
|
|
Tables external_tables;
|
|
|
|
|
|
|
|
Poco::Logger * log;
|
|
|
|
|
2021-07-31 07:45:26 +00:00
|
|
|
UInt32 shard_count;
|
2021-07-15 16:15:16 +00:00
|
|
|
void addLazyPipe(Pipes & pipes, const ClusterProxy::IStreamFactory::Shard & shard);
|
|
|
|
void addPipe(Pipes & pipes, const ClusterProxy::IStreamFactory::Shard & shard);
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|