-
Notifications
You must be signed in to change notification settings - Fork 78
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
Yii2: Logs are not flushed on shutdown #650
Comments
Not sure if this is the best solution, but I've fixed this by registering my own shutdown function:
Sidenote: it would be nice if |
Hi @timkelty, just to confirm, does this issue only occur when batch sending is enabled? |
@yousif-bugsnag correct – if I disable batch sending, it works, because it sends them immediately and doesn't need to wait for the shutdown handler |
HI @timkelty, The Yii2 framework is not something we officially support as there are some more significant differences to other PHP frameworks. I suspect the issue you are reporting could be due to these differences. Full support for Yii2 is on our roadmap but I don't have a timeframe at the moment. I have noted your interest and use case and will let you know here as soon as we have updates. For now your workaround would seem perfectly reasonable if it is suiting your needs. As a slight aside, there is a third party Yii2 Bugsnag notifier library that someone has created, so that might be of interest to you: https://github.com/pinfirestudios/yii2-bugsnag. However its worth noting Bugsnag has no connection to this so we cannot support it nor verify if it works correctly. |
@johnkiely1 thanks! FWIW, this is for Craft CMS@4 (Yii2 under the hood), which uses Monolog for logging, so we're currently getting Bugsnag integration through https://packagist.org/packages/mead-steve/mono-snag |
Describe the bug
Using Bugsnag with https://github.com/yiisoft/yii2, logged errors are not flushed to Bugsnag with batching enabled.
$bugsnagClient->setBatchSending(false);
By settings some breakpoints, I can see that the order of operations seems off:
\Bugsnag\Shutdown\PhpShutdownStrategy::registerShutdownStrategy
\Bugsnag\Client::flush
(queue is empty)\Bugsnag\Client::notify
(after which, queue has report)As you can see, flush seems to be getting called before notify, so the reports never get flushed to Bugsnag.
This seems to be because Yii's logger has its own
register_shutdown_function
to flush its logs, but is always called last. In this case Bugsnag's shutdown needs to be called after, or no logs exist.Environment
The text was updated successfully, but these errors were encountered: