forked from pingcap/tiflash
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
storage: Use mmap to view vector index (pingcap#165)
Signed-off-by: Wish <[email protected]>
- Loading branch information
1 parent
d99c7dd
commit 27d7e64
Showing
35 changed files
with
2,108 additions
and
835 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,125 @@ | ||
// Copyright 2023 PingCAP, Inc. | ||
// | ||
// Licensed under the Apache License, Version 2.0 (the "License"); | ||
// you may not use this file except in compliance with the License. | ||
// You may obtain a copy of the License at | ||
// | ||
// http://www.apache.org/licenses/LICENSE-2.0 | ||
// | ||
// Unless required by applicable law or agreed to in writing, software | ||
// distributed under the License is distributed on an "AS IS" BASIS, | ||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
// See the License for the specific language governing permissions and | ||
// limitations under the License. | ||
|
||
#pragma once | ||
|
||
#include <DataStreams/BlockIO.h> | ||
#include <Flash/Coprocessor/ChunkCodec.h> | ||
#include <Flash/Coprocessor/DAGPipeline.h> | ||
#include <Flash/Coprocessor/DAGStorageInterpreter.h> | ||
#include <Flash/Coprocessor/TiDBTableScan.h> | ||
#include <Interpreters/AggregateDescription.h> | ||
#include <Interpreters/Context_fwd.h> | ||
#include <Interpreters/ExpressionActions.h> | ||
#include <Storages/TableLockHolder.h> | ||
#include <TiDB/Schema/TiDB.h> | ||
#pragma GCC diagnostic push | ||
#pragma GCC diagnostic ignored "-Wunused-parameter" | ||
#pragma GCC diagnostic ignored "-Wnon-virtual-dtor" | ||
#include <kvproto/coprocessor.pb.h> | ||
#include <pingcap/coprocessor/Client.h> | ||
#include <tipb/select.pb.h> | ||
#pragma GCC diagnostic pop | ||
|
||
namespace DB | ||
{ | ||
class DAGQueryBlock; | ||
class ExchangeReceiver; | ||
class DAGExpressionAnalyzer; | ||
struct SubqueryForSet; | ||
class Join; | ||
class Expand2; | ||
using JoinPtr = std::shared_ptr<Join>; | ||
using Expand2Ptr = std::shared_ptr<Expand2>; | ||
|
||
/** build ch plan from dag request: dag executors -> ch plan | ||
*/ | ||
class DAGQueryBlockInterpreter | ||
{ | ||
public: | ||
DAGQueryBlockInterpreter( | ||
Context & context_, | ||
const std::vector<BlockInputStreams> & input_streams_vec_, | ||
const DAGQueryBlock & query_block_, | ||
size_t max_streams_); | ||
|
||
~DAGQueryBlockInterpreter() = default; | ||
|
||
BlockInputStreams execute(); | ||
|
||
#ifndef DBMS_PUBLIC_GTEST | ||
private: | ||
#endif | ||
void executeImpl(DAGPipeline & pipeline); | ||
void handleMockTableScan(const TiDBTableScan & table_scan, DAGPipeline & pipeline); | ||
void handleTableScan(const TiDBTableScan & table_scan, DAGPipeline & pipeline); | ||
void handleJoin( | ||
const tipb::Join & join, | ||
DAGPipeline & pipeline, | ||
SubqueryForSet & right_query, | ||
size_t fine_grained_shuffle_count); | ||
void handleExchangeReceiver(DAGPipeline & pipeline); | ||
void handleMockExchangeReceiver(DAGPipeline & pipeline); | ||
void handleProjection(DAGPipeline & pipeline, const tipb::Projection & projection); | ||
void handleWindow(DAGPipeline & pipeline, const tipb::Window & window, bool enable_fine_grained_shuffle); | ||
void handleWindowOrder(DAGPipeline & pipeline, const tipb::Sort & window_sort, bool enable_fine_grained_shuffle); | ||
void handleExpand2(DAGPipeline & pipeline, const tipb::Expand2 & expand2); | ||
void executeWhere( | ||
DAGPipeline & pipeline, | ||
const ExpressionActionsPtr & expressionActionsPtr, | ||
String & filter_column, | ||
const String & extra_info = ""); | ||
void executeWindowOrder(DAGPipeline & pipeline, SortDescription sort_desc, bool enable_fine_grained_shuffle); | ||
void executeOrder(DAGPipeline & pipeline, const NamesAndTypes & order_columns); | ||
void executeLimit(DAGPipeline & pipeline); | ||
void executeExpand(DAGPipeline & pipeline, const ExpressionActionsPtr & expr); | ||
void executeExpand2(DAGPipeline & pipeline, const Expand2Ptr & expand); | ||
void executeWindow( | ||
DAGPipeline & pipeline, | ||
WindowDescription & window_description, | ||
bool enable_fine_grained_shuffle); | ||
void executeAggregation( | ||
DAGPipeline & pipeline, | ||
const ExpressionActionsPtr & expression_actions_ptr, | ||
const Names & key_names, | ||
const TiDB::TiDBCollators & collators, | ||
AggregateDescriptions & aggregate_descriptions, | ||
bool is_final_agg, | ||
bool enable_fine_grained_shuffle); | ||
void executeProject(DAGPipeline & pipeline, NamesWithAliases & project_cols, const String & extra_info = ""); | ||
void handleExchangeSender(DAGPipeline & pipeline); | ||
void handleMockExchangeSender(DAGPipeline & pipeline); | ||
|
||
void recordProfileStreams(DAGPipeline & pipeline, const String & key); | ||
|
||
void recordJoinExecuteInfo(size_t build_side_index, const JoinPtr & join_ptr); | ||
|
||
void restorePipelineConcurrency(DAGPipeline & pipeline); | ||
|
||
DAGContext & dagContext() const; | ||
|
||
Context & context; | ||
std::vector<BlockInputStreams> input_streams_vec; | ||
const DAGQueryBlock & query_block; | ||
|
||
NamesWithAliases final_project; | ||
|
||
/// How many streams we ask for storage to produce, and in how many threads we will do further processing. | ||
size_t max_streams = 1; | ||
|
||
std::unique_ptr<DAGExpressionAnalyzer> analyzer; | ||
|
||
LoggerPtr log; | ||
}; | ||
} // namespace DB |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.