
laravel 运行 `php artisan config:cache` 后,`.env` 文件将不再被加载,所有环境变量需通过 `config()` 辅助函数访问已缓存的配置项,直接调用 `env()` 将始终返回 `null`。
在 Laravel 8 中,php artisan config:cache 命令会将所有配置文件(如 config/database.php、config/mail.php)编译为一个高性能的 PHP 数组文件(bootstrap/cache/config.php),并完全绕过 .env 文件解析过程。这意味着:
- ✅ 邮件能正常发送:因为 Mail 组件在启动时已从缓存配置中读取了 mail.driver、mail.host 等值(这些值在 config/mail.php 中通过 env('MAIL_HOST') 初始化过——但仅在首次加载配置时生效);
- ❌ env('DB_HOST') 返回 null:因为缓存生成后,env() 函数本身被 Laravel 禁用(底层设为 return null),以防止运行时意外依赖未缓存的环境变量,保障生产环境一致性与性能。
正确做法:始终通过 config() 访问配置值
请将所有直接调用 env() 的代码替换为对应的 config() 路径访问:
// ❌ 错误:缓存后失效
$host = env('DB_HOST', '127.0.0.1');
// ✅ 正确:从已缓存的配置中读取(推荐)
$host = config('database.connections.mysql.host', '127.0.0.1');同理,其他常用变量应映射为: | .env 变量 | 推荐 config() 路径 | |-------------|----------------------| | DB_HOST | config('database.connections.mysql.host') | | MAIL_FROM_ADDRESS | config('mail.from.address') | | APP_NAME | config('app.name') | | REDIS_HOST | config('database.redis.default.host') |
⚠️ 注意事项:env() 仅应在配置文件(如 config/database.php)中使用,用于在缓存生成前将环境值注入配置数组;应用代码(控制器、服务类、任务、监听器等)中禁止直接调用 env();执行 config:clear 后恢复 env() 可用,是开发调试的临时手段,绝不可用于生产环境逻辑;若自定义配置项未被 config:cache 收录,请确认其位于 config/ 目录下且被 ConfigServiceProvider 加载。
总结
config:cache 是 Laravel 生产环境强制要求的优化步骤,它牺牲了 .env 的动态可读性,换取了配置加载速度提升(减少数十次文件 I/O 和字符串解析)。遵循“配置即代码”原则——把环境变量映射到结构化配置中,再通过 config() 统一访问,才是 Laravel 8+ 的标准实践。部署前务必运行 php artisan config:cache,并确保全部 env() 调用均已迁移。










