• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

YII2通过composer优化vendor

武飞扬头像
PHP中文网
帮助33

学新通技术网

在Yii2社区里经常会遇到一类问题,那就是 安装完官方推荐的版本后

1 为什么没有vendor文件夹?

在Yii2 中,vendor是composer下载的依赖库文件,官方的项目模板代码里只有其自己的项目文件,而其依赖的yii框架等类库,都记录在composer.json里面,只要安装好composer,然后install或update即可。

2 自己安装的Yii2的项目中,vendor中的包在composer.json 中找不到对应,而这些包大多是暂时不需要用到的,该如何remove,保持vendor最小化?

验证过的场景

2.1 使用 composer remove 删除包

所删除的包必须在vendor文件夹下的composer.json中有记录,并且在删除包的同时,所有的包会重新安装一次。

2.2 使用 composer update --no-dev 删除包

开发模式下的包会直接被删除,删除后运行项目,直接报错。因此开发模式的包不能被全部删除

学新通技术网

学新通技术网

2.3使用 remove codeception/verify 删除包,大部分测试模式下的包均被删除,根据我的以往开发经验,单元测试相关的组件没有使用到,所以可以 remove codeception/verify 命令对Yii2的compposer包进行精简。这个命令是优化composer包的关键一环。

3 多个项目在一个工程下时,会不会因为首次加载composer包太多而引起加载的性能问题, 自带的延迟加载是否能够解决这个问题?

项目明显不需要的组件可以直接remove处理掉,至于性能性能影响暂时还没有遇到过。延迟加载算是框架级别的优化,我选择相信它的能力

4 vendor路径问题造成的目录或文件不存在提示

假设我们的项目路径是 E:sourcestemplates

在Vendor路径有问题时,会出现以下类似的问题,即某个composer包不存在

Invalid Parameter – yiibaseInvalidParamException
The file or directory to be published does not exist: E:sourcestemplatesbackendvendorbower-asset/jquery/dist

文件包不存在只是表现,主要的原因是vendor路径和工程的配置文件不对应。

在工程的主配置文件main.php下有关于vendor的配置入口,VendorPath具体值,要结合配置文件的路径,请参照下面的两幅图以及相关的路径配置

第一幅

学新通技术网

'vendorPath' => dirname(dirname(__DIR__)) . '/vendor',

第二幅

学新通技术网

'vendorPath' => dirname(dirname(dirname(__DIR__))) . '/vendor',

总结:

我们在使用compser时需要考虑以下三个问题

1 composer install 和composer update的区别

2 composer版本管理和稳定性

3 公共组件如何以 composer包的方式输出和维护

以下命令区别参考网络资料整理

composer install

应该是最常用的命令,composer会根据本地的composer.json安装包,将下载的包放入项目下的vendor目录下,同时将安装时候的包版本信息放入到composer.lock,以便锁定版本.

其实在install的时候,假如发现composer.lock版本和目前vendor目录下的代码版本是一致的,则Composer会什么也不做,composer.lock的目的就是让你安心在目前这个版本下工作,而不获取最新版本的包.

composer update

composer.lock文件中的包版本会被更新,composer.json记录的包都会被更新到最新。

composer update命令要谨慎使用。

如果组件已经使用composer引用到项目中,成为公共组件,需要谨慎使用composer命令,当然需要专人负责维护,没有共享操作权限。

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tangbhjik
系列文章
更多 icon
同类精品
更多 icon
继续加载