• Since updating to WordPress 4.5, W3TC causes memory exhaustion. It’s still unsure that it’s actually w3TC. However, after a while of debugging, this is what I saw.

    Backtrace from warning 'post_permalink is deprecated since version 4.4! Use get_permalink() instead.' at /home/user/public_html/wp-includes/functions.php 3662:
    
    /home/user/public_html/wp-includes/functions.php 3662 calling trigger_error()
    /home/user/public_html/wp-includes/deprecated.php 3607 calling _deprecated_function()
    /home/user/public_html/wp-content/plugins/w3-total-cache/lib/W3/SharedPageUrls.php 111 calling post_permalink()
    /home/user/public_html/wp-content/plugins/w3-total-cache/lib/W3/PgCacheFlush.php 102 calling get_post_urls()
    /home/user/public_html/wp-content/plugins/w3-total-cache/lib/W3/CacheFlushLocal.php 103 calling flush_post()
    /home/user/public_html/wp-content/plugins/w3-total-cache/lib/W3/CacheFlush.php 106 calling pgcache_flush_post()
    /home/user/public_html/wp-content/plugins/w3-total-cache/lib/W3/Plugin/PgCache.php 244 calling pgcache_flush_post()
    calling on_post_change()
    /home/user/public_html/wp-includes/plugin.php 525 calling call_user_func_array()
    /home/user/public_html/wp-includes/post.php 5661 calling do_action()
    /home/user/public_html/wp-includes/post.php 3426 calling clean_post_cache()
    /home/user/public_html/wp-includes/post.php 3602 calling wp_insert_post()
    /home/user/public_html/wp-admin/includes/post.php 369 calling wp_update_post()
    /home/user/public_html/wp-admin/post.php 193 calling edit_post()
    
    Fatal error: Allowed memory size of 268435456 bytes exhausted (tried to allocate 5659508 bytes) in /home/user/public_html/wp-includes/functions.php on line 434

    An update would help solve the issues.

    https://www.ads-software.com/plugins/w3-total-cache/

Viewing 7 replies - 1 through 7 (of 7 total)
  • Its a little hard to pin the memory issue on W3TC. Unless it was configured incorrectly in which case we would need to know what you have enabled.

    As for those errors there has been a fix around here on the forum. It won’t break anything because its a depreciation notice but it is an annoying error that needs to be fixed.

    Shown below are a list of patch fixes i’ve done to my w3tc files and you can apply yourself (if you aren’t afraid of looking at code). The first patch is what might fix your problem (we will have to look into the memory issue after). I recommend you incorporate each fix to resolve other issues i’ve dealt with. For me, w3tc has been working flawlessly even in PHP 7.0.5.

    File: /wp-content/plugins/w3-total-cache/lib/W3/SharedPageUrls.php

    Line: 111 — Deprecation issue.

    Replace:

    $post_link = post_permalink($post_id);

    With:

    $post_link = get_permalink($post_id);

    ***********************************************
    File: /wp-content/plugins/w3-total-cache/lib/W3/Plugin/TotalCache.php

    Line: 512 — This resolves the php7 compatibility issue. Without it caching doesnt occur in php7+.

    Replace:

    function ob_callback(&$buffer)

    With:

    function ob_callback($buffer)

    ***********************************************
    File: /wp-content/plugins/w3-total-cache/lib/W3/PgCache.php

    Line: 961 — Resolves an issue with https caching

    Replace:

    $key = substr($request_uri, strtolower(substr($request_uri, 0, 8)) == 'https' ? 8: 7);

    With:

    $key = substr($request_uri, strtolower(substr($request_uri, 0, 8)) == 'https://' ? 8: 7);

    ***********************************************
    File: /wp-content/plugins/w3-total-cache/lib/W3/PgCacheAdminEnvironment.php

    Line: 562 — Deprecation issue.

    Replace:

    $current_user = get_currentuserinfo();

    With:

    $current_user = wp_get_current_user();

    ***********************************************
    File: /wp-content/plugins/w3-total-cache/lib/W3/AdminActions/SupportActionsAdmin.php

    Line: 655 — Deprecation issue.

    Replace:

    global $current_user;
    get_currentuserinfo();

    With:

    //global $current_user; -- Not needed.
    $current_user = wp_get_current_user();

    I also wrote a small code tweak to resolve an issue of it having no code to cache RSS/Atom/RDF feeds locally. Oddly, w3tc doesnt do that — feeds are regenerated in real time when accessed. I only wrote code for page_enhanced caching though since that is what i use. It generates a feed cache file when a rss/rss2/atom/rdf request is made, and regenerates if the page/post is updated (and deletes when a page/post is deleted). Seeing as how most people’s feeds are not local (FeedBurner?) i have chosen not to include the code here. I cant remmeber the several other tweaks i did to w3tc…its been a long time.

    Thread Starter Karthikeyan KC

    (@karthikeyankc)

    I’ve already patched the deprecated parts in my development environment and it works fine. Thanks anyway… ?? But I just encountered the same memory issue on a friend’s installation an hour ago, using the latest W3TC. I think an update is recommended universally.

    Agreed about a universal update. I wish. Seems the author has abandoned this. ?? As for the memory issue, very strange. I have never seen anyone (besides you, of course) who has had this problem. A lot more info will be needed to pinpoint the root cause.

    @kimberly – Thanks so much for this. Has fixed the problem!

    Any suggestions on caching tweaks to increase site load speed if running a heavy theme (Avada).

    thanks @kimberly

    But File: /wp-content/plugins/w3-total-cache/lib/W3/AdminActions/SupportActionsAdmin.php

    Line: 656
    $email = $current_user->user_email;

    So, I think global $current_user; is needed or it might cause undefined variable error.

    Hi @vee,

    Incorrect. The global $current_user is not needed because the returning object from: $current_user = wp_get_current_user(); already has it. WordPress changed the underlying structure. It seems you missed that line of code i wrote in the earlier reply. ??

    Regards
    Kimberly

Viewing 7 replies - 1 through 7 (of 7 total)
  • The topic ‘Not so compatible with 4.5’ is closed to new replies.