[扩展推荐] JosephSilber/page-cache Laravel 静态页面缓存
43

file

Laravel 页面缓存

这个包允许您轻松地将响应缓存为磁盘上的静态文件,以便更快速地加载页面。

介绍

当静态网站构建器例如 Jekyll 和 Jigsaw 在现今十分流行的时候,动态的PHP网站仍然提供了很大的价值,即使是一个大多是静态的网站。一个正确的PHP网站可以让您轻松地在需要的地方添加动态功能,也意味着根本不需要去推送更新等这些构建步骤。

这就是说,对于网站上真正的静态页面,真的是没有理由要必须启动一个完整的PHP应用程序来提供静态页面,而从磁盘提供一个简单的HTML页面速度更快,对服务器的要求更低。

解决方案就是整页缓存。

使用这个包里面的中间件,可以有选择地缓存对任何请求的响应到磁盘中。随后对同一页面的调用将直接作为静态html页面提供!

安装

用 composer 安装 page-cache 包:

$ composer require silber/page-cache

服务提供者

注意:如果你使用Laravel5.5+,service provider 会自动注册,你可以完全忽略这一步骤。

找到 config/app.php 并添加这一段到 providers 数组中:

Silber\PageCache\LaravelServiceProvider::class,

中间件

打开 app/Http/Kernel.php 并添加这行到你的 web 中间件组中:

protected $middlewareGroups = [
    'web' => [
        \Silber\PageCache\Middleware\CacheResponse::class,
        /* ... keep the existing middleware here */
    ],
];

这个中间件非常智能,它只会缓存状态码是200的HTTP的GET请求。

如果你想有选择地缓存特定的请求到你的网站,你应该添加新的映射到 routeMiddleware 数组中:

protected $routeMiddleware = [
    'page-cache' => Silber\PageCache\Middleware\CacheResponse::class,
    /* ... keep the existing mappings here */
];

当注册了中间件后,你就可以参考这里 use this middleware on individual routes.

URL 重定向

为了在缓存后直接提供静态文件,您需要正确配置您的Web服务器来检查这些静态文件。

  • nginx:

修改 location 中的 try_files 命令来包含 page-cache 目录:

location = / {
        try_files /page-cache/pc__index__pc.html /index.php?$query_string;
}

location / {
        try_files $uri $uri/ /page-cache/$uri.html /index.php?$query_string;
}
  • apache:

打开 public/.htaccess 并在 Handle Front Controller 之前添加下面内容:

# Serve Cached Page If Available...
RewriteCond %{REQUEST_URI} ^/?$
RewriteCond %{DOCUMENT_ROOT}/page-cache/pc__index__pc.html -f
RewriteRule .? page-cache/pc__index__pc.html [L]
RewriteCond %{DOCUMENT_ROOT}/page-cache%{REQUEST_URI}.html -f
RewriteRule . page-cache%{REQUEST_URI}.html [L]

忽略缓存文件

为了确保你不把你的本地缓存文件提交到你的git仓库,添加这行到你的 .gitignore 文件中:

/public/page-cache

使用

使用中间件

注意:如果你添加这个中间件到全局 web 中间件组中,那么所有的成功的 GET 请求都会被缓存下来,这就不需要再把中间件添加到路由中了。

如果您将其注册为路由中间件,那么您应该在要缓存的任何路由上使用中间件。

如果要缓存指定请求的响应,使用 page-cache 中间件:

Route::middleware('page-cache')->get('posts/{slug}', 'PostController@show');

现在每一篇文章都会缓存在 public/page-cache 目录中,需要完全匹配 URL 结构,所有后续的这个帖子的请求将直接由磁盘提供,甚至都不会去请求你的应用程序!

清除缓存

由于响应作为静态文件缓存到磁盘,所以应用程序中这些页面的任何更新都不会在您的网站上有所展示,如果要更新您网站上的页面,您应该使用以下命令清除缓存:

php artisan page-cache:clear

一个经验之谈,将这个命令添加到您的部署脚本是一种很好的做法。
这样,无论何时更新代码并推送到您的站点的时候,页面缓存都将自动清除。

如果你使用 Forge 的快速部署功能,你应该在你部署脚本的最后加入这行命令,这将确保当您将更新推送到您的网站时,缓存被清除。

证书

这个 Page Cache 包是完全开源并遵循 MIT license 的。


Practice makes perfect.

原文地址:https://github.com/JosephSilber/page-cac...

译文地址:https://laravel-china.org/topics/7939/ex...

本帖已被设为精华帖!
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 1

@Summer
[InvalidArgumentException]
Could not find package silber/page-cache.

Did you mean this?
silber/page-cache

file
请问这个是啥么原因吖,怎么解决?

7个月前

  • 请注意单词拼写,以及中英文排版,参考此页
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`, 更多语法请见这里 Markdown 语法
  • 支持表情,使用方法请见 Emoji 自动补全来咯,可用的 Emoji 请见 :metal: :point_right: Emoji 列表 :star: :sparkles:
  • 上传图片, 支持拖拽和剪切板黏贴上传, 格式限制 - jpg, png, gif
  • 发布框支持本地存储功能,会在内容变更时保存,「提交」按钮点击时清空
  请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!