• Resolved Pat K

    (@blackcapdesign)


    This is not a question – it’s a tip for others who might be experiencing super slow scans and & very high CPU usage. I have had WordFence in place on a bunch of sites for many years with no issues. Scans usually take less than a minute to complete – unless the site is huge, in which case it can take a few minutes. In mid-2020 I migrated to a new server with identical settings BUT on every new site on the server with WordFence installed, scans were taking on average 24 – 36 minutes to complete AND I was seeing huge CPU spikes every time a scan was run. I’ve been trying to figure this out for a LONG time and FINALLY figured out the culprit: InnoDB

    Today I happened to check Wordfence > Tools > Diagnostics > Database Tables …and when comparing this to other sites, ALL of the new sites are showing the MySQL engine to be InnoDB for the Wordfence tables. On the old sites, the MySQL engine is MyISAM.

    So I manually edited /etc/my.cnf (I have root access…if you don’t, conctact your hosting provider) and added:
    default-storage-engine=MYISAM

    ….then restarted MySQL.

    I exported the settings, then uninstalled Wordfence (being sure to check “Delete Wordfence tables and data on deactivation”, then reinstalled Wordfence & imported my settings. I checked to confirm the Wordfence tables are now MyISAM. I ran a scan; the same scan that took over 24 minutes previously now takes 14 seconds.

    Hopefully this helps someone else experiencing this problem…
    pk

Viewing 2 replies - 1 through 2 (of 2 total)
  • Plugin Support wfpeter

    (@wfpeter)

    Hi @blackcapdesign, thanks for your feedback and solution.

    For the record, Wordfence doesn’t change database collations and observes the defaults currently set on your server when making changes or plugin updates. WordPress switched to using utf8mb4 quite a while ago, so seeing that there is another collation set might suggest a WordPress update didn’t finish changing your tables back then, or perhaps a migration or restore from backup used the wrong collation.

    Here’s a WordPress article highlighting the change and may assist in anybody referencing this ticket: https://make.www.ads-software.com/core/2015/04/02/the-utf8mb4-upgrade/

    Peter.

    Thread Starter Pat K

    (@blackcapdesign)

    Thanks…I think. For the record, I didn’t suggest in any way that Wordfence is the culprit; I’m merely posting the fix that I found and implemented for slow scans & high CPU usage. I have read MANY posts in this forum that describe similar symptoms – and in many cases, people simply stop using Wordfence because it’s the easiest fix – albeit not the best solution in terms of security.

    Your reference to utf8mb4 and associated link is curious since it doesn’t have any bearing in my situation. This is not a data collation issue; it’s a database engine issue.

    While I don’t claim to any sort of expert on the matter there is ample information online suggesting that InnoDB is considerably slower than MyISAM when it comes to full table scans. One such example:
    https://stackoverflow.com/questions/2194914/why-is-mysql-innodb-so-much-slower-at-full-table-scans-than-myisam

Viewing 2 replies - 1 through 2 (of 2 total)
  • The topic ‘Slow Scans & High CPU Load on Server due to InnoDB Engine’ is closed to new replies.