18

我对 Laravel 中环境工作的理解是,对于不同的环境,你有不同的环境。所以,如果你在本地运行你的应用程序,你可以有一个.env.local文件。如果您正在测试或生产,您可以使用.env.testingor .env.production(如果我错了,请纠正我。)
默认情况下.env,我们会得到可以编辑的文件。但是谁能告诉我在 Laravel 中改变环境的工作流程是什么。我尝试了文档,但我无法得到它。请帮我。

4

2 回答 2

31

当你安装 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

于 2015-07-18T10:01:04.537 回答
9

自 Laravel 5 以来,拥有.env.local.php,的想法已被弃用。现在,在 L5 中,我们有一个文件,您可以在其中存储所有环境配置。要定义你的环境,你应该把它放到这个文件中。.env.production.php.envAPP_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 连接中获得结果

于 2015-07-18T09:41:37.310 回答