There are three main methods for managing the database when deploying from one workspace to another.<br><br>The most common is &quot;write down, or script your database configuration settings and repeat them in the next workspace.&quot;  This is where people generally start out as it is the easiest, conceptually, to understand.  It is both prone to human error and tedious, though.<br>

<br>The second method is &quot;put everything in code and update functions.&quot;  This is the most recommended method because it is scalable both for very small and very large projects.  It is also the most complicated because it requires adept programmers and takes away all the nice gui tools that makes Drupal development so accessible.  There is progress towards this front, though.  There is a movement to provide more &quot;exportables&quot; that will allow a developer to use the web gui to configure something, export the settings, and place it into code.  Views currently supports this method out of the box.  The &quot;features&quot; module is starting to give exportable support to other areas.<br>

<br>The last, and rarely used, method is &quot;put the database in version control, and merge databases.&quot;  This is probably the most difficult to understand conceptually, but fairly scriptable allowing non-programmer developers to use the web gui and contribute to a project.  It is great for small projects, and becomes increasingly more difficult the larger and larger the database (the restriction is your developer&#39;s computing power, but a production database exceeding 500mb would start to require extra finesse to manage).  The &quot;dbscripts&quot; module provides an extensive amount of scripts in order to use this method.<br>

<br>I use my version control system to deploy to a workspace from the primary repository.  I don&#39;t need to worry about settings.php because I do not include that in version control.  I set the database configuration settings once, and then never erase that file again.  If you do have other settings being used in settings.php, you could put the database connection settings, and any other workspace-specific settings in a separate file and include that file in settings.php.  Manually updating the workspace-specific settings would then only be required when they change  (e.g.: adding Google Analytics to production, while keeping it disabled in development and testing).<br>

<br>I don&#39;t use a &quot;one click&quot; deploy, however, I generally just have to run &quot;svn update&quot; or &quot;svn switch&quot;. <br><br>If you use the &quot;put everything in code and update functions&quot; method, you can install drush and have drush run update.php for you.  Your script would then just say something like, &quot;svn update &amp;&amp; drush updatedb&quot; or &quot;svn switch &amp;&amp; drush updatedb&quot;.<br>

<br>If you use the &quot;put the database in version control, and merge databases&quot; method, then you would restore the appropriate database for the given workspace.  For development and testing, your script would just say something like, &quot;svn update &amp;&amp; ./dbscripts/restore.php none&quot;.  For production, you would first  merge the development and production databases, commit the merged databases and then deploy.  The final deploy script would be something like, &quot;svn switch &lt;release branch&gt; &amp;&amp; ./dbscripts/restore.php production min&quot;.<br>

<br clear="all">--<br>Kathleen Murtagh<br>
<br><br><div class="gmail_quote">On Mon, Jul 13, 2009 at 9:04 AM, Unai Rodriguez <span dir="ltr">&lt;<a href="mailto:me@u-journal.org">me@u-journal.org</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">

Dear Kathleen,<br>
<br>
Thank you so much for your reply.<br>
<br>
I guess we would like our deployment process to be somewhat similar to<br>
what we use in other projects; a number of developers are writing code<br>
while testing on their local machine first (aka developer sandbox).<br>
Each developer&#39;s machine has a web server and database server with a<br>
copy of the code. Once a developer is sure that her stuff is working<br>
fine on her sandbox that is the time when she will commit it into our<br>
version control system (i.e. we use subversion).<br>
<br>
We have a server that takes care of the automated deployments. That is,<br>
any developer can access a web-based interface, input her user/password<br>
and click one button. This button will deploy the build which is<br>
currently on the trunk in subversion and put it into the development<br>
server; also some other things will take place like copying the proper<br>
settings.php file (in drupal&#39;s case) to the proper server(s).<br>
<br>
&gt;From the web-based interface a developer can deploy to any of the 3<br>
environments: development, staging or production. Usually development<br>
is where developers test (plus their sandboxes). Our Quality Assurance<br>
team takes care of testing the staging and production servers. That<br>
means deployments to these two environments are more controlled.<br>
<br>
The deployment process is automated, meaning, you can push the code to<br>
any environment upon clicking one button. The process takes care of<br>
deploying the right code in the right place plus the configuration<br>
files (in this case settings.php).<br>
<br>
We have been doing this for a while, I think is pretty standard.<br>
<br>
Now, for Drupal is different since part of the &quot;settings&quot; are stored in<br>
the database, right? We are having a hard time getting the database<br>
settings to be applied over to the next environment (i.e. development<br>
to staging or staging to production).<br>
<br>
I have been testing the deploy module which is able to do something<br>
like this... My question is more along the lines of... What do you guys<br>
do? Do you just deploy manually (i.e. reproduce the settings from your<br>
sandboxes to development, then to staging then to production) or you<br>
found a way of having this automated?<br>
<div class="im"><br>
Thank you so much :-)<br>
unai<br>
<br>
</div><div><div></div><div class="h5">On Mon, 13 Jul 2009 08:40:48 -0400, Kathleen Murtagh wrote:<br>
&gt; &quot;Automating&quot; deployment?  To what degree do you expect this to be automated?<br>
&gt;<br>
&gt; I can&#39;t think of any situation in which you&#39;d want deployment to be<br>
&gt; done without observation and testing during the process.<br>
&gt;<br>
&gt; Can you elaborate on what sort of process you are expecting?<br>
&gt;<br>
&gt; --<br>
&gt; Kathleen Murtagh<br>
&gt;<br>
&gt;<br>
&gt; On Mon, Jul 13, 2009 at 4:53 AM, Unai Rodriguez &lt;<a href="mailto:me@u-journal.org">me@u-journal.org</a>&gt; wrote:<br>
&gt;&gt; Dear All,<br>
&gt;&gt;<br>
&gt;&gt; We are building a somewhat complex site based on Drupal which features<br>
&gt;&gt; redundant servers at all levels of the system. We are starting of with 12<br>
&gt;&gt; machines. We currently have three environments: development, staging and<br>
&gt;&gt; production.<br>
&gt;&gt;<br>
&gt;&gt; We are having a hard time setting an automated deployment mechanism.<br>
&gt;&gt;<br>
&gt;&gt; I have searched on the archives but was able to find this thread only:<br>
&gt;&gt; <a href="http://lists.drupal.org/pipermail/support/2007-May/004711.html" target="_blank">http://lists.drupal.org/pipermail/support/2007-May/004711.html</a><br>
&gt;&gt;<br>
&gt;&gt; I have not been able to understand from that how other people out there are<br>
&gt;&gt; implementing automated deployment.<br>
&gt;&gt;<br>
&gt;&gt; I found a number of links outside <a href="http://drupal.org" target="_blank">drupal.org</a>:<br>
&gt;&gt;<br>
&gt;&gt;<br>
<a href="http://stackoverflow.com/questions/377629/drupal-deployment-testing-dont-how-to-call-it-tool" target="_blank">http://stackoverflow.com/questions/377629/drupal-deployment-testing-dont-how-to-call-it-tool</a><br>
&gt;&gt; <a href="http://stackoverflow.com/questions/282858/drupal-source-control-strategy" target="_blank">http://stackoverflow.com/questions/282858/drupal-source-control-strategy</a><br>
&gt;&gt;<br>
<a href="http://nicksergeant.com/blog/drupal/painless-drupal-revision-control-cvs-and-subversion-shared-host" target="_blank">http://nicksergeant.com/blog/drupal/painless-drupal-revision-control-cvs-and-subversion-shared-host</a><br>


&gt;&gt;<br>
<a href="http://nicksergeant.com/blog/drupal/my-thoughts-small-scale-drupal-development-production-environments-cvs-and-subversion" target="_blank">http://nicksergeant.com/blog/drupal/my-thoughts-small-scale-drupal-development-production-environments-cvs-and-subversion</a><br>


&gt;&gt; <a href="http://www.workhabit.com/labs/autopilot" target="_blank">http://www.workhabit.com/labs/autopilot</a><br>
&gt;&gt; <a href="http://www.dave-cohen.com/node/1066" target="_blank">http://www.dave-cohen.com/node/1066</a><br>
&gt;&gt; <a href="http://www.garfieldtech.com/blog/drupal-dev-server" target="_blank">http://www.garfieldtech.com/blog/drupal-dev-server</a><br>
&gt;&gt;<br>
&gt;&gt; I have been working with Drupal&#39;s DEPLOY Module<br>
&gt;&gt; (<a href="http://drupal.org/project/deploy" target="_blank">http://drupal.org/project/deploy</a>). Also I am trying to contact Workhabit<br>
&gt;&gt; (i.e. Autopilot guys).<br>
&gt;&gt;<br>
&gt;&gt; I have not found yet a solid approach to automate deployment. Would anyone<br>
&gt;&gt; through me some pointers on how to do it? How are you guys doing this?<br>
&gt;&gt;<br>
&gt;&gt; Thank you so much,<br>
&gt;&gt; unai<br>
&gt;&gt; --<br>
&gt;&gt; [ Drupal support list | <a href="http://lists.drupal.org/" target="_blank">http://lists.drupal.org/</a> ]<br>
&gt;<br>
&gt;<br>
&gt; --<br>
&gt; [ Drupal support list | <a href="http://lists.drupal.org/" target="_blank">http://lists.drupal.org/</a> ]<br>
--<br>
[ Drupal support list | <a href="http://lists.drupal.org/" target="_blank">http://lists.drupal.org/</a> ]<br>
</div></div></blockquote></div><br>