WordPress毫无疑问是最优秀使用量最大的开源cms程序,但是WordPress建站有个问题,就是文章数据达到10万级以上就会变得很卡。一般的个人博客是很难达到这个数据的,但是有些大型网站或者采集网站,却比较容易达到这个量级。

图片[1]-WordPress建站10万级数据不卡的解决方法,解决网站打开速度慢的问题?-猎富团

当网站的文章数量超过10万篇时,明显感觉到打开速度变慢了很多。

变慢的原因

SELECT SQL_CALC_FOUND_ROWS wp_posts.ID FROM wp_posts WHERE 1=1 AND wp_posts.post_type = ‘post’ AND (wp_posts.post_status = ‘publish’ ) ORDER BY wp_posts.post_date DESC LIMIT 0, 20
SELECT FOUND_ROWS()

query_posts和WP_Query会因为SQL_CALC_FOUND_ROWS出现慢查询。

解决办法一:彻底禁用SQL_CALC_FOUND_ROWS

add_action(‘pre_get_posts’, ‘wndt_post_filter’);
function wndt_post_filter($query) {
if (is_admin() or !$query->is_main_query()) {
return $query;
}
// 禁止查询 SQL_CALC_FOUND_ROWS
$query->set(‘no_found_rows’, true);
}

解决办法二:使用更加高效的EXPLAIN方式

if ( ! function_exists( ‘maizi_set_no_found_rows’ ) ) {
/**
* 设置WP_Query的 ‘no_found_rows’ 属性为true,禁用SQL_CALC_FOUND_ROWS
*
* @param WP_Query $wp_query WP_Query实例
* @return void
*/
function maizi_set_no_found_rows(WP_Query $wp_query)
{
$wp_query->set(‘no_found_rows’, true);
}
}
add_filter( ‘pre_get_posts’, ‘maizi_set_no_found_rows’, 10, 1 );
if ( ! function_exists( ‘maizi_set_found_posts’ ) ) {
/**
* 使用 EXPLAIN 方式重构
*/
function maizi_set_found_posts($clauses, WP_Query $wp_query)
{
// Don’t proceed if it’s a singular page.
© 版权声明
THE END
点赞2876