Allow short healthcheck interval with long timeout

This commit is contained in:
Kevin McConnell 2023-08-08 15:40:05 +01:00 committed by GitHub
parent d6457e6cbb
commit 55e00be36e
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 51 additions and 6 deletions

View file

@ -338,7 +338,6 @@ Below are the available options for the health check mechanism:
!!! info "Interval & Timeout Format" !!! info "Interval & Timeout Format"
Interval and timeout are to be given in a format understood by [time.ParseDuration](https://golang.org/pkg/time/#ParseDuration). Interval and timeout are to be given in a format understood by [time.ParseDuration](https://golang.org/pkg/time/#ParseDuration).
The interval must be greater than the timeout. If configuration doesn't reflect this, the interval will be set to timeout + 1 second.
!!! info "Recovering Servers" !!! info "Recovering Servers"

View file

@ -69,11 +69,6 @@ func NewServiceHealthChecker(ctx context.Context, metrics metricsHealthCheck, co
timeout = time.Duration(dynamic.DefaultHealthCheckTimeout) timeout = time.Duration(dynamic.DefaultHealthCheckTimeout)
} }
if timeout >= interval {
logger.Warn().Msgf("Health check timeout should be lower than the health check interval. Interval set to timeout + 1 second (%s).", interval)
interval = timeout + time.Second
}
client := &http.Client{ client := &http.Client{
Transport: transport, Transport: transport,
} }

View file

@ -18,6 +18,57 @@ import (
healthpb "google.golang.org/grpc/health/grpc_health_v1" healthpb "google.golang.org/grpc/health/grpc_health_v1"
) )
func TestNewServiceHealthChecker_durations(t *testing.T) {
testCases := []struct {
desc string
config *dynamic.ServerHealthCheck
expInterval time.Duration
expTimeout time.Duration
}{
{
desc: "default values",
config: &dynamic.ServerHealthCheck{},
expInterval: time.Duration(dynamic.DefaultHealthCheckInterval),
expTimeout: time.Duration(dynamic.DefaultHealthCheckTimeout),
},
{
desc: "out of range values",
config: &dynamic.ServerHealthCheck{
Interval: ptypes.Duration(-time.Second),
Timeout: ptypes.Duration(-time.Second),
},
expInterval: time.Duration(dynamic.DefaultHealthCheckInterval),
expTimeout: time.Duration(dynamic.DefaultHealthCheckTimeout),
},
{
desc: "custom durations",
config: &dynamic.ServerHealthCheck{
Interval: ptypes.Duration(time.Second * 10),
Timeout: ptypes.Duration(time.Second * 5),
},
expInterval: time.Second * 10,
expTimeout: time.Second * 5,
},
{
desc: "interval shorter than timeout",
config: &dynamic.ServerHealthCheck{
Interval: ptypes.Duration(time.Second),
Timeout: ptypes.Duration(time.Second * 5),
},
expInterval: time.Second,
expTimeout: time.Second * 5,
},
}
for _, test := range testCases {
t.Run(test.desc, func(t *testing.T) {
healthChecker := NewServiceHealthChecker(context.Background(), nil, test.config, nil, nil, http.DefaultTransport, nil)
assert.Equal(t, test.expInterval, healthChecker.interval)
assert.Equal(t, test.expTimeout, healthChecker.timeout)
})
}
}
func TestServiceHealthChecker_newRequest(t *testing.T) { func TestServiceHealthChecker_newRequest(t *testing.T) {
testCases := []struct { testCases := []struct {
desc string desc string