Laravel踩坑日记之一

背景

昨天晚上发布生产之后,准备执行php artisan migrate同步表结构,结果报错了。然后立马有人反应后台也无法使用了,所有操作都报Target [Illuminate\Contracts\Bus\Dispatcher] is not instantiable.,这时侯我内心是崩溃的,因为代码和测试环境是一样的,第一反应是环境问题,因为生产环境是开启了opcache,立刻关闭了opcache,错误仍然存在的。

百度

百度的高赞结果是缺少一个 BUS 的中间件,那很简单,config/app.php注释它,结果还是报错。既然百度不能解决,只能下一步回滚了。

回滚

因为我们是用阿里云流水线发布代码的,所以能马上回滚。回滚之后,代码就没有报错了。正是因为是流水线发布代码,所以怀疑是发布脚本的问题。 看了发布脚本如下:

#!/bin/bash
cd  /home/admin/laravel/
composer update -vvv
#php artisan migrate
cp -n .env.xxx.production .env
rsync -av --exclude '.git' /home/admin/laravel/ /www/xxx/laravel/
cd /www/xxx/laravel/
sh ./deploy_comm.sh
chown -R www.www /www/xxx/laravel/
echo '---结束--- deploy_正式'

验证

因为怀疑了是流水线发布代码的问题,所以为了验证,直接在www目录克隆了代码,执行composer update -vvv时就报内存错误了,解决了composer错误。果然问题就没有了。然后再次发布代码,错误仍然存在。代码、环境都没问题了,根据经验来看,那就只是权限和缓存了,仔细检查了权限之后,想起来每次composer之后他都会提示一个命令php artisan package:discover --ansi,平时都没怎么关注它,详情看完之后,它的描述是Rebuild the cached package manifest,那应该就是它的问题了,执行完它之后,问题终于解决了。

总结

对于像laravel这种大而全的重量级框架来说,踩坑是必然的。对于框架的报错,一定得从提示里面找答案。像执行php artisan就报Target [Illuminate\Contracts\Bus\Dispatcher] is not instantiable.这样的错误基本就排除了业务代码的问题。使用流水线发布代码,脚本还是得完善,像上面的脚本,没有判断composer是否成功,下面就必然有坑了。



–end–

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值