You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
We are using IProxyStateLookup in a Asp.Net Core Healthcheck to check if a specific cluster is healthy using the cluster id as query param in a Azure environment with Azure Front Door and YARP as regional proxy. After upgrading from .NET 6 and YARP 1.1.1 to .NET 8 and YARP 2.1.0, AvailableDestinations contains an unhealthy destination, where in the previous version, that would not be the case. We checked breaking changes by going through the release notes and couldn't find anything.
When calling the exposed healthcheck with http://localhost:7014/health?clusterId=json-server we get the following results (The cluster is not running at that time):
With YARP 2.1.0 and .NET8
With YARP 1.1.0 and .NET6
Further technical details
Relevant health check code in IHealthcheck service
if(_httpContextAccessor.HttpContext==null)thrownewInvalidOperationException("HttpContext is null.");varhttpRequestFeature=_httpContextAccessor.HttpContext.GetHttpRequestFeature();varclusters=_proxyStateLookup.GetClusters();if(!clusters.Any())returnTask.FromResult(newHealthCheckResult(HealthStatus.Unhealthy,HealthProbeErrorDescriber.NoConfig));if(TryGetClusterId(httpRequestFeature.QueryString,outvarclusterId)){if(!_proxyStateLookup.TryGetCluster(clusterId,outvarclusterState)){returnTask.FromResult(newHealthCheckResult(HealthStatus.Unhealthy,HealthProbeErrorDescriber.FormatClusterNotFound(clusterId)));}returnTask.FromResult(clusterState.DestinationsState.AvailableDestinations.Count>0?HealthCheckResult.Healthy():new(HealthStatus.Unhealthy,HealthProbeErrorDescriber.FormatUnhealthyCluster(clusterId)));}
Yarp.ReverseProxy 2.1.0, .NET 8
Windows
The text was updated successfully, but these errors were encountered:
While understandable, it has quite an impact on the operating side of things. We typically want to be informed if a cluster is unhealthy for the sake of alerting / monitoring. I personally would have classified that as breaking change :) - as in, it broke our monitoring.
We fixed the issue with a IProxyConfigFilter to set the 1.1.1 default policy on all cluster configs.
Sorry about that, you can see that the PR #2171 was marked as a breaking change, but we forgot to call out breaking changes in the 2.1.0 preview 1 release notes.
I've updated the release notes for that release now.
Describe the bug
We are using
IProxyStateLookup
in a Asp.Net Core Healthcheck to check if a specific cluster is healthy using the cluster id as query param in a Azure environment with Azure Front Door and YARP as regional proxy. After upgrading from .NET 6 and YARP 1.1.1 to .NET 8 and YARP 2.1.0,AvailableDestinations
contains an unhealthy destination, where in the previous version, that would not be the case. We checked breaking changes by going through the release notes and couldn't find anything.To Reproduce
The configuration uses a simple json-server
When calling the exposed healthcheck with
http://localhost:7014/health?clusterId=json-server
we get the following results (The cluster is not running at that time):With YARP 2.1.0 and .NET8
With YARP 1.1.0 and .NET6
Further technical details
Relevant health check code in
IHealthcheck
serviceThe text was updated successfully, but these errors were encountered: