最新公告
  • 欢迎您光临更好小站,本站频繁遭到攻击,如无法访问请晚点或次日访问,感谢!立即加入我们
  • 声明:“付费源码经本站测试后发布,下载即用;相对于别的资源站,搬运但不测试, 付费购买又不能用!不是浪费大家时间?欢迎大家支持我们!签到投稿即可获得积分下载!“

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

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

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

    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; 检查一下即可

    1. 本站坚持“不能用的源码发出去都是浪费大家时间“,付费源码都是亲测的
    2. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入!
    3.更好小站仅提供学习的平台,所有资料均来自于网络,版权归原创者所有!本站不提供任何保证,并不承担任何法律责任,如果对您的版权或者利益造成损害,请提供相应的资质证明,请练习客服予以删除。

    更好小站 » 【怎样优化wordpress】WP站点优化@中篇

    发表评论