1

我想在 heroku 上使用 MySQL 运行一个应用程序。我已经cleardb为此目的安装和配置了。我剩下要做的就是配置环境变量。但是,我找不到合适的方法来做到这一点。

本文中,Matt 解释了如何配置上述变量:

// config/database.php

$url = parse_url(getenv("CLEARDB_DATABASE_URL"));

$host = $url["host"];
$username = $url["user"];
$password = $url["pass"];
$database = substr($url["path"], 1);

// . . .

'mysql' => array(
    'driver'    => 'mysql',
    'host'      => $host,
    'database'  => $database,
    'username'  => $username,
    'password'  => $password,
    'charset'   => 'utf8',
    'collation' => 'utf8_unicode_ci',
    'prefix'    => '',
),

他还说:

如果您实际上是在真实站点上工作,则应该确保您只是专门为您的生产环境编辑数据库凭据

那么,在生产环境中应该如何配置环境变量以cleardb在 heroku 上运行 MySQL 呢?

4

2 回答 2

6

被标记为 Laravel 5.2,您需要在.env文件中设置环境变量。该文件不包含在版本控制中,因为您应该在每次安装时使用不同的版本。.env.example默认情况下提供A。

例如,如果您的网址是:

CLEARDB_DATABASE_URL => mysql://adffdadf2341:adf4234@us-cdbr-east.cleardb.com/heroku_db?reconnect=true

然后在你的.env文件中你可以放:

DB_CONNECTION=mysql
DB_HOST=us-cdbr-east.cleardb.com
DB_PORT=3306
DB_DATABASE=heroku_db
DB_USERNAME=adffdadf2341
DB_PASSWORD=adf4234

config/database.php保持原样。

另一种解决方案是在.env文件中定义上面的 URL 并按照建议动态解析它。请注意,这些变量是使用 访问的env("CLEARDB_DATABASE_URL")

编辑

由于 CLEARDB_DATABASE_URL 是自动设置的,因此使用它可能会更好。

// config/database.php

if ($url = env('CLEARDB_DATABASE_URL', false)) {
    $parts = parse_url($url);
    $host = $parts["host"];
    $username = $parts["user"];
    $password = $parts["pass"];
    $database = substr($parts["path"], 1);
} else {
    $host = env('DB_HOST', 'localhost');
    $username = env('DB_USERNAME', 'forge');
    $password = env('DB_PASSWORD', '');
    $database = env('DB_DATABASE', 'forge');
}

// ...
        'mysql' => [
            'driver' => 'mysql',
            'host' => $host,
            'database' => $database,
            'username' => $username,
            'password' => $password,
            'charset' => 'utf8',
            'collation' => 'utf8_unicode_ci',
            'prefix' => '',
        ],
于 2016-04-21T22:46:15.590 回答
0

在 Heroku 上设置环境变量非常简单。您可以使用 Heroku CLI,如下所示: heroku config:set CLEARDB_DATABASE_URL="Your DB URL"

您还可以通过 Heroku 仪表板轻松配置环境变量。

于 2016-04-18T20:30:35.460 回答