我们不讲底层架构,核心原理,太枯燥,也记不住,没必要。
毕竟不是人人都要当架构师。
我们从M2的模式说起。
理解了他的模式,就知道了他的原理。
M2有3种模式,
- 默认模式(default)
- 开发模式(developer)
- 生产模式(production)
默认模式
安装完成后,就是默认模式。
它跟生产模式差不多.
最大的不同是,
默认模式可以在后台清缓存,生产模式不能。
它带有一点灵活性。
- 错误不显示在页面上,错误记录到项目的var/report里
- 开启静态缓存文件,也就是说读取的静态缓存文件,在pub/static里
- 默认模式未针对生产环境进行优化,主要原因是静态文件是动态生成(先创建静态文件再缓存)。而生产模式是用命令行工具生成的静态文件,不是动态生成。所以默认模式的性能没有生产模式好。
- 可以在后台开启/禁用/刷新缓存
开发模式
顾名思义,就是开发测试用的。
- 错误直接显示在页面上
- 关闭静态缓存文件,每次页面刷新都动态生成静态文件到pub/static里
- 可以在后台开启/禁用/刷新缓存
- 可以在后台设置浏览器编译less
生产模式
线上站点都必须改成生产模式。
- 错误不显示在页面上,错误记录在项目的var/report里
- 开启静态缓存文件,每次只从pub/static目录读取缓存文件,如果没有的话 就报错了。错误要在var/report里看。
- 不能在后台开启/禁用/刷新缓存。
- 要用命令行工具来生成静态文件,生成在pub/static目录下
也就是说,生产模式为了加速,提高效率,一律只读取pub/static下的静态缓存文件。任何人都干扰不了它。
总结
说白了,默认模式就是个鸡肋,食之无用,弃之可惜。
我们只需要开发模式和生产模式就行。
也就是说我们:
在开发模式下开发测试。
在生产模式下部署上线。
因为默认模式和生产模式都强制性的读取pub/static下的静态缓存文件,所以就比较复杂了,每次修改内容都要清缓存并且重新生成静态文件才生效。
默认模式和生产模式要类似这样操作:
php bin/magento maintenance:enable && git pull origin master
rm -rf var/di/* && rm -rf var/generation/* && rm -rf var/cache/* && rm -rf var/page_cache/* && rm -rf var/view_preprocessed/* && rm -rf pub/static/* && rm -rf generated/* && mkdir var/di
php bin/magento setup:upgrade && php bin/magento setup:di:compile
php bin/magento setup:static-content:deploy -f && php bin/magento indexer:reindex && php bin/magento maintenance:disable && php bin/magento cache:clean && php bin/magento cache:flush
说白了,就是
#1,开启维护模式,如果有用git版本控制代码的话,就pull最新代码下来。
#2,删除静态文件和一系列缓存文件
#3,更新数据库以及代码编译
#4, deploy生成静态文件到pub/static里,供m2读取。
#5,更新索引,关闭维护模式,以及清空刷新magento缓存。
这个我就不细说了,在后面的Magento2线上部署
章节里会详细说到。
他这个pub/static下的静态文件都来源于插件和主题下的web目录下的文件,都是网站运行过程中需要调用的js/css/images/字体等等。
一定要搞清楚你目前的m2项目是处于哪个模式。要对症下药。
不然总是遇到无样式或者页面空白的情况,一脸懵逼。
用这个命令查看当前模式
php bin/magento deploy:mode:show
一句话
开发模式不用管pub/static下的静态缓存文件,也不需要deploy什么的。
生产模式一定要管pub/static下的静态缓存文件,要先删除静态文件清缓存后再deploy生成静态文件,刷新缓存,不然就会出问题。
注意:
不是说开发模式下就不用管缓存了,我这里说的是不需用deploy生成静态文件,缓存还是要清的。
还需要rm generated/* -rf
,因为如果你有修改过php的构造函数function __construct()
里的代码 就需要清下generated/
下的代码缓存,不然会报错 说找不到这个类 等奇怪的错误。
什么是Magento缓存呢?
这里就是所谓的magento缓存。
缓存在var/
下面。
比如var/generation/
,var/di/
,var/cache/
,var/page_cache
,var/view_preprocessed
。
这几个目录都是magento缓存。
不要跟deploy的静态文件搞混淆了,不是同一个东西。
因为deploy的静态文件在pub/static
下面。
因为现在的浏览器缓存也很严重,特别是css/js,要强制刷新才会更新。
所以你修改js/css后 一定要清浏览器缓存,才会看到最新的效果
开发模式/生产模式 任意切换
切换到生产模式
php bin/magento deploy:mode:set production
切换到生产模式后,需要删除缓存文件并deploy下。
切换到开发模式
php bin/magento deploy:mode:set developer
如果有无样式或其他报错的话,先尝试执行更新系统的操作:
php bin/magento maintenance:enable
rm -rf var/di/* && rm -rf var/generation/* && rm -rf var/cache/* && rm -rf var/page_cache/* && rm -rf var/view_preprocessed/* && rm -rf pub/static/* && rm -rf generated/* && mkdir var/di
php bin/magento setup:upgrade && php bin/magento setup:di:compile
php bin/magento setup:static-content:deploy -f && php bin/magento indexer:reindex && php bin/magento maintenance:disable && php bin/magento cache:clean && php bin/magento cache:flush
关于服务器配置问题
因为m2分开发模式和生产模式,因为开发模式非常耗资源,所以服务器配置按需配置:
- 开发和线上版本都在同一个服务器,配置至少是4核8G
- 服务器只放线上版本,配置至少是2核4G
- 服务器只放开发版本,配置至少是2核8G