!
也想出现在这里? 联系我们
广告位

WordPress文章过多导致网站慢卡顿优化方法

当我们使用 WordPress 作为程序时,如果 WordPress 网站的文章数量超过 10 万,即使网站服务器的配置很强大,网站的打开速度基本上也会很慢。这时我们就需要对网站进行优化

这是因为 WordPress 在查询文章列表时,默认也会查询文章数。这对于少量的网站数据应该不会造成任何问题,但是对于大量的文章是不可避免的。慢查询。主机引用的一位用户告诉我们,他的网站有 40 万篇文章,打开首页需要一两分钟,甚至首页或文章页也经常打不开。

WordPress 网站查询慢的原因:WordPress 在查询帖子列表时,默认也会查询帖子数。使用此方法:get_posts、query_posts 和 WP_Query。get_posts 在 4.6.1+中没有使用 SQL_CALC_FOUND_ROWS,但是 query_posts 和 WP_Query 仍然使用,所以需要优化。

那么如何解决 WordPress 文章过多导致网站慢的问题呢?

方法一:完全禁用 SQL_CALC_FOUND_ROWS,将以下的代码放到 functions.php 文件中:

  1. add_action('pre_get_posts', 'wndt_post_filter');
  2. function wndt_post_filter($query) {
  3. if (is_admin() or !$query->is_main_query()) {
  4. return $query;
  5. }
  6. // 禁止查询 SQL_CALC_FOUND_ROWS
  7. $query->set('no_found_rows', true);
  8. }

方法二、如果您还需要查询文章数,请使用更高效的 EXPLAIN 方法代替 SQL_CALC_FOUND_ROWS,以更高效的方式禁用 SQL_CALC_FOUND_ROWS。这里我们使用 EXPLAIN 方法。

具体代码如下,将以下的代码放在 functions.php 文件中。

  1. if ( ! function_exists( 'zjck_set_no_found_rows' ) ) {
  2. /**
  3. * 设置WP_Query的 'no_found_rows' 属性为true,禁用SQL_CALC_FOUND_ROWS
  4. *
  5. * @param WP_Query $wp_query WP_Query实例
  6. * @return void
  7. */
  8. function zjck_set_no_found_rows(\WP_Query $wp_query)
  9. {
  10. $wp_query->set('no_found_rows', true);
  11. }
  12. }
  13. add_filter( 'pre_get_posts', 'zjck_set_no_found_rows', 10, 1 );
  14. if ( ! function_exists( 'zjck_set_found_posts' ) ) {
  15. /**
  16. * 使用 EXPLAIN 方式重构
  17. */
  18. function zjck_set_found_posts($clauses, \WP_Query $wp_query)
  19. {
  20. // Don't proceed if it's a singular page.
  21. if ($wp_query->is_singular()) {
  22. return $clauses;
  23. }
  24. global $wpdb;
  25. $where = isset($clauses['where']) ? $clauses['where'] : '';
  26. $join = isset($clauses['join']) ? $clauses['join'] : '';
  27. $distinct = isset($clauses['distinct']) ? $clauses['distinct'] : '';
  28. $wp_query->found_posts = (int)$wpdb->get_row("EXPLAIN SELECT $distinct * FROM {$wpdb->posts} $join WHERE 1=1 $where")->rows;
  29. $posts_per_page = (!empty($wp_query->query_vars['posts_per_page']) ? absint($wp_query->query_vars['posts_per_page']) : absint(get_option('posts_per_page')));
  30. $wp_query->max_num_pages = ceil($wp_query->found_posts / $posts_per_page);
  31. return $clauses;
  32. }
  33. }
  34. add_filter( 'posts_clauses', 'zjck_set_found_posts', 10, 2 );

给TA打赏
共{{data.count}}人
人已打赏
WordPress教程

如何防止WordPress网站垃圾留言和垃圾内容投稿

2023-4-5 3:33:43

WordPress教程

WordPress 限制非登录用户浏览分类文章

2023-4-19 3:33:34

下载说明

  • 1、微码盒所提供的压缩包若无特别说明,解压密码均为weimahe.com
  • 2、下载后文件若为压缩包格式,请安装7Z软件或者其它压缩软件进行解压;
  • 3、文件比较大的时候,建议使用下载工具进行下载,浏览器下载有时候会自动中断,导致下载错误;
  • 4、资源可能会由于内容问题被和谐,导致下载链接不可用,遇到此问题,请到文章页面进行反馈,以便微码盒及时进行更新;
  • 5、其他下载问题请自行搜索教程,这里不一一讲解。

站长声明

本站大部分下载资源收集于网络,只做学习和交流使用,版权归原作者所有;若为付费资源,请在下载后24小时之内自觉删除;若作商业用途,请到原网站购买;由于未及时购买和付费发生的侵权行为,与本站无关。本站发布的内容若侵犯到您的权益,请联系本站删除,我们将及时处理!
0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索