1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219
|
syntax = "proto3";
package gitaly;
import "google/protobuf/timestamp.proto";
import "lint.proto";
import "shared.proto";
option go_package = "gitlab.com/gitlab-org/gitaly/v16/proto/go/gitalypb";
// PraefectInfoService is a service which provides RPCs to query and modify
// Praefect-specific parameters.
service PraefectInfoService {
option (intercepted) = true;
// This comment is left unintentionally blank.
rpc RepositoryReplicas(RepositoryReplicasRequest) returns (RepositoryReplicasResponse);
// DatalossCheck checks for unavailable repositories.
rpc DatalossCheck(DatalossCheckRequest) returns (DatalossCheckResponse);
// SetAuthoritativeStorage sets the authoritative storage for a repository on a given virtual storage.
// This causes the current version of the repository on the authoritative storage to be considered the
// latest and overwrite any other version on the virtual storage.
rpc SetAuthoritativeStorage(SetAuthoritativeStorageRequest) returns (SetAuthoritativeStorageResponse);
// MarkUnverified marks replicas as unverified. This will trigger verification as Praefect's metadata
// verifier prioritizes unverified replicas.
rpc MarkUnverified(MarkUnverifiedRequest) returns (MarkUnverifiedResponse);
// SetReplicationFactor assigns or unassigns host nodes from the repository to meet the desired replication factor.
// SetReplicationFactor returns an error when trying to set a replication factor that exceeds the storage node count
// in the virtual storage. An error is also returned when trying to set a replication factor below one. The primary node
// won't be unassigned as it needs a copy of the repository to accept writes. Likewise, the primary is the first storage
// that gets assigned when setting a replication factor for a repository. Assignments of unconfigured storages are ignored.
// This might cause the actual replication factor to be higher than desired if the replication factor is set during an upgrade
// from a Praefect node that does not yet know about a new node. As assignments of unconfigured storages are ignored, replication
// factor of repositories assigned to a storage node removed from the cluster is effectively decreased.
rpc SetReplicationFactor(SetReplicationFactorRequest) returns (SetReplicationFactorResponse);
// GetRepositoryMetadata returns the cluster metadata for a repository. Returns NotFound if the repository does not exist.
rpc GetRepositoryMetadata(GetRepositoryMetadataRequest) returns (GetRepositoryMetadataResponse);
}
// MarkUnverifiedRequest specifies the replicas which to mark unverified.
message MarkUnverifiedRequest {
// Storage identifies a single storage in a virtual storage.
message Storage {
// virtual_storage is the virtual storage the storage is part of.
string virtual_storage = 1;
// storage is the name of the storage.
string storage = 2;
}
// selector specifies the replicas which to mark unverified.
oneof selector {
// repository_id is the id of a repository to mark all replicas for unverified.
int64 repository_id = 1;
// virtual_storage is the name of virtual storage which will have all of its replicas
// marked unverified.
string virtual_storage = 2;
// storage specifies a single storage. The replicas on the storage marked unverified.
Storage storage = 3;
}
}
// MarkUnverifiedResponse returns the number of replicas marked unverified.
message MarkUnverifiedResponse {
// replicas_marked indicates the number of replicas that were marked unverified.
int64 replicas_marked = 1;
}
// GetRepositoryMetadataRequest specifies the repository to retrieve metadata for.
message GetRepositoryMetadataRequest {
// This comment is left unintentionally blank.
message Path {
// virtual_storage is the virtual storage where the repository is.
string virtual_storage = 1;
// relative_path is the relative path of the repository in the virtual storage.
string relative_path = 2;
}
oneof query {
// repository_id is the ID of the repository to retrieve information for.
int64 repository_id = 1;
// path is the external path of the repository to retrieve information for.
Path path = 2;
};
}
// GeRepositoryMetadataResponse contains the repository's cluster metadata.
message GetRepositoryMetadataResponse {
// This comment is left unintentionally blank.
message Replica {
// storage is the name of the replica's storage.
string storage = 1;
// assigned indicates whether the replica is on an assigned storage.
bool assigned = 2;
// generation is the replicas confirmed generation. Generation is -1 if the replica
// does not yet exist.
int64 generation = 4;
// healthy indicates whether the replica is on a healthy storage.
bool healthy = 5;
// valid_primary indicates whether the replica is considered a valid primary.
bool valid_primary = 6;
// verified_at is the last successful verification time of the replica.
google.protobuf.Timestamp verified_at = 7;
}
// repository_id is the internal ID of the repository.
int64 repository_id = 1;
// virtual_storage is the virtual storage in which the repository is located.
string virtual_storage = 2;
// relative_path is the relative path of the repository in the virtual storage.
string relative_path = 3;
// replica_path is the path on the disk where the replicas are stored.
string replica_path = 4;
// primary is the current primary of the repository.
string primary = 5;
// generation is the repository's current generation.
int64 generation = 6;
// replicas are the existing and supposed to exist replicas of this repository.
repeated Replica replicas = 7;
}
// SetReplicationFactorRequest sets the desired replication factor for a repository.
message SetReplicationFactorRequest {
// virtual_storage is the virtual storage the repository is located in
string virtual_storage = 1;
// relative_path is the relative path of the repository
string relative_path = 2;
// replication_factor is the desired replication factor. Replication must be equal or greater than 1.
int32 replication_factor = 3;
}
// SetReplicationFactorResponse returns the assigned hosts after setting the desired replication factor.
message SetReplicationFactorResponse {
// storages are the storages assigned to host the repository.
repeated string storages = 1;
}
// This comment is left unintentionally blank.
message SetAuthoritativeStorageRequest {
// This comment is left unintentionally blank.
string virtual_storage = 1;
// This comment is left unintentionally blank.
string relative_path = 2;
// This comment is left unintentionally blank.
string authoritative_storage = 3;
}
// This comment is left unintentionally blank.
message SetAuthoritativeStorageResponse {
}
// This comment is left unintentionally blank.
message DatalossCheckRequest {
// This comment is left unintentionally blank.
string virtual_storage = 1;
// include_partially_unavailable indicates whether to include repositories which are available but
// are unavailable on some assigned storages.
bool include_partially_replicated = 2;
}
// This comment is left unintentionally blank.
message DatalossCheckResponse {
// This comment is left unintentionally blank.
message Repository {
// This comment is left unintentionally blank.
message Storage {
// name of the storage
string name = 1;
// behind_by indicates how many generations this storage is behind.
int64 behind_by = 2;
// assigned indicates whether the storage is assigned to host the repository.
bool assigned = 3;
// healthy indicates whether the storage is considered healthy by the consensus of Praefect nodes.
bool healthy = 4;
// valid_primary indicates whether the storage is ready to act as the primary if necessary.
bool valid_primary = 5;
}
// relative path of the repository with outdated replicas
string relative_path = 1;
// storages on which the repository is outdated
repeated Storage storages = 2;
// unavailable indicates whether the repository is in unavailable.
bool unavailable = 3;
// current primary storage of the repository
string primary = 4;
}
// repositories with data loss
repeated Repository repositories = 2;
}
// This comment is left unintentionally blank.
message RepositoryReplicasRequest{
// This comment is left unintentionally blank.
Repository repository = 1;
}
// This comment is left unintentionally blank.
message RepositoryReplicasResponse{
// This comment is left unintentionally blank.
message RepositoryDetails {
// This comment is left unintentionally blank.
Repository repository = 1;
// This comment is left unintentionally blank.
string checksum = 2;
};
// This comment is left unintentionally blank.
RepositoryDetails primary = 1;
// This comment is left unintentionally blank.
repeated RepositoryDetails replicas = 2;
}
|