mirror of https://github.com/grpc/grpc-java.git
cds: Import Envoy load balancing extension protos. (#9133)
This commit is contained in:
parent
5686018d40
commit
e147b5ebfb
|
|
@ -129,6 +129,9 @@ envoy/extensions/filters/http/fault/v3/fault.proto
|
||||||
envoy/extensions/filters/http/rbac/v3/rbac.proto
|
envoy/extensions/filters/http/rbac/v3/rbac.proto
|
||||||
envoy/extensions/filters/http/router/v3/router.proto
|
envoy/extensions/filters/http/router/v3/router.proto
|
||||||
envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.proto
|
envoy/extensions/filters/network/http_connection_manager/v3/http_connection_manager.proto
|
||||||
|
envoy/extensions/load_balancing_policies/ring_hash/v3/ring_hash.proto
|
||||||
|
envoy/extensions/load_balancing_policies/round_robin/v3/round_robin.proto
|
||||||
|
envoy/extensions/load_balancing_policies/wrr_locality/v3/wrr_locality.proto
|
||||||
envoy/extensions/transport_sockets/tls/v3/cert.proto
|
envoy/extensions/transport_sockets/tls/v3/cert.proto
|
||||||
envoy/extensions/transport_sockets/tls/v3/common.proto
|
envoy/extensions/transport_sockets/tls/v3/common.proto
|
||||||
envoy/extensions/transport_sockets/tls/v3/secret.proto
|
envoy/extensions/transport_sockets/tls/v3/secret.proto
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,74 @@
|
||||||
|
syntax = "proto3";
|
||||||
|
|
||||||
|
package envoy.extensions.load_balancing_policies.ring_hash.v3;
|
||||||
|
|
||||||
|
import "google/protobuf/wrappers.proto";
|
||||||
|
|
||||||
|
import "udpa/annotations/status.proto";
|
||||||
|
import "validate/validate.proto";
|
||||||
|
|
||||||
|
option java_package = "io.envoyproxy.envoy.extensions.load_balancing_policies.ring_hash.v3";
|
||||||
|
option java_outer_classname = "RingHashProto";
|
||||||
|
option java_multiple_files = true;
|
||||||
|
option go_package = "github.com/envoyproxy/go-control-plane/envoy/extensions/load_balancing_policies/ring_hash/v3;ring_hashv3";
|
||||||
|
option (udpa.annotations.file_status).package_version_status = ACTIVE;
|
||||||
|
|
||||||
|
// [#protodoc-title: Ring Hash Load Balancing Policy]
|
||||||
|
|
||||||
|
// This configuration allows the built-in RING_HASH LB policy to be configured via the LB policy
|
||||||
|
// extension point. See the :ref:`load balancing architecture overview
|
||||||
|
// <arch_overview_load_balancing_types>` for more information.
|
||||||
|
// [#extension: envoy.clusters.lb_policy]
|
||||||
|
// [#next-free-field: 6]
|
||||||
|
message RingHash {
|
||||||
|
// The hash function used to hash hosts onto the ketama ring.
|
||||||
|
enum HashFunction {
|
||||||
|
// Currently defaults to XX_HASH.
|
||||||
|
DEFAULT_HASH = 0;
|
||||||
|
|
||||||
|
// Use `xxHash <https://github.com/Cyan4973/xxHash>`_.
|
||||||
|
XX_HASH = 1;
|
||||||
|
|
||||||
|
// Use `MurmurHash2 <https://sites.google.com/site/murmurhash/>`_, this is compatible with
|
||||||
|
// std:hash<string> in GNU libstdc++ 3.4.20 or above. This is typically the case when compiled
|
||||||
|
// on Linux and not macOS.
|
||||||
|
MURMUR_HASH_2 = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
// The hash function used to hash hosts onto the ketama ring. The value defaults to
|
||||||
|
// :ref:`XX_HASH<envoy_v3_api_enum_value_config.cluster.v3.Cluster.RingHashLbConfig.HashFunction.XX_HASH>`.
|
||||||
|
HashFunction hash_function = 1 [(validate.rules).enum = {defined_only: true}];
|
||||||
|
|
||||||
|
// Minimum hash ring size. The larger the ring is (that is, the more hashes there are for each
|
||||||
|
// provided host) the better the request distribution will reflect the desired weights. Defaults
|
||||||
|
// to 1024 entries, and limited to 8M entries. See also
|
||||||
|
// :ref:`maximum_ring_size<envoy_v3_api_field_config.cluster.v3.Cluster.RingHashLbConfig.maximum_ring_size>`.
|
||||||
|
google.protobuf.UInt64Value minimum_ring_size = 2 [(validate.rules).uint64 = {lte: 8388608}];
|
||||||
|
|
||||||
|
// Maximum hash ring size. Defaults to 8M entries, and limited to 8M entries, but can be lowered
|
||||||
|
// to further constrain resource use. See also
|
||||||
|
// :ref:`minimum_ring_size<envoy_v3_api_field_config.cluster.v3.Cluster.RingHashLbConfig.minimum_ring_size>`.
|
||||||
|
google.protobuf.UInt64Value maximum_ring_size = 3 [(validate.rules).uint64 = {lte: 8388608}];
|
||||||
|
|
||||||
|
// If set to `true`, the cluster will use hostname instead of the resolved
|
||||||
|
// address as the key to consistently hash to an upstream host. Only valid for StrictDNS clusters with hostnames which resolve to a single IP address.
|
||||||
|
bool use_hostname_for_hashing = 4;
|
||||||
|
|
||||||
|
// Configures percentage of average cluster load to bound per upstream host. For example, with a value of 150
|
||||||
|
// no upstream host will get a load more than 1.5 times the average load of all the hosts in the cluster.
|
||||||
|
// If not specified, the load is not bounded for any upstream host. Typical value for this parameter is between 120 and 200.
|
||||||
|
// Minimum is 100.
|
||||||
|
//
|
||||||
|
// This is implemented based on the method described in the paper https://arxiv.org/abs/1608.01350. For the specified
|
||||||
|
// `hash_balance_factor`, requests to any upstream host are capped at `hash_balance_factor/100` times the average number of requests
|
||||||
|
// across the cluster. When a request arrives for an upstream host that is currently serving at its max capacity, linear probing
|
||||||
|
// is used to identify an eligible host. Further, the linear probe is implemented using a random jump in hosts ring/table to identify
|
||||||
|
// the eligible host (this technique is as described in the paper https://arxiv.org/abs/1908.08762 - the random jump avoids the
|
||||||
|
// cascading overflow effect when choosing the next host in the ring/table).
|
||||||
|
//
|
||||||
|
// If weights are specified on the hosts, they are respected.
|
||||||
|
//
|
||||||
|
// This is an O(N) algorithm, unlike other load balancers. Using a lower `hash_balance_factor` results in more hosts
|
||||||
|
// being probed, so use a higher value if you require better performance.
|
||||||
|
google.protobuf.UInt32Value hash_balance_factor = 5 [(validate.rules).uint32 = {gte: 100}];
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,26 @@
|
||||||
|
syntax = "proto3";
|
||||||
|
|
||||||
|
package envoy.extensions.load_balancing_policies.round_robin.v3;
|
||||||
|
|
||||||
|
import "envoy/config/cluster/v3/cluster.proto";
|
||||||
|
|
||||||
|
import "udpa/annotations/status.proto";
|
||||||
|
import "validate/validate.proto";
|
||||||
|
|
||||||
|
option java_package = "io.envoyproxy.envoy.extensions.load_balancing_policies.round_robin.v3";
|
||||||
|
option java_outer_classname = "RoundRobinProto";
|
||||||
|
option java_multiple_files = true;
|
||||||
|
option go_package = "github.com/envoyproxy/go-control-plane/envoy/extensions/load_balancing_policies/round_robin/v3;round_robinv3";
|
||||||
|
option (udpa.annotations.file_status).package_version_status = ACTIVE;
|
||||||
|
|
||||||
|
// [#protodoc-title: Round Robin Load Balancing Policy]
|
||||||
|
|
||||||
|
// This configuration allows the built-in ROUND_ROBIN LB policy to be configured via the LB policy
|
||||||
|
// extension point. See the :ref:`load balancing architecture overview
|
||||||
|
// <arch_overview_load_balancing_types>` for more information.
|
||||||
|
// [#extension: envoy.clusters.lb_policy]
|
||||||
|
message RoundRobin {
|
||||||
|
// Configuration for slow start mode.
|
||||||
|
// If this configuration is not set, slow start will not be not enabled.
|
||||||
|
config.cluster.v3.Cluster.SlowStartConfig slow_start_config = 1;
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,25 @@
|
||||||
|
syntax = "proto3";
|
||||||
|
|
||||||
|
package envoy.extensions.load_balancing_policies.wrr_locality.v3;
|
||||||
|
|
||||||
|
import "envoy/config/cluster/v3/cluster.proto";
|
||||||
|
|
||||||
|
import "udpa/annotations/status.proto";
|
||||||
|
import "validate/validate.proto";
|
||||||
|
|
||||||
|
option java_package = "io.envoyproxy.envoy.extensions.load_balancing_policies.wrr_locality.v3";
|
||||||
|
option java_outer_classname = "WrrLocalityProto";
|
||||||
|
option java_multiple_files = true;
|
||||||
|
option go_package = "github.com/envoyproxy/go-control-plane/envoy/extensions/load_balancing_policies/wrr_locality/v3;wrr_localityv3";
|
||||||
|
option (udpa.annotations.file_status).package_version_status = ACTIVE;
|
||||||
|
|
||||||
|
// [#protodoc-title: Weighted Round Robin Locality-Picking Load Balancing Policy]
|
||||||
|
|
||||||
|
// Configuration for the wrr_locality LB policy. See the :ref:`load balancing architecture overview
|
||||||
|
// <arch_overview_load_balancing_types>` for more information.
|
||||||
|
// [#extension: envoy.clusters.lb_policy]
|
||||||
|
message WrrLocality {
|
||||||
|
// The child LB policy to create for endpoint-picking within the chosen locality.
|
||||||
|
config.cluster.v3.LoadBalancingPolicy endpoint_picking_policy = 1
|
||||||
|
[(validate.rules).message = {required: true}];
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue