WordPress站点优化(中级版)

生命诚可贵,数据价更高。郑重提示,在使用本文所提到的WordPress优化方案时,随时可能出现服务器宕机或者数据库无法连接等现象,务必做好数据备份或者服务器快照,方便数据回滚。

一、删除JS及CSS的版本查询字符串

大多数服务器都不会使用到查询字符串。这就意味着每一次请求,这些js和css都需要从服务器重新获取。这会极大增加我们服务器的带宽压力。而且增加了加载时间。

查看方式:浏览器按下F12,按下图查看方式,若出现 ?ver=x.x.x则说明未禁用
function _remove_script_version ( $src ){
  $parts = explode( '?', $src );
  return $parts[0];
}
add_filter( 'script_loader_src', '_remove_script_version', 15, 1 );
add_filter( 'style_loader_src', '_remove_script_version', 15, 1 );

将以上代码填入主题文件夹的functions.php即可。

二、隐藏WordPress版本

WordPress每个页面都有标签用来显示WordPress的版本,虽然删除这一行代码就节省了几个字节,但是WordPress优化的效果都是从细节上慢慢累加起来的。

删除根目录的readme.html和wp-config-sample.php以及 /wp-admin/install.php,再将下面的代码放入functions.php

// 同时删除head和feed中的WP版本号
function ludou_remove_wp_version() {
  return '';
}
add_filter('the_generator', 'ludou_remove_wp_version');
 
// 隐藏js/css附加的WP版本号
function ludou_remove_wp_version_strings( $src ) {
  global $wp_version;
  parse_str(parse_url($src, PHP_URL_QUERY), $query);
  if ( !empty($query['ver']) && $query['ver'] === $wp_version ) {
    // 用WP版本号 + 12.8来替代js/css附加的版本号
    // 既隐藏了WordPress版本号,也不会影响缓存
    // 建议把下面的 12.8 替换成其他数字,以免被别人猜出
    $src = str_replace($wp_version, $wp_version + 12.8, $src);
  }
  return $src;
}
add_filter( 'script_loader_src', 'ludou_remove_wp_version_strings' );
add_filter( 'style_loader_src', 'ludou_remove_wp_version_strings' );

三、 禁用Dashicons 和 Google地图

dashicons.min.css是包含图标样式的文件,大小约为30kb,将其乘以访问者数量时,就是占有的带宽。Google Maps API是在异步中加载的,但它确实会大幅增加页面的总加载时间。再将下面的代码放入主题文件夹的 functions.php中

// remove dashicons
function wpdocs_dequeue_dashicon() {
if (current_user_can( 'update_core' )) {
  return;
}
wp_deregister_style('dashicons');
}
add_action( 'wp_enqueue_scripts', 'wpdocs_dequeue_dashicon' );

//Remove Google Maps API Call
function disable_google_map_api($load_google_map_api) {
  $load_google_map_api = false;
  return $load_google_map_api;
}
$plugins = get_option('active_plugins');
$required_plugin = 'auto-location-pro/auto-location.php';
if ( in_array( $required_plugin , $plugins ) ) {
  add_filter('avf_load_google_map_api', 'disable_google_map_api', 10, 1);
}

四、禁用或者缓存google字体

如果使用国内开发的主题,一般不会有这个问题,如果是使用国外的主题, 默认使用谷歌字体,这就导致了一些站点打开时间非常之长,原因就是字体文件无法访问阻塞了网页加载。具体的禁用或者替换的方法自行百度。

但是通常都会出问题,要么禁用不生效要么替换后字体访问不了,这个时候可以考虑用插件 Autoptimize 缓存字体,在Extra选项中设置即可缓存字体

五、开启GZIP

方法很多,自行百度,如果是BT面板,在nginx管理中开启即可,最后http://tool.chinaz.com/Gzips/ 这个网站检查一下是否开启成功。注意,开启的方法很多,但是只用一种就可以了,不然服务器可能会宕机。

六、数据库引擎转换

MySql有两种数据库引擎,分别是 MyISAM 和 InnoDB ,如果网站更新两比较大,建议选择 InnoDB,如果是个人博客且更新量少,建议使用 MyISAM,两种引擎优缺点自行百度。转换方式如下:

七、 MySQL 设置 MySQL Query Cache

开启此项可以大幅度加速mysql查询速度

在数据库中运行 SHOW VARIABLES LIKE '%query_cache%';

显示结果 若query_cache_size不为0,query_cache_type = ON 则已开启。

若没有开启可以参照此文开启 https://blog.csdn.net/jilindaxue/article/details/81588557

八、使用redis缓存

WordPress采用的是动态数据库查询技术。通俗的说,就是用户访问每篇文章或页面,都会向数据库发送一条查询命定,数据库根据命定查询之后,反送查询结果。如果访问量大的时候,会出现频繁的查询,所以这会减慢网站速度。如果服务器性能不高,瞬间网站就崩溃了,使用Redis可以减少数据库的查询次数。

在BT面板开启PHP扩展里的redis扩展,再使用 Redis Object Cache 插件来开启redis缓存

九、memcached和opcache

Memcached 是一种高性能的分布式内存对象缓存系统,在动态程序中使用 Memcached, 既能提高访问的速度,同时还减低了数据库的负载。

需要注意的是 redis缓存 和 memcached搭配opcache缓存 这两种方案,选一种优化就行了。

这里我们需要配合WPJAM插件来使用,在BT面板的PHP扩展中,安装memcached和opcache,然后将 wpjam-basic/template/ 目录下的 object-cache.php 文件复制到 wp-content 目录下,注意不是 wp-content/plugins/

WordPress 会自动检查在 wp-content 目录下是否有 object-cache.php 文件,如果有,直接调用它作为 WordPress 对象缓存机制。

安装成功之后,WPJAM Basic 会自动在 WordPress > WPJAM 菜单下的的「系统信息」 下看到 Memcached 的信息:

十、数据库添加索引

随着使用时间的增长,WP数据库中的wp_options表会变得越来越臃肿。很多插件会在wp_options表生成临时数据。表的膨胀会影响数据库的性能,然后影响到网站的速度。优化网站过程中优化wp_options表非常重要。

比较简单的优化方案时是给wp_options表添加索引,可以拥有更快的查询速度。

登陆phpmyadmin然后执行一个SQL命令来查询是否创建了索引

SHOW INDEX FROM wp_options;

创建索引SQL语句如下:

CREATE INDEX autoloadindex ON wp_options(autoload, option_name); 

创建完成后再用 SHOW INDEX FROM wp_options; 检查一下即可

 收藏 (0) 打赏

您可以选择一种方式赞助本站

支付宝扫一扫赞助

微信钱包扫描赞助

转载请注明出处橙苏博客 » WordPress站点优化(中级版)
分享到: 生成海报

本站接广告推广、脚本定制、付费咨询

联系微信:Saynothing2020
切换注册

登录

忘记密码 ?

切换登录

注册

我们将发送一封验证邮件至你的邮箱, 请正确填写以完成账号注册和激活