m.form1.cn

整理laravel性优化过程

PHP Laravel 1865

0.系统层面的优化:

ulimit -n    #默认是1024,修改大些
sudo vim /etc/security/limits.conf

 

添加两行

* soft nofile 655360
* hard nofile 655360


1. 配置信息缓存

使用以下 Artisan 自带命令,把 config 文件夹里所有配置信息合并到一个文件里,减少运行时文件的载入数量:

php artisan config:cache


上面命令会生成文件 bootstrap/cache/config.php,可以使用以下命令来取消配置信息缓存:

php artisan config:clear


此命令做的事情就是把 bootstrap/cache/config.php 文件删除。


注意:配置信息缓存不会随着更新而自动重载,所以,开发时候建议关闭配置信息缓存,一般在生产环境中使用,可以配合 Envoy 任务运行器 一起使用。


2. 路由缓存

路由缓存可以有效的提高路由器的注册效率,在大型应用程序中效果越加明显,可以使用以下命令:

php artisan route:cache


以上命令会生成 bootstrap/cache/routes.php 文件,需要注意的是,路由缓存不支持路由匿名函数编写逻辑,详见:文档 - 路由缓存。


可以使用下面命令清除路由缓存:

php artisan route:clear


此命令做的事情就是把 bootstrap/cache/routes.php 文件删除。


注意:路由缓存不会随着更新而自动重载,所以,开发时候建议关闭路由缓存,一般在生产环境中使用,可以配合 Envoy 任务运行器 一起使用。


4. 自动加载优化

注:laravel 5.6开始已去掉php artisan optimize功能,在conposer.json中加上

"config": {
"optimize-autoloader": true
}

将自动把常用类缓存刚才 \bootstrap\cache\services.php


5. 使用 Memcached 来存储会话

每一个 Laravel 的请求,都会产生会话,修改会话的存储方式能有效提高程序效率,会话的配置信息是 config/session.php,建议修改为 Memcached 或者 Redis 等专业的缓存软件:

'driver' => 'memcached',


6. 使用专业缓存驱动器

「缓存」是提高应用程序运行效率的法宝之一,默认缓存驱动是 file 文件缓存,建议切换到专业的缓存系统,如 Redis 或者 Memcached,不建议使用数据库缓存。

'default' => 'redis',


7. 数据库请求优化

数据库请求优化


数据关联模型读取时使用 延迟预加载 和 预加载 ;

使用 Laravel Debugbar 或者 Clockwork 留意每一个页面的总数据库请求数量;

这里的篇幅只写到与 Laravel 相关的,其他关于数据优化的内容,请自行查阅其他资料。


8. 为数据集书写缓存逻辑

合理的使用 Laravel 提供的缓存层操作,把从数据库里面拿出来的数据集合进行缓存,减少数据库的压力,运行在内存上的专业缓存软件对数据的读取也远远快于数据库。

$posts = Cache::remember('index.posts', $minutes = 30, function()
{
    return Post::with('comments', 'tags', 'author', 'seo')->whereHidden(0)->get();
});

remember 甚至连数据关联模型也都一并缓存了,多么方便呀。


9. 使用即时编译器(JIT)

HHVM 是目前比较好的 JIT 实现,能轻轻松松的让你的应用程序在不用做任何修改的情况下,直接提高 50% 或者更高的性能。


10. 开启 OpCache

PHPhub 之前做个一个实验,具体请见:使用 OpCache 提升 PHP 5.5+ 程序性能。


11. 前端资源合并

作为优化的标准,一个页面只应该加载一个 CSS 和 一个 JS 文件,并且文件要能方便走 CDN,需要文件名随着修改而变化。


Laravel Elixir 提供了一套简便实用的方案,详细请见文档:Laravel Elixir 文档。


参考链接:

https://learnku.com/articles/2020/ten-laravel-5-program-optimization-techniques

https://www.cnblogs.com/cj8988/p/9606508.html

https://www.cnblogs.com/lamp01/p/8985068.html