• Paul

    (@paultgoodchild)


    We run iControlWP and hundreds of our sites have been knocked offline since your latest update.

    We get this fatal error:
    Fatal error: Unknown: Cannot use output buffering in output buffering display handlers in Unknown on line 0

    I narrowed it down to WP Super Cache and us simply calling PHP die().

    Can you please point to the changes/fix for this as soon as possible?

Viewing 13 replies - 16 through 28 (of 28 total)
  • Hi @donncha,

    is there any ETA for this? Still experiencing this issue.

    Cheers
    Andreas

    @rokkyt – no ETA.

    @paultgoodchild – where did you call die()? Was it in a plugin that created an output buffer?

    @rokkyt – edit wp-cache-phase2.php and look for the function wp_super_cache_query_vars and do the following:
    1. Add $wp_query to the global list.
    2. Add that check on $wp_query.

    function wp_super_cache_query_vars() {
        global $wp_super_cache_query, $wp_query;
    
        if ( ! is_object( $wp_query ) ) {
            return false;
        }

    With that in place some of the functionality of the plugin is impaired (the parts where it doesn’t cache certain types of pages) but your site probably doesn’t depend on those anyway..

    Hi @donncha,

    thank you for your reply, but your fix did not solve the problem for us :/
    We still get the same error in our log files.

    The error occurs, when we try to follow a link, which was created with pretty link.
    The prettyLink-Url page remains white and no redirection takes place.

    If we switch off the caching by setting caching to off in the optionspage, the prettylink works as expected.

    Do you have any ideas, what can cause this issue?

    Thank you in advance.

    With kind regards
    Christoph (from rokkyt :))

    Sa?a

    (@stodorovic)

    Hi @rokkyt,

    Thanks you for your report. I’ve one website which has installed prettyLink and supercache. They work together without any issues (from version 1.5.4, I think).

    I’m guessing that’s trouble with 3rd plugin. By my research, it’s possible that some plugin executes flush from shutdown hook.

    Could you enable debug mode ( https://codex.www.ads-software.com/Debugging_in_WordPress ) and check for errors into debug.log?

    Sasa

    Hi Sasa,

    thank you for the reply.
    I tries turning on debugmode and logged the errors.

    The debug.log had these lines:

    [24-Oct-2017 09:29:59 UTC] PHP Fatal error: Call to a member function get() on null in /wp-includes/query.php on line 28
    [24-Oct-2017 09:29:59 UTC] PHP Fatal error: Unknown: Cannot use output buffering in output buffering display handlers in Unknown on line 0

    Do you still have any ideas?

    thanks in advance

    regards
    Christoph

    Sa?a

    (@stodorovic)

    I pretty sure that isn’t (only) related to WPSC. I’ve reproduced second error when I use flush or similar functions from output buffer handlers. If you have installed latest version of WPSC, we already added condition which prevent first error – method_exists( $GLOBALS['wp_query'], 'get').

    You can try to deactivate plugin by plugin (except WPSC and PrettyLink) until you locate which plugin(s) triggers error. If it isn’t possible (and you have a little experience with PHP), then you can try to add simple must-use plugin for debugging purpose:

    https://github.com/stracker-phil/wp-no-white-screen

    This plugin will log stack trace and we can easy see which functions are called before fatal error. I hope that helps and when you send more details, I’ll try to reproduce your issue.

    • This reply was modified 7 years, 1 month ago by Sa?a.

    Hi @stodorovic

    we now investigated this issue further and found the following stacktrace leading to the problem:

    We solved it with these changes (+ making $wp_query global) in wp-cache-phase2.php:

    Can you assess whether this is worth a minor fix in Super Cache? Would really make our lives easier.

    Cheers
    Andreas

    Sa?a

    (@stodorovic)

    Hi @rokkyt

    I think that’s already fixed by https://github.com/Automattic/wp-super-cache/pull/373. There are couple improvements related to sitemap’s code. Line which you changed is replaced to simple if ( isset( $wp_super_cache_query[ 'is_sitemap' ] ) ) {.

    Can you try this PR (just copy wp-cache-phase2.php from this PR and check)?

    Regards,
    Sasa

    • This reply was modified 7 years, 1 month ago by Sa?a.

    Thanks @stodorovic. I’ve merged #373, and will merge it with SVN shortly so you’ll be able to test the development version in a short while.

    @rokkyt – I’ve merged a bunch of bugfixes into the development version. You can grab it from the download page, and find more info on it too.

    https://odd.blog/y/2o

    Hi @donncha,

    we installed the development version of wp-supercache at our test environment and the problem seems to fixed.
    No more white-screens so far.

    Will these fixes be part of the next release of wp-supercache?
    When will the next version be released?

    thanks in advance

    regards
    Christoph

    @rokkyt – great! Next release will be next week. Your site will get the usual update notification as always because the development version uses the same version number as the current release.

Viewing 13 replies - 16 through 28 (of 28 total)
  • The topic ‘Fatal error with latest update’ is closed to new replies.