8

我是一名 RoR 开发人员,但我目前正在为一个无法调整服务器的项目使用 CakePHP。在我的 Rails 生产服务器中,Passenger 设置为自动使用“生产”环境,覆盖本地应用程序设置。我想设置我的 cakephp 应用程序来做同样的事情。您通常如何使用 CakePHP 来实现这一点?您是否设置了域解析器,或者您只是将 core.php 和 database.php 排除在版本控制之外?在此先感谢,戴维德

4

4 回答 4

13

如果我正确理解了这个问题,这可能是您需要的:

在 CakePHP 中自动选择数据库连接

简而言之,重写DATABASE_CONFIG构造函数:

class DATABASE_CONFIG
{
    //initalize variable as null
    var $default=null;

    //set up connection details to use in Live production server
    var $prod = 
        array(
            // ...
        );

    // and details to use on your local machine for testing and development
    var $dev = 
        array(
            // ...
        );

    function __construct ()
    {       
        if(isset($_SERVER['SERVER_NAME'])){
            switch($_SERVER['SERVER_NAME']){
                case 'digbiz.localhost':
                    $this->default = $this->dev;
                    break;
                case 'digbiz.example.com':
                    $this->default = $this->prod;
                    break;
            }
        }
        else // we are likely baking, use our local db
        {
            $this->default = $this->dev;
        }
    }
}
于 2009-06-29T10:44:31.460 回答
9

在 bootstrap.php 中定义 prod/dev 可能会更好。这样您就可以在整个应用程序中重用常量。

引导程序.php:

define('IS_PROD',(isset($_SERVER['SERVER_NAME']) && $_SERVER['SERVER_NAME'] == 'cubismedia.com') ? true : false); 

数据库.php:

function __construct() {
        if (IS_PROD) {
            $this->default = $this->prod;
        } else {
            $this->default = $this->dev;
        }
    }

//development
public $dev = array(
    //db settings
);

//production
public $prod = array(
    //db settings
);
于 2013-06-01T20:07:21.463 回答
1

您可以创建一个包含单个Configure::write('debug', 0)* 指令的额外文件,将其导入 core.php 文件并使其不受版本控制。两全其美。

*或您需要更改的其他任何内容

于 2009-06-29T07:10:21.237 回答
1

对于数据库,您可以设置本地和生产连接设置,然后创建文件 app/app_model.php 并包含以下行:

class AppModel extends Model
{
  var $useDbConfig = 'production';
}

然后您可以创建文件 app/app_controller.php 并解析域并通过使用 Configure::write 告诉它要使用哪个 dbconfig 以及任何其他 core.php 设置。

于 2009-06-29T07:13:48.483 回答