Blog

Blog

PHODAL

Nginx Wp Super Cache 配置

一直不满意于寻ta驿站的加载速度,而wordpress的解决方案又比Django简单得多,于是便开始寻觅插件——wp super cache

WP Super Cache

A very fast caching engine for WordPress that produces static html files.

一个快速的缓存引擎用于给WordPress生成产品极的静态html文件。

果断到插件搜索WP Super Cache

安装完,打开

 wp-content

于是就tree一下,有了下面的结果,然而没有缓存html。

.
|____wp-cache-ba402bb3c61119a05655cd0babe02921.html
|____config
| |____master.php
| |____index.html
|____supercache
| |____xunta.phodal.net
| | |____person
| | | |____lian-zai-ji-ke-ai-qing-xu
| | | | |____index.html
| | | |____she-jian-shang-de-cheng-xu-yuan
| | | | |____index.html
| | | |____ji-ke-ai-qing-zhi-yi-ai-ta-hai-shi-ai-wo
| | | | |____index.html
| | | |____zhong-guo-de-nan-bei-wen-hua-cha-yi
| | | | |____index.html
| | | |____category
| | | | |____thinking
| | | | | |____index.html
| | | |____ji-ke-ai-qing-zhi-er-wo-men-qu-shi-yan-shi-yue-hui-ba
| | | | |____index.html
| | |____index.html
| | |____about
| | | |____index.html
|____index.html
|____blogs
|____meta
| |____wp-cache-ba402bb3c61119a05655cd0babe02921.meta
|____tmp
|____.htaccess

因为还需要进一步设置。但是已经可以用curl找到寻ta的相关信息了

  curl -I -s http://xunta.phodal.net/person/ji-ke-ai-qing-zhi-er-wo-men-qu-shi-yan-shi-yue-hui-ba/

HTTP/1.1 200 OK
Server: mokcy/0.17.0
Date: Wed, 04 Jun 2014 02:27:06 GMT
Content-Type: text/html; charset=UTF-8
Connection: keep-alive
Vary: Accept-Encoding
X-Powered-By: PHP/5.4.0
WP-Super-Cache: Served supercache file from PHP
X-Page-Speed: 1.7.30.4-3847
Cache-Control: max-age=0, no-cache, must-revalidate

可以看到Super Cache在里面了,接着便是配置Nginx了

Nginx WP Super Cache

添加下面的配置

set $cache_uri $request_uri;

# POST requests and urls with a query string should always go to PHP
if ($request_method = POST) {
    set $cache_uri 'null cache';
}   
if ($query_string != "") {
    set $cache_uri 'null cache';
}

# Don't cache uris containing the following segments
if ($request_uri ~* "(/wp-admin/|/xmlrpc.php|/wp-(app|cron|login|register|mail).php|wp-.*.php|/feed/|index.php|wp-comments-popup.php|wp-links-opml.php|wp-locations.php|sitemap(_index)?.xml|[a-z0-9_-]+-sitemap([0-9]+)?.xml)") {
    set $cache_uri 'null cache';
}

# Don't use the cache for logged in users or recent

 commenters
if ($http_cookie ~* "comment_author|wordpress_[a-f0-9]+|wp-postpass|wordpress_logged_in") {
    set $cache_uri 'null cache';
}

# Use cached or actual file if they exists, otherwise pass request to WordPress
location / {
    try_files /wp-content/cache/supercache/$http_host/$cache_uri/index.html $uri $uri/ /index.php ;
}

需要注意location /,如果其中还有其他东西的话。

          location / {
            try_files /wp-content/cache/supercache/$http_host/$cache_uri/index.html $uri $uri/ /index.php ;
    etag on;
    FileETag on;
    if (-f $request_filename/index.html){
                    rewrite (.*) $1/index.html break;
            }
    if (-f $request_filename/index.php){
                    rewrite (.*) $1/index.php;
            }
    if (!-f $request_filename){
                    rewrite (.*) /index.php;
            }
    }

关于我

Github: @phodal     微博:@phodal     知乎:@phodal    

微信公众号(Phodal)

围观我的Github Idea墙, 也许,你会遇到心仪的项目

QQ技术交流群: 321689806

新书《前端架构:从入门到微前端》

《前端架构:从入门到微前端》是一本围绕前端架构的实施手册,从基础的架构规范,到如何设计前端架构,再到采用微前端架构拆分复杂的前端应用。本书通过系统地介绍前端架构世界的方方面面,来帮助前端工程师更好地进行系统设计。

前端架构包含以下五部分内容:

  • 设计:讲述了架构设计的模式,以及设计和制定前端工作流。
  • 基础:通过深入构建系统、单页面应用原理、前端知识体系等,来构建出完整的前端应用架构体系。
  • 实施:通过与代码结构的方式,介绍如何在企业级应用中实施组件化架构、设计系统和前后端分离架构。
  • 微前端:引入6种微前端的概念,以及如何划分、设计微前端应用,并展示了如何实现这6种微前端架构。
  • 演进:提出更新、迁移、重构、重写、重新架构等架构演进方式,来帮助开发人员更好地设计演进式架构。
comment

Feeds

RSS / Atom

最近文章

关于作者

Phodal Huang

Developer, Consultant, Writer, Designer

ThoughtWorks 高级咨询师

工程师 / 咨询师 / 作家 / 设计学徒

开源深度爱好者

出版有《前端架构:从入门到微前端》、《自己动手设计物联网》、《全栈应用开发:精益实践》

联系我: h@phodal.com

微信公众号: 与我沟通

标签