详解laravel mysql表优化
发布时间 - 2021-02-05 00:00:00 点击率:次下面由laravel教程栏目给大家详解laravel mysql表优化 ,希望对需要的朋友有所帮助!
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 任务运行器 一起使用。
3. 类映射加载优化
optimize 命令把常用加载的类合并到一个文件里,通过减少文件的加载,来提高运行效率:
php artisan optimize --force
会生成 bootstrap/cache/compiled.php 和 bootstrap/cache/services.json 两个文件。
你可以可以通过修改 config/compile.php 文件来添加要合并的类。
在 production 环境中,参数 --force 不需要指定,文件就会自动生成。
要清除类映射加载优化,请运行以下命令:
php artisan clear-compiled
此命令会删除上面 optimize 生成的两个文件。
注意:此命令要运行在 php artisan config:cache 后,因为 optimize 命令是根据配置信息(如:config/app.php 文件的 providers 数组)来生成文件的。
4. 自动加载优化
此命令不止针对于 Laravel 程序,适用于所有使用 composer 来构建的程序。此命令会把 PSR-0 和 PSR-4 转换为一个类映射表,来提高类的加载速度。
composer dumpautoload -o
注意:php artisan optimize --force 命令里已经做了这个操作。
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. 使用即时编译器
HHVM 和 OpCache 都能轻轻松松的让你的应用程序在不用做任何修改的情况下,直接提高 50% 或者更高的性能,PHPhub 之前做个一个实验,具体请见:使用 OpCache 提升 PHP 5.5+ 程序性能。
10. 前端资源合并
作为优化的标准,一个页面只应该加载一个 CSS 和 一个 JS 文件,并且文件要能方便走 CDN,需要文件名随着修改而变化。
# 加载
# 可以使用
# 应用程序
# 的是
# 并到
# 就会
# 你可以
# 不需要
# 都能
# 适用于
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
js实现获取鼠标当前的位置
Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解
Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理
iOS中将个别页面强制横屏其他页面竖屏
Laravel如何使用Blade模板引擎?(完整语法和示例)
消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工
如何在服务器上配置二级域名建站?
微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】
Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程
javascript基本数据类型及类型检测常用方法小结
Linux系统命令中screen命令详解
零服务器AI建站解决方案:快速部署与云端平台低成本实践
Laravel路由怎么定义_Laravel核心路由系统完全入门指南
如何在万网自助建站中设置域名及备案?
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
如何利用DOS批处理实现定时关机操作详解
laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法
详解vue.js组件化开发实践
详解Android图表 MPAndroidChart折线图
Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧
如何生成腾讯云建站专用兑换码?
LinuxCD持续部署教程_自动发布与回滚机制
免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?
如何在景安服务器上快速搭建个人网站?
Laravel如何实现API版本控制_Laravel版本化API设计方案
如何在阿里云高效完成企业建站全流程?
Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门
如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?
百度浏览器如何管理插件 百度浏览器插件管理方法
高端网站建设与定制开发一站式解决方案 中企动力
在线教育网站制作平台,山西立德教育官网?
Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理
Laravel怎么清理缓存_Laravel optimize clear命令详解
青岛网站建设如何选择本地服务器?
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
Laravel事件监听器怎么写_Laravel Event和Listener使用教程
简单实现jsp分页
php485函数参数是什么意思_php485各参数详细说明【介绍】
深圳网站制作的公司有哪些,dido官方网站?
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集
lovemo网页版地址 lovemo官网手机登录
Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】
详解Android中Activity的四大启动模式实验简述
如何在搬瓦工VPS快速搭建网站?
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
如何快速生成橙子建站落地页链接?
Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】
Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理


he