[READ ONLY MIRROR] Envoy REST/proto API definitions and documentation. (grpc依赖)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

90 lines
3.5 KiB

// [#protodoc-title: Health check]
syntax = "proto3";
package envoy.api.v2;
import "google/protobuf/duration.proto";
import "google/protobuf/wrappers.proto";
message HealthCheck {
// The time to wait for a health check response. If the timeout is reached the
// health check attempt will be considered a failure.
google.protobuf.Duration timeout = 1;
// The interval between health checks.
google.protobuf.Duration interval = 2;
// An optional jitter amount in millseconds. If specified, during every
// internal Envoy will add 0 to interval_jitter to the wait time.
google.protobuf.Duration interval_jitter = 3;
// The number of unhealthy health checks required before a host is marked
// unhealthy. Note that for http health checking if a host responds with 503
// this threshold is ignored and the host is considered unhealthy immediately.
google.protobuf.UInt32Value unhealthy_threshold = 4;
// The number of healthy health checks required before a host is marked
// healthy. Note that during startup, only a single successful health check is
// required to mark a host healthy.
google.protobuf.UInt32Value healthy_threshold = 5;
// Non-serving port for health checking.
google.protobuf.UInt32Value alt_port = 6;
// Reuse health check connection between health checks. Default is true.
google.protobuf.BoolValue reuse_connection = 7;
// Describes the encoding of the payload bytes in the payload
message Payload {
oneof payload {
string text = 1;
bytes binary = 2;
}
}
message HttpHealthCheck {
// The value of the host header in the HTTPS health check request. If left
// empty (default value), the IP on behalf of which this health check is
// performed will be used.
string host = 1;
// This parameter is required if the type is http. It species the HTTP path
// that will be requested during health checking. For example /healthcheck.
string path = 2;
Payload send = 3;
Payload receive = 4;
// The Envoy HTTP health checker supports the service_name option. If this
// option is set, the health checker additionally compares the value of the
// x-envoy-upstream-healthchecked-cluster response header to service_name. If
// the values do not match, the health check does not pass. The upstream
// health check filter appends x-envoy-upstream-healthchecked-cluster to the
// response headers. The appended value is determined by the --service-cluster
// command line option.
string service_name = 5;
}
message TcpHealthCheck {
// Empty payloads imply a connect-only health check.
Payload send = 1;
// When checking the response, “fuzzy” matching is performed such that each
// binary block must be found, and in the order specified, but not
// necessarly contiguous.
repeated Payload receive = 2;
}
message RedisHealthCheck {
}
oneof health_checker {
HttpHealthCheck http_health_check = 8;
TcpHealthCheck tcp_health_check = 9;
RedisHealthCheck redis_health_check = 10;
}
}
enum HealthStatus {
// UNKNOWN should be treated by Envoy as HEALTHY.
UNKNOWN = 0;
HEALTHY = 1;
UNHEALTHY = 2;
// Connection draining in progress -
// https://aws.amazon.com/blogs/aws/elb-connection-draining-remove-instances-from-service-with-care/
// and
// https://cloud.google.com/compute/docs/load-balancing/enabling-connection-draining.
DRAINING = 3;
// This value is used by HDS Remote server. From Envoy’s perspective
// TIMEOUT = UNHEALTHY in case EDS returns HealthStatus.
TIMEOUT = 4;
}