-
Notifications
You must be signed in to change notification settings - Fork 1.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Make queue-proxy NOT count the health check requests by the users #14581
Comments
Hi @houshengbo
Could you specify which metrics are not accurate, are these Knative metrics or external ones? Btw do you use KServe and https://github.com/kserve/kserve/blob/master/qpext/cmd/qpext/main.go? |
@skonto We are using KServe to launch the inference services, which launch the knative services as the backend supporting services. The health check is from external of the inference services. The inference services usually have endpoint to call to run the health check. When there is a request coming to the inference service, no matter it is directly calling the inference service to serve or just checking the health. It will always be counted as the valid requests for that specific service, and the number is added into the metrics. In fact, it is more meaningful for us to count only the requests calling the inference service, not including the requests calling the health check endpoint. I saw the filter here, is this a certain key for the header that we can use, so it will not be counted? |
Is that kubelet that checks the health of the isvc? The filter mentioned above checks for the |
@skonto We use consul for service discovery and consul sends health checks to the KServe inference services which are currently counted as normal request by Knative. Are you suggesting to add the |
Hi @yuzisun I see a couple of options as I am not familiar with the architecture you have:
|
This issue is stale because it has been open for 90 days with no |
/remove-lifecycle stale |
This issue is stale because it has been open for 90 days with no |
/remove-lifecycle stale |
This issue is stale because it has been open for 90 days with no |
/lifecycle frozen |
/triage accepted |
It's not possible to use Solution which uses custom header is implemented in following PR`s: #15653, knative/networking#1025, knative/docs#6177 |
Describe the feature
We leverage a platform managing all the knative services. All knative services report the health status via a separate URL/path, and the path is NOT consistent across different knative services.(Just confirmed internally with the team)
For example, the health check path of the knative service is determined by the model deployed in the knative service. Different models have different url for health check.
Each time, when the health check is called, the request is counted by the queue-proxy, which makes the metrics data NOT accurate, since all the health check requests are counted as well.
We are thinking of whether knative serving can distinguish the normal requests and the health check requests, so the health check requests do not count by the queue-proxy.
@skonto @dprotaso
The text was updated successfully, but these errors were encountered: