Skip to content

Deploying to Heroku

peakpg edited this page May 14, 2012 · 14 revisions

In BrowserCMS 3.5.0, we are improving the support for deploying CMS sites to Heroku. This page covers how to set up and deploy a BrowserCMS site on Heroku. In general, using Heroku should work reasonable well, though there are some limitations (See 'No page caching' below) which may limit scalability at the top end.

If you have issues, feedback or questions setting up on Heroku, please post them to the mailing list.

Overview

Deploying to Heroku is slightly different then other servers due to the constraints of the platform. In particular:

  1. No Page Caching: The CMS typically relies on Rails page caching working in conjunction with the web server for performance. Page caching isn't available on Heroku, so for the time being, caching is not used. We are aiming to make caching more configurable in upcoming versions.
  2. Subdomains: The typical configuration of a site will have multiple subdomains (one for the 'public' site, and another for the 'admin' site.). Heroku now supports wildcard domains for free (on Cedar), so BrowserCMS can use the typical subdomain setup.
  3. No file storage: Uploaded files cannot be stored on heroku so you must use an external host, such as AWS S3. There is module bcms_aws_s3 which can be used to store files. The module seemlessly handles sending and storing files on S3. See the installation instructions for that module for more details.
  4. Postgresql - BrowserCMS is most well tested with MySQL and/or Sqlite. Heroku used Postgresql as its default database. At this time, it appears as though BrowserCMS works just fine with Postgresql in production. However, you may want to generate a new browsercms project locally using sqlite3 locally for testing, then switch the database to postgresql after.

Before starting this, review the Rail 3 Heroku guide found here.

1. Instructions

1a. Generate the project

We create the project (using sqlite)

$ bcms new my_heroku_site

This may also work (depending on your local machine setup)

$ bcms new my_heroku_site -d postgresql

1b. Configure Postgresql in production

Ensure your project is configured to use postgresql in production (at least).

# Gemfile
gem 'sqlite3', :group=>:development
gem 'pg', :group=>:production
# config/database.yml
production:
  adapter: postgresql
  encoding: unicode
  database: heroku_app_production
  pool: 5
  username: heroku_app_user
  password: heroku_app_pw

1c. Set up the S3 module

Follow the installation instructions for the bcms_aws_s3 module.

1d. Setup Heroku project

Install Heroku and configure the project to deploy to it. See the Rails 3 Heroku guide for more info.

$ gem install heroku
$ heroku create --stack cedar

Modify the Gemfile to match the heroku deployment environment. This sample Gemfile is a reasonable start. Then check in your changes and deploy the site.

$ git push heroku master
$ heroku run rake db:install

Take note of the domain name that was generated when heroku create was run above (something like: randomname-1234.herokuapp.com), as well as the cmsadmin password generated when running rake db:install

1e. Enable wildcard subdomains

Run the following, substituting your generated domain name above.

$ heroku domains:add randomname-1234.herokupapp.com

You can now access the site at http://www.randomname-1234.herokupapp.com and the admin site at http://www.randomname-1234.herokuapp.com/cms. You may want to set up a redirect from http://falling-light-1159.herokuapp.com to http://www.falling-light-1159.herokuapp.com for consistency.

2. Configuration Options:

Single Domain mode

If you don't want to bother with subdomains, you can disable them, as well as turn of page caching (since they are coupled) by editing your production.rb to disable caching:

# config/environments/production.rb
config.action_controller.perform_caching = false

When caching is disable, the CMS will no longer redirect to the www and cms subdomains.

References:

Clone this wiki locally