网站速度优化之前要先对网站做个测试,以Gtmetrix为例:
- https://gtmetrix.com
- http://www.whatsmyip.org/http-compression-test
- https://developers.google.com/speed/pagespeed/insights
Gtmetrix的使用很简单,直接输入对应网站,进入官网 输入对应网址,分析即可
data:image/s3,"s3://crabby-images/0f9cb/0f9cb5f6d9e1fd4a7290cd1dadd5bc5558ebbbf7" alt="网站速度优化 Enable Gzip Compression (1)"
然后得分低的一个个优化就好了
data:image/s3,"s3://crabby-images/0a73f/0a73fc6e9c610c346267e41e4e09ae2e1843624c" alt="网站速度优化 Enable Gzip Compression (2)"
先来个文章目录:
以下是正文:
第一个问题: Enable Gzip Compression / Gzip 压缩
Gzip 压缩非常重要,所以说的详细一点。使用不同的服务器会有不同的方法。一个个来说。
第一种情况:Ngnix 独立主机版本【比如Vultr】
先用SSH客户端【比如Xshell】连接独立主机
sudo nano /etc/nginx/nginx.conf
data:image/s3,"s3://crabby-images/3f28c/3f28cacb6320dce9414c071ecf6a98cba276813a" alt="网站速度优化 Enable Gzip Compression (3)"
有时候会提示是否进入 输入字母Y就可以,没提示就直接进入
data:image/s3,"s3://crabby-images/09d6e/09d6e9d5fbb84c697a43da09e40075821ba5e589" alt="网站速度优化 Enable Gzip Compression (4)"
去掉 gzip前面的#号
然后添加代码在下面
gzip_disable “MSIE [1-6]\.(?!.*SV1)”;gzip_vary on;gzip_types text/plain text/css text/javascript application/javascript application/x-javascript;
data:image/s3,"s3://crabby-images/c61ca/c61cae7c0b36c1e1371ecbe96e34fc7ab80fc43c" alt="网站速度优化 Enable Gzip Compression (5)"
Ctrl+X 退出
Y保存
按Enter回到主界面退出,代码重启服务器即可。
service nginx restart
再来测试一下 GZIP已经生效
data:image/s3,"s3://crabby-images/30907/30907d0febf572d9c80bd6139d7c27e5688c0c09" alt="网站速度优化 Enable Gzip Compression (6)"
第二种情况:Apache版本【Centos 控制面板下】
- 进入Apache Configuration
- 找到 # LoadModule deflate_module modules/mod_deflate.so
- 删除#号
- 重启服务器即可
data:image/s3,"s3://crabby-images/6cb74/6cb74a49bb0db137e60c3e86e20e621ca2302e5d" alt="网站速度优化 Enable Gzip Compression (7)"
也可以使用 SSH客户端进入Apache之后输入代码
vi /usr/local/apache/conf/httpd.conf
找到对应代码,删除#号保存
# LoadModule deflate_module modules/mod_deflate.so
重启服务器
service httpd restart
第三种情况:SiteGround版本:
进入控制面版,进入File Manager 进入对应网站目录
data:image/s3,"s3://crabby-images/4863c/4863c1e87d14d1419361c4d50a0d4a62d0136141" alt="网站速度优化 Enable Gzip Compression (8)"
找到 Htaccess文件 编辑
data:image/s3,"s3://crabby-images/14cd5/14cd542ae5fcd26ec7c1d4efa0a0ea51d85d8bdb" alt="网站速度优化 Enable Gzip Compression (9)"
添加代码
<IfModule mod_deflate.c>AddOutputFilterByType DEFLATE text/plainAddOutputFilterByType DEFLATE text/htmlAddOutputFilterByType DEFLATE text/xmlAddOutputFilterByType DEFLATE text/cssAddOutputFilterByType DEFLATE application/xmlAddOutputFilterByType DEFLATE application/xhtml+xmlAddOutputFilterByType DEFLATE application/rss+xmlAddOutputFilterByType DEFLATE application/javascriptAddOutputFilterByType DEFLATE application/x-javascript</IfModule>
data:image/s3,"s3://crabby-images/bd418/bd41890f6d3231af0f97a8b7181f559d741aed4a" alt="网站速度优化 Enable Gzip Compression (10)"
然后右上角的Save保存即可。
第二个问题:Leverage Browser Caching 利用浏览器缓存
## EXPIRES CACHING ##<IfModule mod_expires.c>ExpiresActive On ExpiresByType image/jpg “access 1 year”ExpiresByType image/jpeg “access 1 year”ExpiresByType image/gif “access 1 year”ExpiresByType image/png “access 1 year”ExpiresByType text/css “access 1 month”ExpiresByType application/pdf “access 1 month”ExpiresByType text/x-javascript “access 1 month”ExpiresByType application/x-shockwave-flash “access 1 month”ExpiresByType image/x-icon “access 1 year”ExpiresDefault “access 2 weeks”</IfModule>## EXPIRES CACHING ##
输入以上代码到 hatcess文件保存即可
data:image/s3,"s3://crabby-images/4d3cb/4d3cb2dca91fda4861d5a7a4c405ef07f2ea8624" alt="网站速度优化Leverage Browser Caching"
第三个问题:Optimize Images
WordPress站点,可以直接用免费插件 EWWW Image Optimzier 或者 SMUSH
如果是其他网站类型,比如Magento,可以借助图片压缩工具压缩后再上传。
第四个问题: CDN加速
CDN的基本原理是广泛采用各种缓存服务器,将这些缓存服务器分布到用户访问相对集中的地区或网络中,在用户访问网站时,利用全局负载技术将用户的访问指向距离最近的工作正常的缓存服务器上,由缓存服务器直接响应用户请求。【来自百科】
解决方案:
- 如果你是Siteground用户,系统又自带的CDN,设置一下就可以。
- 也可以购买CDN加速服务,自行谷歌。 【不建议新手折腾】
- 或者自己搭建CDN服务器 【不建议+1】
Siteground自带的CDN, 懒得可以直接找客服设置。
进入 Cloudflare
data:image/s3,"s3://crabby-images/b8268/b826860444b446a89ea043b904e8a0896a92718d" alt="网站速度优化-CDN加速 (1)"
Active – Confirm勾选 – Proceed 即可
data:image/s3,"s3://crabby-images/b7f56/b7f56bef0293beb3d632ff28d5cad76db727535b" alt="网站速度优化-CDN加速 (2)"
用户体验是无限的,但是如果没有CDN也没关系。做到其他的,比对手也强多少倍了。
Leave A Comment