trademonster 发表于 2019-8-17 00:00:55

WordPress网站速度优化超强图文教程,实测十分有用!

本帖最后由 trademonster 于 2019-8-17 00:21 编辑

https://img.liaosam.com/uploads/2019/08/accelerate_wordpress_website.png
本文是转载文章。原文链接
网站速度是 WordPress 网站成功的关键因素。网站速度越快,用户体验越好,网页浏览量也会随之上升,访客也更容易在页面停留。此外,速度也是网站在 Google SERP(搜索结果页))中排名的重要指标之一。
根据亚马逊和谷歌实验室的研究表明,页面加载时间延迟 1 秒可导致转换率下降 7%,页面浏览量减少 11%,访问者满意度降低 16%。更重要的是,谷歌和其它搜索引擎会对速度慢的网站降低排名,这意味着响应速度缓慢的网站从搜索引擎上自然搜索产生的流量会降低。
我一直希望网站速度能够更快些。我把英文网站从 Bluehost 迁移到了 SiteGround 上,我把中文博客从 Linode VPS 东京机房迁移到阿里云香港,去年又迁入内地阿里云杭州,都是为了速度能更快点。
事实上,促使我在过去不断尝试更好的 WordPress 主机商的原因就在于此,最终对 SiteGround 还算满意。
在本文中,我将梳理和分享最实用的 WordPress 速度优化技巧。我会帮你把网站速度至少提升2倍!
一、使用在线测速工具测试你的网站速度
国外比较知名的测速平台就是 Pingdom 和 GTMetrix 了。通过 Pingdom 测速,我们可以大概知道你的网站的评分等级和存在哪些可以优化的问题。
比如截图中的这个网站,这张图片是我从网上随便找的,我不知道这个网站安装的是什么主题,又安装了哪些插件应用,但是问题很明显,HTTP 请求(Requests) 太多了!
https://img.liaosam.com/uploads/2019/08/Pingdom_speed_test.jpg
正如你所看到的,网站首页加载了 106 个资源请求,加载时间 2.35 秒。网站速度表现评分为 78 分,级别为 C。
通常,主要拖慢网站速度的因素有:各类的 Http 资源请求太多、网页没有进行压缩,DNS查询时间偏长等等。有时候未优化的大尺寸图片太多,也会明显拖慢网站速度。
每一项 Suggestion,你都可以点击右侧的小三角,点开看看说明文字,会帮助你更好地理解他们为何会影响网站页面加载速度。
除了 Pingdom,GTMetrix 也会测试并对你的网站给出优化意见。如下面这个测试就是一个做了一定优化的英文网站的测试结果。得分一般,还有很多可以改进的空间。
https://img.liaosam.com/uploads/2019/08/GtMetrix_website_speed_test.png
看起来这些优化建议好像技术性很强,但是不要紧,我会尽量介绍一些工具帮助大家更容易理解和处理这些优化步骤。
二、哪些因素拖慢了你的网站速度?
通常来说,一个网站加载速度主要是由几个部分决定的:
[*]网站主机 – 当你所用的虚拟主机或 VPS 性能不高或机房维护质量不佳时,可能会影响你的网站速度。
[*]WordPress 没有配置缓存 – 如果您的 WordPress 网站没有启用缓存机制,那么访问每次都需要请求主机或服务器,网站自然会变慢。访问量大时,也容易崩溃。
[*]错误的 HTTP 请求 – 网站页面 URL 出现错误导致 403, 404, 500, 502 或其他 HTTP 错误,则可能会显着降低网站的整体性能。在 Chrome 浏览器使用 F12 调用开发者工具然后找到 Networks 选项卡,重新 F5 刷新页面,在“网络”选项卡中检查网站是否有此类链接;或者使用 GTmetrix“Waterfall”选项卡和“Pingdom”中的“Response Codes”中查看是否有错误链接。
[*]重定向 (Redirect) 过多 – 多个重定向会进一步减慢网站的重定向等待时间。最好的做法是最终合并成单个重定向:从 HTTP/HTTPS 非 www 的访问(http://domain.com 或 https://domain.com)到 https 的 www 访问(https://www.domain.com)。
[*]图片优化 – 通常页面上的文字并不十分影响速度,没有针对 Web 访问进行优化的图片,会明显拖慢页面加载速度。
[*]页面未压缩 – 如果网页上包含很多文字和图片,以及其它多种元素,那么页面加载速度可能会减慢。比如,一篇较长的小说,如果不分页来阅读,即使是静态 HTML 页面,文件大小也非常大,可能达到几 MB。如果开启页面压缩,则页面文件体积会减小,加载速度也会明显变快。
[*]WordPress主题 – 如果你使用轻量简洁的主题,网站加载速度自然很快。如果你使用功能比较强大,用途比较广的主题,比如 Multi-purpose 主题,这些主题要实现非常多的功能则需要加载很多的 Javascript 脚本文件和不少 CSS 样式表文件,这些都会影响速度。简而言之,根据用途来选择主题。如果只是建个博客,无需使用太臃肿的主题。
[*]数据库查询负荷 – 如果数据库始终处于大量并发同时查询任务,那么数据库查询和读取结果的速度会变慢,进而表现为网站响应速度变慢。甚至数据库会崩溃,网站打不开。
[*]外部资源/脚本 – 比如,某种网页字体,比如实现某些功能的 JS 脚本,也会对网站性能产生很大影响。最明显的就是有时候安装太多 WordPress 插件,会感觉网站速度变慢。有时候某一款插件可能调用的 JS 文件有问题,导致网站加载半天都打不开。这些都是外部资源脚本造成的。


既然知道了有哪些因素会减慢 WordPress 网站的速度,让我们来看看如何加快你的 WordPress 网站。
三、选择质量性能过硬的网站主机或VPS
这是直接影响网站速度的重要因素。对于虚拟主机,我推荐 SiteGround。如果你需要对比国外虚拟主机,请看这篇文章:SiteGround虚拟主机注册和使用教程。SiteGround 今年更新了新的后台界面,清爽简洁。真香!
对于VPS,推荐 Linode 或 Aliyun。无论是建国内网站还是外贸网站,VPS 里口碑相对较好的还是 Linode 和阿里云。阿里云ECS其实就是VPS,建国内中文站选国内机房,建外贸站英文站之类,可以选美国机房,质量也是还不错的,但是阿里云俗称套路云,用起来各种费用开支。
另外,VPS建站需要你懂 VPS 建站操作,如果是纯新手,可能会比较费劲,因为你可能连装个 BT 新手面板都不会操作。
如果是建站新手,还是建议直接从虚拟主机开始。毕竟,快速建立起你希望看到的网站并不断丰富内容,才是最重要的。而 SiteGround 在这些方面已经做到了最好:

[*]全SSD硬盘,5A级机房,专业机房维护人员24小时轮值,保证网站正常在线运行时间99.99%
[*]提供特有的 SiteGround Supercacher 的专有服务器级缓存,以提高站点速度
[*]免费提供 Cloudflare CDN(我将在后面解释 CDN 是什么及其重要性)
[*]使用最新的服务器级软件。例如,SiteGround 总是第一时间提供升级更新最新版本的 PHP。
[*]免费提供一次从你的旧主机帐户免费将网站转移到 SiteGround 的服务,这是非常实用又有价值的服务。(如果需要转移多个网站,需要付费)
[*]SiteGround 还有一个内置的 WordPress 插件:SG Optimizer,这个插件的设置对提高网站的速度非常重要。


四、开启缓存插件
缓存,英文名Cache,有个美妙的发音,跟 Cash 发音基本相同。缓存的作用主要是减少数据交互的传输量,减少数据处理次数,降低对磁盘文件的访问次数。总之,缓存能将一些文件创建副本存放起来,用以下一次访问或查询的快速调用响应,返回页面或结果。当缓存副本被调用时,只会产生很小的网络流量,可以有效地降低带宽消耗。
网站所涉及到的缓存,主要是指指一个 Web资源(如 html 页面,图片,JS文件,数据等)存在于 Web 主机(服务器)和客户端(浏览器)之间的副本。缓存会根据网站访客的请求保存输出内容的副本;当下一个请求来到的时候,如果是相同的URL,缓存会根据缓存机制来决定:是直接使用副本来响应访问请求,还是向源 Web 主机(服务器)再次发送请求。
为什么我要认真介绍缓存,因为当你的网站建立差不多的时候,你就要开始应用缓存机制。缓存可以使你的 WordPress网站的速度明显提高2-4倍!
一般来说,在客户端,我们比较常见的是本地电脑浏览器的缓存。我们的浏览器会缓存访问过网站的网页,当再次访问这个 URL 网页地址的时候,如果网页没有更新,就不会再次下载网页,而是直接使用本地浏览器中缓存的网页。
根据缓存的类型,一般分为:静态缓存、动态缓存、数据库缓存、CDN缓存以及浏览器缓存等。
静态缓存 (Static):CSS样式表文件、JS脚本文件、HTML静态网页、JPG/GIF/PNG 图片文件、MP3/MP4/AVI 等静态媒体文件的缓存。如果一个页面包含很多图片,每次访问都要从网站主机上下载图片,必然十分耗费资源。所以一些经常要读取又很少要修改的静态文件,是最佳的缓存对象。通常很多缓存插件都支持静态文件缓存。
动态缓存 (Dynamic):关于动态缓存,主要是加速 PHP 运行效率用的。
WordPress 的页面是“动态的”,即使可以设置 rewrite 规则使得 WordPress 支持伪静态,但本质来说,WP 还是动态的。这意味着每当有人访问你网站上的文章或页面时,它们都是即时构建的。如果对 PHP 能够创建缓存,那么这个环节的速度会得到极大提升。
事实上,一些知名的缓存插件如 WP Super Cache 或 WP Fastest Cache 都支持动态缓存。如果你使用 SiteGround 主机,则无需安装这些插件。后面我再解释。
另外,如果你使用 VPS,可以用 LNMP 环境包装包开启 OPCache 缓存,或者安装BT面板开启 OPCache 缓存,有助于提升 PHP7 的 PHP 性能。PHP 5.5 版本之后已经默认内嵌 OPCache 了,只是没有开启。
以前还有个老牌的 PHP 缓存应用:eAccelerator。一般使用了 OPCache 之后,就无需再安装 eAccelerator 了。
至于 SiteGround 的用户就更不用操心了,SiteGround 从 PHP7 版本就默认配置开启了 OpCache 缓存,所以不用管它。
数据库缓存:如果同一时间访问请求太多,可能会造成对于数据库查询的负荷增大。有很多功能强大的 Web 应用或 WP插件,由于功能太多,往往会创建很多数据库表,如果频繁进行数据库查询,很容易导致数据库不堪重荷。为了提升数据查询的性能,可以把查询后的数据放到内存中进行缓存。下次查询时,直接从内存缓存读取。
比如常见的数据库缓存方案有 Memcached 和 Redis,我比较喜欢用前者。Memcached 和 Redis 都是通过在内存中缓存数据和对象来减少读取数据库的次数,属于内存级的缓存。如果你用 SiteGround 主机,也无需了解如何安装 memcached,后面我再解释。
另外,如果你使用 VPS,可以用 LNMP 环境包装包开启和配置 MemCached 缓存,或者安装BT面板开启 MemCached 缓存,有助于提升数据库查询速度和效率。VPS 上安装开启 MemCached 之后,可以在 WordPress 后台搜索:Memcached is your friend 插件,启用插件,即可此插件的 object-cache.php 文件管理 Memcached 缓存。
CDN缓存:CDN(Content delivery networks)缓存,也叫反向代理缓存。关于 CDN 是什么,下文我再解释。'
浏览器缓存:浏览器缓存的作用是记住浏览器已加载的资源。当访问者访问你网站上的其它页面,并且新页面调用跟之前已访问页面相同的资源时(比如 网站 Logo 图片,CSS文件或JS文件)时,不需要再次连接获取这些文件,而是会从本地浏览器的缓存中加载,这对加速网站是非常有用的。
很多缓存插件都支持开启浏览器缓存,比如 WP Super Cache 或 WP Fastest Cache。如果你使用 SiteGround 主机,则无需安装这些插件。二楼继续!

trademonster 发表于 2019-8-17 00:05:22

引起我注意的是,这个插件有几个其他的小功能特别棒,都是 SG Optimizer 插件里没有的功能,正好补全了。比如:
[*]1)Site-Wide 不加载文件设置
[*]2)Fonts 字体文件的遇加载功能
[*]3)Google Fonts 字体的合并处理。
https://img.liaosam.com/uploads/2019/08/Asset_CleanUp_Sitewide_Unload_common_files.png在 Site-Wide Common Unloads 这里,按照截图中的设置去启用相应功能。禁用 Emojis(没什么鸟用)、禁用网页嵌入(不安全)、禁用新款的古藤堡 Block 编辑器的 CSS 库(反正还是经典编辑器舒服)。在 Local Fonts 这里,需要预加载的字体文件,可以在 Preload Google Font Files 文本区内填入字体的地址。如何排查没能顺利加载的字体呢?可以用 F12 开发者工具,刷新网页,选择 Console,注意看哪些字体文件 Fall back,把 URL 记录下来。然后根据插件 Exmaples 的提示,跟你本地网站上调用的主题的字体有关,就粘贴到 Local Fonts 的 Preload Local Font Files 里;跟 https://fonts.gstatic.com 有关的字体就填写到 Google Fonts 那里。https://img.liaosam.com/uploads/2019/08/Asset_CleanUp_Local_Fonts_Preload.png在 Google Fonts 那里,把 Combine Multiple Requests Into Fewer Ones 和 Preconnect? 这两个都开启。https://img.liaosam.com/uploads/2019/08/Asset_CleanUp_Google_Fonts_Preload.png点击 Update All Settings。然后测试一下,你已经起飞了!Pingdom 的 Performance 和 GTMetrix 的 PageSpeed 都是 A。Pingdom检测,得分A grade 93,加载速度 1秒以内(原来评分为 C,加载速度 3.4 秒):https://img.liaosam.com/uploads/2019/08/Pingdom_A_score.pngGTMetrix检测,得分双A grade,请求数 33,页面加载时间 1.5S;未速度优化之前,得分 B(85%) 和 C(76%),请求数 36,页面加载时间2.1S。https://img.liaosam.com/uploads/2019/08/GTMetrix_double_A_score_new.png九、启用CDN加速一般国内网站建站做速度优化,还会做一下动静分离。动静分离是将网站静态资源(HTML,JavaScript,CSS,img 等文件)与后台 PHP 应用分开部署,提高用户访问静态文件或代码的速度,降低对后台应用访问。比如把静态文件全部放在一个二级域名上,如 static.xyz.com 或 img.xyz.com,给静态文件做缓存,并对二级域名开启 CDN 加速。这种用单独的二级域名存放静态文件,Yahoo 的 YSlow 则之为 cookie-free domain。当然,也有不做动静分离,直接全站 CDN 加速的。对于我们使用虚拟主机的建站者来说,动静分离在虚拟主机上是不太好弄的,其实也不需要动静分离这么多复杂的技术活,直接全站开启 CDN 即可。CDN的原理前面我们讲到了客户端浏览器的缓存,只是对访问过的资源,提升二次或重复访问的速度。而对于首次访问的加速不起作用,所以从网络层考虑,最常见的手段就是CDN(Content Delivery Network,内容分发网络)加速。CDN 通过骨干网络把一组服务器连接起来,存储客户数据或内容的副本(缓存)。https://img.liaosam.com/uploads/2019/08/cdn_example.png而通过将静态资源缓存到离用户很近的相同网络运营商的CDN节点上,不但能提升用户的访问速度,还能节省服务器的带宽消耗,降低负载。不同地区的用户会访问到离自己最近的相同网络线路上的CDN节点,当请求达到CDN节点后,节点会判断自己的内容缓存是否有效,如果有效,则立即响应缓存内容给用户,从而加快响应速度。如果CDN节点的缓存失效,它会根据服务配置去源站获取最新的资源抓取到CDN节点上,呈现给访问用户。并且,它会把内容缓存下来,以便响应给后续访问的用户。https://img.liaosam.com/uploads/2019/08/cdn_region_specific.png之所以不同地区的用户访问同一个域名却能得到不同 CDN 节点的 IP 地址,这要依赖于 CDN 服务商提供的智能域名解析服务,浏览器发起域名查询时,这种智能 DNS 服务会根据用户 IP 计算并返回离它最近的同网络 CDN 节点 IP,引导浏览器与此节点建立连接以获取资源。使用CDN的好处使得分布在各个地方的访客都能从离得最近的 CDN 节点服务器上获取网页内容。另外,如果是全站 CDN,那么对于源站,相当于是套了一层防护,可以抵御流量攻击,更安全。废话不多说,来说说具体怎么使用 CDN,如何操作和设置吧。我们所用的 SiteGround,登录后台之后,在 Information & Settings 那里,有个 Cloudflare CDN。这是免费的方案。如果要购买付费的方案,要点击 Get Plus 按钮。https://img.liaosam.com/uploads/2019/08/SiteGround_Cloudflare_CDN.png点击后跳转到 Cpanel 下的 Cloudflare CDN 界面,点击 Activate Free 按钮。https://img.liaosam.com/uploads/2019/08/Siteground_Cpanel_Cloundflare_Free.png在弹出的窗口里,确认你的邮箱作为 Cloudflare CDN 账户。激活 Free account 后,你邮箱会收到一封提示邮件,告知你,你的域名已经添加到 Cloudflare 里了。点击 Manage 按钮,https://img.liaosam.com/uploads/2019/08/Siteground_Cloundflare_Free_manage.png在管理设置页面,找到 Speed。开启 CSS 和 HTML 的 Auto Minify,以及 Railgun(这个是加快 Cloudflare 去你的 SiteGround 上的源站资源的)。https://img.liaosam.com/uploads/2019/08/Cloundflare_Manage_Speed.pngSSL Support 选择 Full (strict),点击 Change 按钮。我就不截图了。很简单的设置,强制所有连接必须为 https。OK,CDN免费账户设置完成!不过 CDN 免费的服务全球节点有限,如果你要开通付费的 CDN 服务,则需要付费。每个月 20 美金左右,觉得需要的话还是可以开通这个付费 CDN 服务的,付费以后 CDN 线路和节点多很多。如果你的网站访客没有固定来源,分散在世界各地,那么一个付费的 CDN 服务还是有价值的。如果预算足够,建议升级付费的 Cloudflare PLUS建站预算不那么紧张的,建议升级付费的 CDN 吧。付费的 Cloudflare CDN才是真CDN,存储在云服务器上;Cloudflare 免费CDN,其实文件并没有真的存储到云服务器才去,效果真的只能呵呵。除了 Cloudflare CDN 之外,还有一个老牌的商家 MaxCDN (现在叫 StackPath CDN) 也是很不错的。检查CDN解析是否生效我们看一下 CDN 智能解析生效了没有。在本地电脑命令提示符中,输入网址:ping www.xyz.com 返回 www.xyz.com.cdn.cloudflare.net [ CDN 节点 IP ]https://img.liaosam.com/uploads/2019/08/Cloudflare_dns_check.pngOK,大功告成!最后再用 GTMetrix 测一下:https://img.liaosam.com/uploads/2019/08/gtmetrix_final_score-1.png十、有针对性地排查网站速度问题如果你对技术有一点兴趣,可以尝试学着使用 F12 Developer Tool。会用基本的 Console、Networks 就差不多了,基本可以很有针对性地排查网站速度问题了。https://img.liaosam.com/uploads/2019/08/all_cached.png其它的部分如 Audits 和 Application 也很有用,但是暂时用不到,以后再讲解吧。本教程完!
原文地址:https://www.liaosam.com/speed-up-wordpress-website.html

trademonster 发表于 2019-8-17 00:03:12

SiteGround 的 SuperCacher 缓存工具SiteGround 开发了一个名为 SuperCacher 的缓存工具,这个工具在三个不同的层提供服务器端缓存:
[*]Level 1 Cache 一级缓存 – 用于静态内容,如图像,HTML文件等;
[*]Level 2 Cache 二级缓存 – 用于动态内容,如 PHP 脚本;
[*]Level 3 Cache 三级缓存 – 用于执行数据库的结果查询
在 SiteGround 后台 Cpanel 下,可以看到一个 SITE IMPROVEMENT TOOLS 板块。下面有个 SuperCacher 应用。https://img.liaosam.com/uploads/2019/08/Siteground_SuperCacher_1.png点击进入后可以看到,有三部分的设置。https://img.liaosam.com/uploads/2019/08/Siteground_SuperCacher_2.png这个 SuperCacher 相当于你 SiteGround 上网站的缓存总开关。我们依次开启 LEVEL 1,LEVEL 2 和 LEVEL 3。因为 SuperCacher 这个缓存工具,是 SiteGround 开发的整体的缓存机制,适用于每个网站。但不同的网站是由不同的程序创建的,比如有些是 WordPress 建的站,有些是 Drupal, Joomla 或 Magento 建的站,不同的程序怎样控制这个缓存系统呢?当然不同的程序下,开发了各自对应的插件,来分别控制。这里我们全部启用之后,WordPress 网站上,只要安装启用插件 “SG Optimizer“,就可以控制各类缓存功能。安装插件后,在 WP 后台左侧菜单中,找到 SG Optimizer。进行如下设置:https://img.liaosam.com/uploads/2019/08/SG_Optimizer_1.png要排除的缓存的 URL,可以填写 wp-admin/* 和 wp-includes/* ,防止 wp-admin 和 wp-includes 下的动态文件被缓存。https://www.ledlightsmfg.com/wp-includes/*https://www.ledlightsmfg.com/wp-admin/*https://img.liaosam.com/uploads/2019/08/SG_Optimizer_Environment.png关于 PHP Management Method 说明:保持使用最新版本的 PHP,可以提高 PHP 的效率,提高网站速度。另外,保持使用较高版本的 PHP,也可以让网站变得更安全一些。
但,可能有个问题,一些插件可能还不支持最新版的 PHP。所以为了兼容性,你也可以选择 Set Manual PHP Version,选择次高版本的 PHP 版本。然后每过半年检查一次 PHP 的版本,保持一致使用次高版本的 PHP。这里的 Browser Caching 的作用类似于 VPS 上设置 Nginx 规则:location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)${   expires 1d;}这里设置expires,并不是指把静态内容缓存在 nginx 中,而是设置客户端浏览器缓存的时间。接着前端页面优化设置(Fronted Optimization)如下,我个人建议不要勾选 Minify Javascript Files,因为 JS 脚本文件的代码压缩,比 CSS 样式表文件容易出一些意外的问题或状况。https://img.liaosam.com/uploads/2019/08/SG_Optimizer_3.png还有一页的 IMAGE OPTIMIZAITON 可以启用。以前我们使用 TinyPNG 出品的图片压缩插件,这个之前的文章里介绍过:WordPress图片压缩插件:Compress JPEG & PNG images现在我们可以少使用一个插件了。当然你可以先取消启用这个图片插件(不然后台总是提示 SG Optimizer 有图片优化功能,跟你已经安装的图片压缩插件功能类似…),然后启用 SG Optimizer 的 IMAGE OPTIMIZATION 里的图片优化功能。开启新图片优化,执行批量图片压缩优化,开启图片的 Lazy Load 功能,具体下面的每个选项,如果你并非的确清楚或强烈需要,我建议不用开启。https://img.liaosam.com/uploads/2019/08/SG_Optimizer_4.png注意:这里有个问题,批量优化图片时,可能会把你网站现有的 LOGO 图片的质量降低。如果出现这种情况,你可以对 LOGO 图片单独用 Cpanel 的 File Manager 上传上去,或者用 FTP 工具如 FlashFXP 上传。OK!这样几步就搞定了 SG Optimizer 的设置。另外,在后台顶部,有个 Purge SG Cache 的链接按钮。点击之后,会清理 SiteGround 的缓存。有时候,你做了一些修改,想清理缓存。比如修改更新了 CSS 文件,希望加载新的样式。但是刷新后网站并无变化,此时你需要刷新缓存。可能你点击了 Purge SG Cache 后也没什么用,因为尽管 SiteGround 主机上已经清理了缓存,但你的浏览器上仍然存在静态文件缓存。此时假设你是 Chrome 浏览器,可以直接按 Ctrl+F5 或 ctrl+shift+R(Mac上使用Cmd + Shift + R)强制不读取浏览器缓存刷新,即可看到修改后的最新样式。其他浏览器我不太清楚,可以尝试一下快捷键,如果不行在浏览器菜单里清理一下缓存文件,刷新网页即可。另外,如果你使用的不是 SiteGround/Bluehost 等虚拟主机而是 VPS,你也不会安装设置各类缓存应用或安装BT面板,那么有个简单的方案可以供你考虑:安装 WP Rocket 加速插件。
注意:如果你使用的是 SiteGround 虚拟主机,不需要去安装 WP Rocket 插件。再次提醒一下,SiteGround 虚拟主机不用安装!跟 SG Opitimizer 很多功能重合!这是一个付费的WP加速插件,有不同价格套餐。如果是单个网站,价格 49 美金/年 (Single方案);如果是 3个网站以内,价格 99 美金/年(Single方案);更高的 Infinite 方案不限网站数量 249美金/年。如果你用的不是 SiteGround 虚拟主机,你非常有必要买一个这样简单又给力的插件。WP Rocket 功能包括:Combine Google Fonts FilesStatic File OptimaztionRemove query strings from static resourcesMinify CSS FilesCombine CSS FilesMinify HTML OutputMinify JavaScript Files(不建议开启)Combine JavaScript Files(不建议开启)Lazy LoadPreloadDatabase OptimizationCDN SettingAdd-ons具体就不一一解释介绍了。上面介绍了 SiteGround 的 SG Optimizer 插件的各项设置,大概各项起什么作用也有个基本概念了。这里再解释一下什么是 Lazy load(懒加载)。就是浏览者页面往下滚动时,滚动到能看到图片的位置时,图片才加载出来。可以节省加载资源,加快网页载入速度。注意:SiteGround 的 SG Optimizer 插件只能用在 SiteGround 主机上,且该插件很多功能与 WP Rocket 插件重合。因此使用 SiteGround 虚拟主机的建站者,无需再安装第三方缓存插件。而 WP Rocket 作为一款优秀的缓存加速插件,功能丝毫不比老牌缓存插件如 WP Super Cache,W3 Total Cache 或 WP Fastest Cache 差,设置和界面的友好度以及易用性等等,都比这些老牌插件好太多了。唯一的一个遗憾是 WP Rocket 没有包含 Memcached 缓存。WP Rocket 团队在官网上解释虽然没有包含 Memcached 缓存,但是并不代表 WP Rocket 和 Memcached 不能共存,并且还推荐了一款 Memcached 插件。具体见:https://docs.wp-rocket.me/article/116-does-wp-rocket-support-memcached关于缓存,就先说到这里。五、优化图片加速页面加载通常在互联网上,JPEG 和 PNG 是最常见的图片格式。PNG图像格式是未压缩的。压缩图像时会丢失一些信息,因此未压缩的图像质量会更高,细节更多。缺点是文件大小较大,因此加载时间较长。而 JPEG是一种压缩文件格式,略微降低了图像质量,但它的尺寸明显较小。那么,在处理一些产品图片的时候,应该如何决定选择哪种图像格式呢?如果照片或图片有很多不同的颜色,那么使用 JPEG。如果图片是一个相对简单颜色较少的图片或你需要透明图片,那么更适合使用 PNG。这个基本上各类缓存插件都开始内嵌图片优化这个功能了。上面 SiteGround 的 SG Optimizer 插件以及付费的 WordPress 缓存插件 WP Rocket 都包含这个功能。使用图片优化,图像大小可以减少最多 5 倍,还是非常有用的。六、大图片适当使用适当尺寸的 Thumbnail 缩略图通过网站测速工具,发现一个问题,提示:Serve scaled images(可以给幻灯片等大图片设置缩放图片),如果你没有这样的问题,这一步可以跳过。在 WP 后台,Settings – Media 下,看到 Thumbnail size,按照,勾选:Crop thumbnail to exact dimensions (normally thumbnails are proportional)点击 Save Changes 按钮,确认保存。七、限制 WordPress 修订版本数量每次在 WordPress 里无论是创建 Page(页面)或 Post(文章),还是编辑,又或者是 Save Draft(保存草稿)或 Publish(发布)或 Update(更新),WordPress 都会自动保存一份修订版本。如果文章编辑的次数很多的话,在数据库里面会存在很多个没用的修订版本,浪费数据库的空间。我们可以限定 WordPress 修订版本的数量,只不过在后台设置里没有这项设置。我们可以在网站文件根目录下的 wp-config.php 里,添加一行代码:define('WP_POST_REVISIONS', 3);这行代码的作用时,只保留最近的3个修订版本。从 SiteGround 后台的 Cpanel 面板里的 File Manager 可以找到网站根目录,用 code edit 方式打开编辑,添加上面这行代码即可。粘贴在 define(‘DB_COLLATE’, ”); 这一行下面,保存即可。八、减少外部资源 HTTP 请求数量我们使用在线网站测速工具测试,经常会发现自己的网站有很多 HTTP 请求。主题功能越多,插件安装得越多,不知不觉调用的 CSS 文件和 JS 文件也越来越多。过多的WordPress插件会降低网站速度。 有的插件可能仅用于某一个特定页面。但是,由于插件开发者欠考虑或代码质量欠佳,这些插件通常会出现在每个页面上,即使它没有被使用。很多 WordPress 网站都加载了很多其实无需加载的文件,这会导致额外的和不必要的请求,这些文件(主要是CSS和JavaScript文件)以及内嵌的代码,都会累加到页面的总体积上,从而减慢您的网站速度。页面加载缓慢或失败,或者 JavaScript 出现错误的代码,或者与其它插件产生冲突,这些都会造成 Google 搜索排名不佳。Asset CleanUp 插件的使用我们可以安装一个名为 Asset CleanUp 的插件,Asset CleanUp 是一个优化前端性能的插件,让你可以选择在网页上禁用不需要在网站上加载的文件,并将剩余的加载的文件组合成更少的文件,这最终将大大减少HTTP请求的数量,优化网页加载速度。https://img.liaosam.com/uploads/2019/08/Asset_CleanUp_Page_Speed_Booster_plugin.png假设你有一个页面,其中加载了 30 个文件(CSS 和 JS),总大小为 1.5 MB。 使用 Asset CleanUp,您可以通过不加载页面上无用的其他 18 个文件,将数量减少到 12 个文件。于是,页面的总体积减小到 0.7 MB,这样可以减少下载资源的时间,从而加快页面加载速度。如果你不确定是否需要在页面上加载某些 CSS 或 JavaScript 文件,并且担心某些内容可能会破坏网站的功能或布局,那么可以使用“Test Mode”。激活此选项后,Asset CleanUp 中设置的所有规则仅对已登录后台的管理员(你)生效,常规访问者看不到测试模式下的页面,看到的还是正常的网站页面。你可以在插件的设置页(Settings)下开启 Test Mode。当你在测试模式下,你可以开启设置页下的使用偏好(Plugin Usage Preferrences),然后启用 Manage in the Front-end(在前台页面管理)。这样,每个页面你都可以拖到最下面,查看加载的 CSS 和 JS 文件,选择不加载哪些文件。等一切设置好后,关闭“测试模式”,你所做的更改也将对未登录的网站访客生效可见。不过说实话,我觉得这个针对页面精准控制禁止加载哪些文件有点太讲究了。大多数外贸人不是极客,不会做这种精细活儿。所以,我就只介绍一下,不讲具体操作了。实际上,我只是体验过特别针对网站首页去前台页面禁止加载某些文件,确实减少了一些 Requests。比如,首页我不需要加载表单插件的 JS。https://img.liaosam.com/uploads/2019/08/Asset_CleanUp_Unload_file_settings.png实际上,每个 Page 或者 Post 编辑区下方,都会显示出加载了哪些文件资源。你都可以进行单独的设置,对我这样喜欢折腾的人来说,太舒服了!当然,我建议你不用学我,这里可以不折腾。因为实际上缓存部分已经有压缩CSS,合并CSS等功能,其实跟着这篇教程做到这里,你的网站已经优化得非常不错了,至少 Pingdom 测测能得 A grade 了!不信你测试看看?三楼继续!

woshigaozhen 发表于 2019-8-21 14:56:31

作者就在论坛里的,他的WP模板的确是不错.

sars231 发表于 2019-9-24 11:20:56

干货满满啊

trademonster 发表于 2019-10-3 11:28:07

sars231 发表于 2019-9-24 11:20
干货满满啊

谢谢支持!

fancylau 发表于 2019-11-29 11:37:14

好文章,最近就打算买siteground的虚机。

ericyang 发表于 2019-12-21 15:36:04

感谢楼主分享。很有用很好用。

iamlinkent 发表于 2019-12-22 21:09:41

文章介绍的部分优化已经用过,确实很好!先收藏了

670003614 发表于 2020-1-16 13:09:20

谢谢分享

displaysonline 发表于 2021-3-21 00:22:58

:lol 我直接 真静态化512K带宽都能秒开-

sead 发表于 2021-3-21 11:42:21

displaysonline 发表于 2021-3-21 00:22
我直接 真静态化512K带宽都能秒开-

静态化解决不了js,css资源臃肿问题。
html 加载完,后续的css,jss才是影响性能得分的最大因素

sunfeng27 发表于 2021-4-24 09:06:20

比较实用,我也准备开搞了。加油。

imant168 发表于 2021-5-7 17:36:31

优化中,国外主题就是卡

trademonster 发表于 2021-8-13 18:09:03

自己顶个帖~ 哈哈~;P
页: [1] 2
查看完整版本: WordPress网站速度优化超强图文教程,实测十分有用!