Welcome to mirror list, hosted at ThFree Co, Russian Federation.

service_config.proto « proto - gitlab.com/gitlab-org/gitaly.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: f2286f7e3d452ea4e7f2c5648bd3dd991d920f1b (plain)
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
syntax = "proto3";

package gitaly;

import "google/protobuf/duration.proto";
import "google/protobuf/wrappers.proto";

option go_package = "gitlab.com/gitlab-org/gitaly/v16/proto/go/gitalypb";

// ServiceConfig defines the configuration that allows service owners to publish parameters to be
// automatically used by all clients of their service. gRPC doesn't export this protobuf. So, we
// built a minimized version to for Gitaly use. The completed version is defined at
// https://github.com/grpc/grpc-proto/blob/master/grpc/service_config/service_config.proto
message ServiceConfig {
  // load_balancing_config ...
  // protolint:disable:next REPEATED_FIELD_NAMES_PLURALIZED
  repeated LoadBalancingConfig load_balancing_config = 1;
  // method_config ...
  // protolint:disable:next REPEATED_FIELD_NAMES_PLURALIZED
  repeated MethodConfig method_config = 2;
}

// LoadBalancingConfig wraps around the round-robin strategies. Only one strategy can be selected.
message LoadBalancingConfig {
  // policy ...
  oneof policy {
    // pick_first strategy
    PickFirstConfig pick_first = 1 [json_name = "pick_first"];
    // round_robin strategy
    RoundRobinConfig round_robin = 2 [json_name = "round_robin"];
  }
}

// PickFirstConfig signals the pick_first load-balancing strategy. This strategy is the default
// strategy of grpc client libraries so that the connection has only one subchannel, which is the
// first address after resolution
message PickFirstConfig {
}

// RoundRobinConfig indicates the round_robin strategy. This strategy distributes the incoming
// requests to active subchannels in a round-robin fashion.
message RoundRobinConfig {
}

// MethodConfig is the configuration for a method.
message MethodConfig {
  // Name is an object indicating which services/methods being affected by the config
  message Name {
    // service is name of the service,including its package. For example: gitaly.SmartHTTPService
    string service = 1;
    // method is the name of the method within the above service. Empty method name implies the
    // method policy is effective for all methods of the service
    string method = 2;
  }

  // RetryPolicy defines the configuration for exponential backoff when a request fails
  message RetryPolicy {
    // max_attempts is the total retry attempts client perform before bailing out
    uint32 max_attempts = 1;
    // initial_backoff is the minimum delay for the first retries
    google.protobuf.Duration initial_backoff = 2;
    // max_backoff is the minimum delay
    google.protobuf.Duration max_backoff = 3;
    // backoff_multiplier is the factor determining "how fast" the delay increases after each retry
    float backoff_multiplier = 4;
    // retryable_status_codes defines the list of eligible status codes. The status must be in
    // capitalized snake_case form. For example, UNAVAILABLE, FAILED_PRECONDITION
    repeated string retryable_status_codes = 5;
  }

  // name defines the list of affected services/methods
  // The name should be  is the definition of grpc. Nothing we can do about it
  // protolint:disable:next REPEATED_FIELD_NAMES_PLURALIZED
  repeated Name name = 1;
  // The following fields are unused by Gitaly at the moment. Please refer to the original
  // documentation for more information
  // protolint:disable FIELDS_HAVE_COMMENT
  google.protobuf.BoolValue wait_for_ready = 2;
  google.protobuf.Duration timeout = 3;
  google.protobuf.UInt32Value max_request_message_bytes = 4;
  google.protobuf.UInt32Value max_response_message_bytes = 5;

  // retry_policy defines the exponential backoff configuration for the affected services/methods
  // protolint:enable FIELDS_HAVE_COMMENT
  RetryPolicy retry_policy = 6;
}