-
Notifications
You must be signed in to change notification settings - Fork 1.9k
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
Add fetch phase to search profile #1764
Comments
Some other aspects of improving the profile output in general -
|
I agree with @rishabhmaurya 's suggestions! Currently as part of the efforts to capture query-level resource usage metrics and the coordinator node level took time, we are able to get phase-level breakdown on latency and resource usages, but we can go even deeper and get insights on the resource usages / time consumptions for some critical functions. |
Additionally, profile output can capture further shard level metrics related to computation of field data cache. This could be helpful for cases when there are too many evictions due to lower heap available for field data caches and user may want to increase heap size to improve performance of their search queries in these scenarios. We don't have a way to flag such queries today and without flame graphs it becomes hard to understand what's taking time in these queries. |
Is your feature request related to a problem? Please describe.
A significant performance regression exists for some use cases in the fetch phase between ES 7.9 and OS 1.0. The root cause was a change to the Lucene codec and it has been mitigated by a change within Lucene that is present in OS 1.2. See issue #1647 for more details. I was able to profile the JVM using Java Flight Recorder and the decompression during the fetch phase stood out as an obvious change, but this would have been much easier if the search profile results had contained timing metrics on the fetch phase.
Describe the solution you'd like
The "profile" section of the query response should contain information about the fetch phase.
Describe alternatives you've considered
Profling the JVM can give a lot of insight into where time is being spent, but is a rather complicated process and requires a lot of knowledge of the Java development ecosystem.
The text was updated successfully, but these errors were encountered: