-
Notifications
You must be signed in to change notification settings - Fork 469
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
Metrics SDK - can we cleanup after a shutdown? #2442
Comments
As you have mentioned, I would prefer to avoid having this check in hot path as well. |
We can use This comes with a performance cost though as the
This would not always be possible. Especially, if the users are using some instrumentation library and have no visibility and access to the instruments and Meters. |
This is not related, but just to add. The Arc upgrade indeed is perf heavy operation, which was the reason it was removed from Logger/LoggerProvider in #1455. |
Based on the prototype @utpilla did I think the cost is not worth the benifit. Most of the MeterProvider should have the same lifecycle as the application |
TODO: Also check this for other signals like Logs. Add tests to confirm the current behavior and if they are behaving as expected or not. |
Though shutdown prevents metrics from ever getting collected/exported, they are still kept in the HashMaps/Aggregations. There is no check in hot path to see if the provider is already shutdown (it may be too expensive to do that check). This maybe okay, but opening an issue to discuss more.
Also, given the Counter/Meter from the API use a
Arc<dyn>
object pointing to something from the SDK, it is not easily possible to do much cleanup in the SDK, unless the user explicitly drops the Counter/Meters themselves.The text was updated successfully, but these errors were encountered: