What's the best way to handle the Rails database.yml if multiple people are working on the project and database locations are different (the socket in particular).
That plugin alerts developers before any Rake tasks are run if they haven't created their own local version of config/database.yml.
Fourth, set up a Capistrano deploy task:
# in RAILS_ROOT/config/deploy.rb:
after 'deploy:update_code', 'deploy:symlink_db'
namespace :deploy do
desc "Symlinks the database.yml"
task :symlink_db, :roles => :app do
run "ln -nfs #{deploy_to}/shared/config/database.yml #{release_path}/config/database.yml"
end
end
Fifth, upload the server's version of database.yml:
In addition to above answers, I wrote a rake task similar to "Where's your database.yml, dude?", but allowing to keep template examples of any configuration file. Check it out: https://github.com/Velid/exemplify
As an alternative to writing separate production configs and linking them via Capistrano, I would also suggest using environment variables for your credentials:
password: <%= ENV['PROD_DATABASE_PASSWORD'] %>
There are a lot of handytools and ways to do this available around.