-
-
Notifications
You must be signed in to change notification settings - Fork 174
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
Sentry Native delays app termination if device is not online #929
Comments
Hey @csk-ableton, thanks for the detailed report and your patience during holidays. We'll discuss the use case and your suggested solutions and follow up here. |
Sorry for not getting back to you sooner, @csk-ableton. Thanks for the detailed analysis, but I might need to bug you with further questions so that I can understand the problem better. The reason for this is that you connect a couple of dots that could be causing your issue as part of their interaction or on their own. It is very surprising that you run into a timeout if the network interface is disabled. I would expect that such an attempt is in the low 100 microseconds range, so even if you have many queued up requests it should not easily reach a 2 second timeout. If you enable the debug logs, do you see how curl fails ( Sorry, that I am asking this, but before we consider adding an API i want to be absolutely sure that this is the root-cause. In any case, considering your solution proposals: I think i would prefer a generic approach that would pause uploading in the worker thread (what you aptly named How would you compare it given you suggested the above "only" as an alternative to deferring the execution of With all deferred deliveries we have to be very careful as to no affect user-consent, but envelopes that reached the transport background worker, must have been given consent and I currently see no way how consent could be applied by accident retroactively. |
No problem for the delay, that sounds very reasonable and thank you for your reply!
In my case the device has multiple network interfaces, one of which is Ethernet via USB which is usually not connected to the internet but just a user's computer. That might explain why it doesn't show your expected behavior? I'm not familiar with the exact behavior of Curl here. I noticed that no timeouts are provided for the call to
I would prefer such a generic API as well. It would mean that all my executables are guaranteed to terminate fast while uploading is disabled. However there is still a remaining reason for me to be in control of processing old runs manually. I should now explain that I'm sharing the same Sentry database across all my executables in order for them to share the user consent setting. This however means that each executable is trying to process old runs even from other executables. It again means that my short-lived executables will potentially start uploading data even though they didn't run into any error. Maybe my setup is a bit too special with the shared database, but I would prefer if my executables would not all try to upload each others last run. Another thought I had was the need for processing old runs at all in my case. At least when using the Crashpad handler it seems that uploading data when the device is online and dropping all data when it's offline would be simple and sufficient. But I'm probably missing the complete picture.
That makes sense, I just want to point out that currently due to the missing timeout in the Curl transport, a request can be queued for a very long time and still be sent even if the user revoked their consent in the meantime. I hope even though my setup is more special it's a useful request. |
You're right, both approaches can make sense in independent scenarios. We'll talk about how to prioritize this internally. cc @kahest |
Description
Sentry Native slows down the termination of my executables in case the device is not online. The termination is delayed by the time defined with
sentry_options_set_shutdown_timeout
(2 seconds by default).By default Sentry has Session Tracking enabled which slows down the process a little bit. However in case the device is not connected (the user disabled Wifi),
sentry_close
will run into the shutdown timeout, delaying the termination of the executable by 2 seconds by default.I thought I can disable Session Tracking by using
sentry_options_set_auto_session_tracking
if I want to avoid communication when there is no error but that is not enough.sentry_init
will attempt to upload old runs insentry__process_old_runs
and the device will still run into the shutdown timeout when callingsentry_close
. This happens in every run as long as the device is offline.In my case the problem is quite severe, as multiple executables are started / terminated, some of which will terminate immediately if there is nothing to do.
Proposal:
Introduce an option
sentry_options_set_auto_process_old_runs
which stops uploading and pruning old runs completely. The app will only start communicating with a server when there is an actual error.Introduce
sentry_process_old_runs
to manually process old runs at an appropriate point in time.Alternatives considered:
sentry_init
only once the device is online. This seems not to be in the spirit of the library. Crash reporting would be completely disabled while offline and I might miss interesting breadcrumbs until the point the device is registered as online.sentry_set_uploading_enabled
to disable uploading while the device is clearly offline. A basic version is easy to implement (same as user consent just without being persistent). A more complicated version would need to delaysentry__process_old_runs
or even continue storing data until uploading is enabled again.When does the problem happen
Environment
The text was updated successfully, but these errors were encountered: