Skip to content

Commit

Permalink
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add lagging agent concept to the volume
Browse files Browse the repository at this point in the history
komarevtsev-d committed Jan 5, 2025

Unverified

This user has not yet uploaded their public signing key.
1 parent 2398e8e commit 99e7632
Showing 37 changed files with 1,681 additions and 93 deletions.
4 changes: 4 additions & 0 deletions cloud/blockstore/libs/storage/api/disk_registry.h
Original file line number Diff line number Diff line change
@@ -53,6 +53,7 @@ namespace NCloud::NBlockStore::NStorage {
xxx(GetCheckpointDataState, __VA_ARGS__) \
xxx(SetCheckpointDataState, __VA_ARGS__) \
xxx(GetAgentNodeId, __VA_ARGS__) \
xxx(AddLaggingDevices, __VA_ARGS__) \
// BLOCKSTORE_DISK_REGISTRY_REQUESTS_PROTO

// requests forwarded from service to disk_registry
@@ -211,6 +212,9 @@ struct TEvDiskRegistry
EvQueryAgentsInfoRequest = EvBegin + 75,
EvQueryAgentsInfoResponse = EvBegin + 76,

EvAddLaggingDevicesRequest = EvBegin + 77,
EvAddLaggingDevicesResponse = EvBegin + 78,

EvEnd
};

34 changes: 33 additions & 1 deletion cloud/blockstore/libs/storage/api/partition.h
Original file line number Diff line number Diff line change
@@ -15,7 +15,7 @@ namespace NCloud::NBlockStore::NStorage::NPartition {
xxx(Drain, __VA_ARGS__) \
// BLOCKSTORE_PARTITION_REQUESTS

// requests forwarded from service to partion
// requests forwarded from service to partition
#define BLOCKSTORE_PARTITION_REQUESTS_FWD_SERVICE(xxx, ...) \
xxx(ReadBlocks, __VA_ARGS__) \
xxx(WriteBlocks, __VA_ARGS__) \
@@ -94,6 +94,25 @@ struct TEvPartition
{}
};

//
// AddLaggingAgent
//

struct TAddLaggingAgentRequest
{
// 0 - for main devices; 1,2 - for mirror replicas
ui32 ReplicaIndex;
TString AgentId;
TAddLaggingAgentRequest(ui32 replicaIndex, TString agentId)
: ReplicaIndex(replicaIndex)
, AgentId(std::move(agentId))
{}
};

struct TAddLaggingAgentResponse
{
};

//
// Events declaration
//
@@ -115,6 +134,9 @@ struct TEvPartition

EvGarbageCollectorCompleted = EvBegin + 8,

EvAddLaggingAgentRequest = EvBegin + 9,
EvAddLaggingAgentResponse = EvBegin + 10,

EvEnd
};

@@ -132,6 +154,16 @@ struct TEvPartition
TGarbageCollectorCompleted,
EvGarbageCollectorCompleted
>;

using TEvAddLaggingAgentRequest = TRequestEvent<
TAddLaggingAgentRequest,
EvAddLaggingAgentRequest
>;

using TEvAddLaggingAgentResponse = TResponseEvent<
TAddLaggingAgentResponse,
EvAddLaggingAgentResponse
>;
};

} // namespace NCloud::NBlockStore::NStorage::NPartition
Original file line number Diff line number Diff line change
@@ -588,6 +588,18 @@ void TDiskRegistryActor::HandleOperationCompleted(
Actors.erase(ev->Sender);
}

void TDiskRegistryActor::HandleAddLaggingDevices(
const TEvDiskRegistry::TEvAddLaggingDevicesRequest::TPtr& ev,
const TActorContext& ctx)
{
Y_UNUSED(ev);
Y_UNUSED(ctx);

BLOCKSTORE_DISK_REGISTRY_COUNTER(AddLaggingDevices);

// TODO(komarevtsev-d): Implement this.
}

////////////////////////////////////////////////////////////////////////////////

STFUNC(TDiskRegistryActor::StateBoot)
20 changes: 19 additions & 1 deletion cloud/blockstore/libs/storage/partition_nonrepl/config.h
Original file line number Diff line number Diff line change
@@ -61,6 +61,8 @@ class TNonreplicatedPartitionConfig
const NActors::TActorId ParentActorId;
const bool MuteIOErrors;
const THashSet<TString> FreshDeviceIds;
// List of devices that have outdated data. Can only appear on mirror disks.
const THashSet<TString> LaggingDeviceIds;
const TDuration MaxTimedOutDeviceStateDuration;
const bool MaxTimedOutDeviceStateDurationOverridden;
const bool UseSimpleMigrationBandwidthLimiter;
@@ -77,6 +79,7 @@ class TNonreplicatedPartitionConfig
NActors::TActorId parentActorId,
bool muteIOErrors,
THashSet<TString> freshDeviceIds,
THashSet<TString> laggingDeviceIds,
TDuration maxTimedOutDeviceStateDuration,
bool maxTimedOutDeviceStateDurationOverridden,
bool useSimpleMigrationBandwidthLimiter)
@@ -88,6 +91,7 @@ class TNonreplicatedPartitionConfig
, ParentActorId(std::move(parentActorId))
, MuteIOErrors(muteIOErrors)
, FreshDeviceIds(std::move(freshDeviceIds))
, LaggingDeviceIds(std::move(laggingDeviceIds))
, MaxTimedOutDeviceStateDuration(maxTimedOutDeviceStateDuration)
, MaxTimedOutDeviceStateDurationOverridden(maxTimedOutDeviceStateDurationOverridden)
, UseSimpleMigrationBandwidthLimiter(useSimpleMigrationBandwidthLimiter)
@@ -111,6 +115,13 @@ class TNonreplicatedPartitionConfig
}
}

THashSet<TString> laggingDeviceIds;
for (const auto& device: devices) {
if (LaggingDeviceIds.contains(device.GetDeviceUUID())) {
laggingDeviceIds.insert(device.GetDeviceUUID());
}
}

return std::make_shared<TNonreplicatedPartitionConfig>(
std::move(devices),
IOMode,
@@ -120,6 +131,7 @@ class TNonreplicatedPartitionConfig
ParentActorId,
MuteIOErrors,
std::move(freshDeviceIds),
std::move(laggingDeviceIds),
MaxTimedOutDeviceStateDuration,
MaxTimedOutDeviceStateDurationOverridden,
UseSimpleMigrationBandwidthLimiter
@@ -176,6 +188,11 @@ class TNonreplicatedPartitionConfig
return FreshDeviceIds;
}

const auto& GetLaggingDeviceIds() const
{
return LaggingDeviceIds;
}

auto GetMaxTimedOutDeviceStateDuration() const
{
return MaxTimedOutDeviceStateDuration;
@@ -229,7 +246,8 @@ class TNonreplicatedPartitionConfig
Y_UNUSED(relativeRange);

return !Devices[i].GetDeviceUUID()
|| FreshDeviceIds.contains(Devices[i].GetDeviceUUID());
|| FreshDeviceIds.contains(Devices[i].GetDeviceUUID())
|| LaggingDeviceIds.contains(Devices[i].GetDeviceUUID());
});
}

Original file line number Diff line number Diff line change
@@ -181,6 +181,7 @@ TNonreplicatedPartitionConfigPtr MakePartitionConfig(
NActors::TActorId(),
false, // muteIOErrors
THashSet<TString>(), // freshDeviceIds
THashSet<TString>(), // laggingDeviceIds
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
useSimpleMigrationBandwidthLimiter);
Original file line number Diff line number Diff line change
@@ -266,11 +266,12 @@ struct TTestEnv
// only SSD/HDD distinction matters
NProto::STORAGE_MEDIA_SSD_MIRROR3},
VolumeActorId,
false, // muteIOErrors
false, // muteIOErrors
std::move(freshDeviceIds),
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
true // useSimpleMigrationBandwidthLimiter
THashSet<TString>(), // laggingDeviceIds
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
true // useSimpleMigrationBandwidthLimiter
);

for (auto& replica: Replicas) {
Original file line number Diff line number Diff line change
@@ -60,11 +60,12 @@ struct TEnv
4_KB,
volumeInfo,
NActors::TActorId(),
false, // muteIOErrors
false, // muteIOErrors
FreshDeviceIds,
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
true // useSimpleMigrationBandwidthLimiter
THashSet<TString>(), // laggingDeviceIds
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
true // useSimpleMigrationBandwidthLimiter
);

{
Original file line number Diff line number Diff line change
@@ -200,11 +200,12 @@ struct TTestEnv
// only SSD/HDD distinction matters
NProto::STORAGE_MEDIA_SSD_MIRROR3},
VolumeActorId,
false, // muteIOErrors
false, // muteIOErrors
std::move(freshDeviceIds),
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
true // useSimpleMigrationBandwidthLimiter
THashSet<TString>(), // laggingDeviceIds
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
true // useSimpleMigrationBandwidthLimiter
);

for (auto& replica: replicas) {
Original file line number Diff line number Diff line change
@@ -202,12 +202,12 @@ struct TTestEnv
// only SSD/HDD distinction matters
NProto::STORAGE_MEDIA_SSD_NONREPLICATED},
VolumeActorId,
false, // muteIOErrors
THashSet<TString>(), // freshDeviceIds
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
false
);
false, // muteIOErrors
THashSet<TString>(), // freshDeviceIds
THashSet<TString>(), // laggingDeviceIds
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
false);

auto part = std::make_unique<TNonreplicatedPartitionMigrationActor>(
std::move(config),
Original file line number Diff line number Diff line change
@@ -129,11 +129,12 @@ struct TTestEnv
// only SSD/HDD distinction matters
NProto::STORAGE_MEDIA_SSD_NONREPLICATED},
VolumeActorId,
false, // muteIOErrors
THashSet<TString>(), // freshDeviceIds
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
false // useSimpleMigrationBandwidthLimiter
false, // muteIOErrors
THashSet<TString>(), // freshDeviceIds
THashSet<TString>(), // laggingDeviceIds
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
false // useSimpleMigrationBandwidthLimiter
);

auto part = std::make_unique<TNonreplicatedPartitionRdmaActor>(
Original file line number Diff line number Diff line change
@@ -131,10 +131,11 @@ struct TTestEnv
TNonreplicatedPartitionConfig::TVolumeInfo{Now(), params.MediaKind},
VolumeActorId,
params.MuteIOErrors,
THashSet<TString>(), // freshDeviceIds
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
false // useSimpleMigrationBandwidthLimiter
THashSet<TString>(), // freshDeviceIds
THashSet<TString>(), // laggingDeviceIds
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
false // useSimpleMigrationBandwidthLimiter
);

auto part = std::make_unique<TNonreplicatedPartitionActor>(
Original file line number Diff line number Diff line change
@@ -134,11 +134,12 @@ struct TTestEnv
// only SSD/HDD distinction matters
NProto::STORAGE_MEDIA_SSD_NONREPLICATED},
VolumeActorId,
false, // muteIOErrors
THashSet<TString>(), // freshDeviceIds
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
true // useSimpleMigrationBandwidthLimiter
false, // muteIOErrors
THashSet<TString>(), // freshDeviceIds
THashSet<TString>(), // laggingDeviceIds
TDuration::Zero(), // maxTimedOutDeviceStateDuration
false, // maxTimedOutDeviceStateDurationOverridden
true // useSimpleMigrationBandwidthLimiter
);

auto part = std::make_unique<TNonreplicatedPartitionActor>(
62 changes: 62 additions & 0 deletions cloud/blockstore/libs/storage/protos/disk.proto
Original file line number Diff line number Diff line change
@@ -278,6 +278,9 @@ message TDiskConfig

// A log of important events in the life of this disk.
repeated TDiskHistoryItem History = 17;

// A list of devices that are lagging begind on writes.
repeated TLaggingDevice LaggingDevices = 18;
}

////////////////////////////////////////////////////////////////////////////////
@@ -417,6 +420,41 @@ message TAgentStats

////////////////////////////////////////////////////////////////////////////////

message TLaggingDevice
{
// UUID of the lagging device.
string DeviceUUID = 1;

// Index of the lagging device in the replica.
uint32 RowIndex = 2;
}

////////////////////////////////////////////////////////////////////////////////

message TLaggingAgent
{
// Agent id.
string AgentId = 1;

// Index of the mirror disk replica.
// 0 - main devices
// 1,2 - replica devices
uint32 ReplicaIndex = 2;

// A list of devices that belong to the agent.
repeated TLaggingDevice Devices = 3;
}

////////////////////////////////////////////////////////////////////////////////

message TLaggingAgentsInfo
{
// A list of agents that lagging behind on writes.
repeated TLaggingAgent Agents = 1;
}

////////////////////////////////////////////////////////////////////////////////

message TDiskRegistryAgentListRequestParams
{
repeated string AgentIds = 1;
@@ -635,6 +673,9 @@ message TAllocateDiskResponse

// New devices used instead of recently replaced ones.
repeated string DeviceReplacementUUIDs = 8;

// Devices that had been lagging.
repeated TLaggingDevice RemovedLaggingDevices = 9;
}

////////////////////////////////////////////////////////////////////////////////
@@ -1662,6 +1703,27 @@ message TGetAgentNodeIdResponse
bool Connected = 4;
}

////////////////////////////////////////////////////////////////////////////////
// Report that some of the devices were lagging.

message TAddLaggingDevicesRequest
{
// Optional request headers.
THeaders Headers = 1;

// Disk identifier to perform operations on.
string DiskId = 2;

// Devices that has been lagging.
repeated TLaggingDevice LaggingDevices = 3;
}

message TAddLaggingDevicesResponse
{
// Optional error, set only if error happened.
NCloud.NProto.TError Error = 1;
}

////////////////////////////////////////////////////////////////////////////////
// Get dependent disks

Loading

0 comments on commit 99e7632

Please sign in to comment.