2021-09-16 21:19:58 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <Storages/MergeTree/MergeTreeData.h>
|
|
|
|
#include <Storages/MergeTree/MergeProgress.h>
|
|
|
|
#include <Storages/MergeTree/FutureMergedMutatedPart.h>
|
|
|
|
#include <Storages/MergeTree/IMergedBlockOutputStream.h>
|
|
|
|
#include <Storages/MutationCommands.h>
|
|
|
|
#include <Interpreters/MutationsInterpreter.h>
|
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
class MutateTask;
|
2022-04-20 19:08:26 +00:00
|
|
|
using MutateTaskPtr = std::shared_ptr<MutateTask>;
|
2021-09-16 21:19:58 +00:00
|
|
|
|
|
|
|
|
|
|
|
class MergeTreeDataMergerMutator;
|
|
|
|
|
|
|
|
struct MutationContext;
|
|
|
|
|
|
|
|
class MutateTask
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
MutateTask(
|
|
|
|
FutureMergedMutatedPartPtr future_part_,
|
|
|
|
StorageMetadataPtr metadata_snapshot_,
|
|
|
|
MutationCommandsConstPtr commands_,
|
|
|
|
MergeListEntry * mutate_entry_,
|
|
|
|
time_t time_of_mutation_,
|
|
|
|
ContextPtr context_,
|
|
|
|
ReservationSharedPtr space_reservation_,
|
|
|
|
TableLockHolder & table_lock_holder_,
|
2022-02-14 19:50:08 +00:00
|
|
|
const MergeTreeTransactionPtr & txn,
|
2021-09-16 21:19:58 +00:00
|
|
|
MergeTreeData & data_,
|
|
|
|
MergeTreeDataMergerMutator & mutator_,
|
|
|
|
ActionBlocker & merges_blocker_);
|
|
|
|
|
|
|
|
bool execute();
|
|
|
|
|
|
|
|
std::future<MergeTreeData::MutableDataPartPtr> getFuture()
|
|
|
|
{
|
|
|
|
return promise.get_future();
|
|
|
|
}
|
|
|
|
|
2022-04-19 13:53:10 +00:00
|
|
|
const MergeTreeData::HardlinkedFiles & getHardlinkedFiles() const;
|
|
|
|
|
2022-10-22 22:51:59 +00:00
|
|
|
MutableDataPartStoragePtr getBuilder() const;
|
2022-06-28 10:51:49 +00:00
|
|
|
|
2021-09-16 21:19:58 +00:00
|
|
|
private:
|
|
|
|
|
|
|
|
bool prepare();
|
|
|
|
|
|
|
|
enum class State
|
|
|
|
{
|
|
|
|
NEED_PREPARE,
|
|
|
|
NEED_EXECUTE
|
|
|
|
};
|
|
|
|
|
|
|
|
State state{State::NEED_PREPARE};
|
|
|
|
|
|
|
|
std::promise<MergeTreeData::MutableDataPartPtr> promise;
|
|
|
|
|
|
|
|
std::shared_ptr<MutationContext> ctx;
|
|
|
|
ExecutableTaskPtr task;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
[[ maybe_unused]] static MergeTreeData::MutableDataPartPtr executeHere(MutateTaskPtr task)
|
|
|
|
{
|
|
|
|
while (task->execute()) {}
|
|
|
|
return task->getFuture().get();
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|