Не используйте тот же файл настроек, который вы предлагаете в псевдокоде. Вместо этого используйте три разных файла настроек в трех разных папках, каждая папка соответствует имени домена каждого из ваших экземпляров.
Как минимум, как правило, каждая среда будет использовать отдельный хост базы данных. Другие параметры, которые могут отличаться от среды к среде, могут включать хост Apache Solr, настройки memcached, временную папку и папку с файлами. Вы можете разместить все это там. Когда вы переносите базу данных из PROD в TEST в DEV, она автоматически выбирает указанные вами настройки.
Представьте, что мой сайт называется myfoobarsite.com. Вот как будет выглядеть моя структура настроек:
/htdocs
../sites
..../default
....../default.settings.php
..../dev.myfoobarsite.com (DEV)
....../settings.php
..../qa.myfoobarsite.com (TEST)
....../settings.php
..../myfoobarsite.com (PROD)
....../settings.php
У меня также обычно есть два локальных экземпляра сайта, один с последним снимком базы данных от PROD и другой, где я храню все свои изменения. Это очень полезно при работе с компонентами и позволяет вам проверять свои функции на производственной базе данных (локально) перед фиксацией. Вот измененная структура:
/htdocs
../sites
..../default
..../dev.myfoobarsite.com (DEV)
..../qa.myfoobarsite.com (TEST)
..../myfoobarsite.com (PROD)
..../mfbs.local (LOCAL ONE)
....../settings.php
..../mfbs2.local (LOCAL TWO)
....../settings.php
Что касается ваших локальных экземпляров, не забудьте сделать соответствующие записи в /etc/hosts
файле и изменить настройки хоста Apache.
На всякий случай я также поместил фрагмент из settings.php для руководства:
<?php
$databases['default']['default'] = array(
'database' => 'myfoobarsite',
'username' => 'foo',
'password' => 'bar',
'host' => '127.0.0.1',
'port' => '3306',
'driver' => 'mysql',
'prefix' => '',
);
/**
* Apache Solr settings.
* Use the acquia_identifier/acquia_key when hosting w/ Acquia.
* Specify only the apachesolr_path key for your local instance
* or instances that do not use Acquia.
*/
//$conf["acquia_identifier"] = "ABCD-12345";
//$conf["acquia_key"] = "1234f05ab12345dc1234a1234bbc1c12";
$conf["apachesolr_path"] = "http://localhost:8983/solr";
/**
* Filesystem settings (MAC OS X, LOCAL)
*/
$conf["file_public_path"] = "sites/default/files";
$conf["file_temporary_path"] = "/Users/amateurbarista/tmp";
$conf["file_private_path"] = "/Users/amateurbarista/Sites/tfk/private";
Наконец, если вы используете хостинг с Acquia, вам нужно будет переходить http://myfoobarsite.com/admin/config/system/acquia-agent
и нажимать «очистить ключи» каждый раз при переносе базы данных. Это заставит Drupal отбросить ключи, которые пришли с импортированной базой данных, и забрать те, которые указаны в файле настроек.