我对 Laravel 中环境工作的理解是,对于不同的环境,你有不同的环境。所以,如果你在本地运行你的应用程序,你可以有一个.env.local
文件。如果您正在测试或生产,您可以使用.env.testing
or .env.production
。(如果我错了,请纠正我。)
默认情况下.env
,我们会得到可以编辑的文件。但是谁能告诉我在 Laravel 中改变环境的工作流程是什么。我尝试了文档,但我无法得到它。请帮我。
2 回答
当你安装 Laravel 5.1 时,你会得到两个文件.env
,.env.example
如果你想在本地工作,你可以设置:
APP_ENV=local
APP_DEBUG=true
在你设置的产品中
APP_ENV=production
APP_DEBUG=false
调试模式下的错误消息
来自生产模式的错误消息
注意:您有两个 .env 文件.env
,并且.env.example
.. 您还可以创建另一个您.env.production
命名的文件,但请记住,为了加载您的配置,您必须将文件重命名为.env
编辑:因此,如果您仍在本地工作并且需要另一个数据库进行测试,您可以创建另一个文件,这样您总共有 3 个 .env 文件:
.env.production
.env.local1
.env.local2
每当您想切换配置时,只需将所需文件重命名为 .env
自 Laravel 5 以来,拥有.env.local.php
,的想法已被弃用。现在,在 L5 中,我们有一个文件,您可以在其中存储所有环境配置。要定义你的环境,你应该把它放到这个文件中。.env.production.php
.env
APP_ENV=local
将项目部署到生产环境后,您将.env
在服务器上创建文件并定义APP_ENV=production
如果你使用 Laravel Forge 之类的服务,它为你提供了一种非常简单的存储环境数据的方法。但这是另一个故事:)
编辑
要使用多个数据库连接,您可以执行以下操作:
在你的config/database.php
文件中
<?php
return array(
'default' => env('DEFAULT_DB_CONNECTION', 'mysql'),
'connections' => array(
# Our primary database connection
'mysql' => array(
'driver' => 'mysql',
'host' => 'host1',
'database' => 'database1',
'username' => 'user1',
'password' => 'pass1'
'charset' => 'utf8',
'collation' => 'utf8_unicode_ci',
'prefix' => '',
),
# Our secondary database connection
'another_mysql' => array(
'driver' => 'mysql',
'host' => 'host2',
'database' => 'database2',
'username' => 'user2',
'password' => 'pass2'
'charset' => 'utf8',
'collation' => 'utf8_unicode_ci',
'prefix' => '',
),
),
);
然后,在.env
文件中放另一个键
DEFAULT_DB_CONNECTION=another_mysql
当然,这种预定义了您的连接。如果要动态,可以执行以下操作
$users = DB::connection('another_db_connection')->select('users somehow');
这样,无论您的环境中设置了什么,您都可以从辅助 mysql 连接中获得结果