ci框架版本:3.1.10
现象:本地跑的好好的,上了测试环境,突然就报错了
排查步骤:
- 遇到问题,肯定是追代码,发现$this->conn_id不存在;
- 继续追,发现是DB_driver.php在初始化函数initialize()里面,$this->conn_id没有生成,但继续执行了,没有报数据库连接错误;
- 就顺着initialize()往前找,找到了system/database/DB.php里面,发现有初始化CI_DB_mysqli_driver 的类;
- 就把初始化传的参数打印出来,发现是数据库连接参数错误;
- 查明为什么参数传的不对,原来是环境变量错误;
- 命令行(cli)调用的环境变量,没有使用nginx配置;
解决办法:
- 执行脚本命令之前,加上
export CI_ENV='testing';