Bootstrap

Magento2运行原理剖析

我们不讲底层架构,核心原理,太枯燥,也记不住,没必要。
毕竟不是人人都要当架构师。

我们从M2的模式说起。
理解了他的模式,就知道了他的原理。

M2有3种模式,

  1. 默认模式(default)
  2. 开发模式(developer)
  3. 生产模式(production)

默认模式

安装完成后,就是默认模式。
它跟生产模式差不多.
最大的不同是,
默认模式可以在后台清缓存,生产模式不能。
它带有一点灵活性。

  1. 错误不显示在页面上,错误记录到项目的var/report里
  2. 开启静态缓存文件,也就是说读取的静态缓存文件,在pub/static里
  3. 默认模式未针对生产环境进行优化,主要原因是静态文件是动态生成(先创建静态文件再缓存)。而生产模式是用命令行工具生成的静态文件,不是动态生成。所以默认模式的性能没有生产模式好。
  4. 可以在后台开启/禁用/刷新缓存

开发模式

顾名思义,就是开发测试用的。

  1. 错误直接显示在页面上
  2. 关闭静态缓存文件,每次页面刷新都动态生成静态文件到pub/static里
  3. 可以在后台开启/禁用/刷新缓存
  4. 可以在后台设置浏览器编译less

生产模式

线上站点都必须改成生产模式。

  1. 错误不显示在页面上,错误记录在项目的var/report里
  2. 开启静态缓存文件,每次只从pub/static目录读取缓存文件,如果没有的话 就报错了。错误要在var/report里看。
  3. 不能在后台开启/禁用/刷新缓存。
  4. 要用命令行工具来生成静态文件,生成在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分开发模式和生产模式,因为开发模式非常耗资源,所以服务器配置按需配置:

  1. 开发和线上版本都在同一个服务器,配置至少是4核8G
  2. 服务器只放线上版本,配置至少是2核4G
  3. 服务器只放开发版本,配置至少是2核8G
;