Wednesday, February 13, 2008

Finished deployment to VPS

There was nothing instant about getting rails deployed to the server, but now that it is there, it should be fairly trivial to deploy new instances from now on.

I had to combine the strengths of Dave Stevenson (SilverRack) and the Agile Web Development with Rails book. There were a few gotchas along the way that I will attempt to address here. In the meantime though, you should be able to access the website here:

http://216.194.127.249/company/list

I'm gonna list the gotchas now, but they may not be in any particular order.
  • An SVN client must be installed on my windows box
  • mongrel_rails cluster::configure command produces a mongrel_cluster.yml file that tells capistrano to look for files in the 'conf' directory instead of the config directory, so after executing that step, it is very important to edit the file appropriately.
  • replace cap --apply-to .... with 'capify .' This was no doubt a new command that didn't exist at the time of publishing
  • In the deploy.rb file, you can add the following entries to make it connect correctly (asterisks added for security):
  • set :user, "root"
    set :svn_username, "*****"
    set :svn_password, "******"
  • cap setup has changed to cap deploy:setup. This only has to be run one time to get all of th right directories in place
  • The /var/www/apg/current directory is actually a symlink that points to another directory under releases. This allows capistrano to maintain several versions of the product, and switch between them with ease.
  • cap cold_deploy changed to cap deploy:cold
  • I had missed the right port numbers in the vhost.conf file. Since the mongrel_cluster.yml file specifies two mongrel threads listening on 8000, and 8001, then the vhost.conf file must also point to 8000 and 8001
  • I found that apache on linux has multiple configuration files all under /etc/httpd/conf.d
  • Only Apache 2.2 supports the mongrel mod and the subversion dav_svn_module. So Apache 2.2 is essential
  • When running capistrano, it starts up the mongrel servers in production mode with a -e production parameter to specify the rails app should use the production server
  • I had to manually run the 'rake db:dbdata:load' command on the application because the rake db:migrate tool didn't have that as part of it.
  • In order to allow http access to SVN, I had to change the ownership on the subversion directories /home/svn. I used the command 'chown -R apache.subversion /home/svn'
  • Centos 4 didn't have the yum repository that includes mysql5 or apache 2.2 so I had to integrate with a repository that Dave Stevenson sent me:

(need to add the exact yum line here)

yum --disablerepo=update --disablerepo=base -y install gcc openssl-devel> mod_perl-devel mod_python mod_ssl mod_dav_svn mysql-server mysql-devel> libpng-devel libjpeg-devel libtiff-devel freetype-devel ghostscript-devel> which>> yum --disablerepo=update --disablerepo=base -y update

  • I still need to configure the database passwords to be taken from a shared location, instead of checked into the database. For now then, I have changed the passwords for the database and modified the file on the server for security.

No comments: