This boilerplate has been tested with a fresh Webfaction server on May 24 2012.
It worked without any issues. However, if you use it and fab install_everything
crashes you will have read the fabric error message
carefully, think hard about what might have gone wrong, probably fix the
fabfile (and open an issue here) and try again. The fab task is setup in such
a way that it deletes previous failed attempts on the server so that it can be
run over and over again.
This project will help you to start new Django projects on Webfaction servers.
Throughout the instructions we will stick to the following naming conventions:
username
is your webfaction username. You will want to chose a username as short as possible since database names have to start withusername_
and are quite limited in length.yourproject
is the name of your project. You will probably name your folder on your local development environment like this. It should be a short name as well.- We will prepend or append
yourproject
at many places. We could just name your appsdjango
,static
andmedia
etc. but we want to make sure that you are able to host several projects on one machine in a clean and manageable way. Most likelyyourproject
andusername
will be the same for your first site. yourdomain.com
is the domain that you want to use.
Before you can start to deploy your Django site on your Webfaction server, you need to add various settings at your Webfaction control panel:
- First, change your control panel password
- Next, change your SSH/FTP password
- Go to domains management
- Add the domain
git.username.webfactional.com
- Add the domain
yourdomain.com
andwww.yourdomain.com
- Go to applications management
- Create a new
Django
appDjango X.X.X (mod_wsgi 3.3/Python 2.7)
. Call it yourproject_django
. Just select the latest release. It doesn't really matter because we will use a virtualenv anyways.- Create a new
Static
appStatic only (no .htaccess)
. Call ityourproject_media
and enableexpires max
. - Create a new
Static
appStatic only (no .htaccess)
. Call ityourproject_static
and enableexpires max
. - Create a new app
Static/CGI/PHP-5.3
. Call ityourproject_www
. - Create a new app
Git
. Call itgit
and enter a password. - Go to website management
- Add a new site called
yourproject
and mapyourproject_django
to/
,yourproject_media
to/media
andyourproject_static
to/static
. - Use the subdomains
username.webfactional.com
,yourdomain.com
andwww.yourdomain.com
. - Add a new site called
git
and mapgit
to/
. - Mark it as
HTTPS
- Use the subdomain
git.username.webfactional.com
- Go to database management
- Create your database (
username_yourproject
) and note down the password. You should create a PostgreSQL database as the latest MySQL has problems with south migrations ofeasy_thumbnails
. - Got to email management
- Crate a new mailbox (
username_yourproject
) and note down the password.
First setup your local virtualenv. If you are not familiar with virtualenv and virtualenvwrapper we strongly recommend to have a look at those first:
mkvirtualenv -p python2.7 yourproject
workon yourproject
Next cd
into your desired project folder and clone this repository:
cd $HOME/Projects
mkdir yourproject
cd yourproject
git clone git://github.com/bitmazk/webfaction-django-boilerplate.git src
Now you can install some requirements that we need to run fabric. We also added
some useful tools that will help you to develop and debug your project more
efficiently. You should also install the requirements of the actual Django
project. Please note that if you are on Linux and want to use gorun for continuous
testing, you should uncomment a few lines in the first requirements.txt
:
cd src
pip install -r requirements.txt --upgrade
pip install -r website/webapps/django/project/requirements.txt --upgrade
Next you need to copy fabric_settings.py.sample
and modify it for your needs.
Basically you just need to modify your webfaction username and your desired
project name. Usually both will be the same unless you are hosting several
Django apps on the same Webfaction server. It also holds some values that will
be inserted into your server's local_settings.py
.
cp fabric_settings.py.sample fabric_settings.py
You might want to create a .ssh
directory on your Webfaction server with
permissions setup properly. Once you have done that, copy your public key, ssh
into your Webfaction server and append your key to .ssh/authorized_keys
. If
you have already done sone, you can skip this step. It will setup the .ssh
folder on your server according to the Webfaction user guide on
accessing your data using SSH keys:
fab run_create_ssh_dir
Since you are on the server now anyways, you might consider to install our Webfaction dotfiles.
From now on we will use a fabric file that will setup your local repository and
deploy it on your webfaction server. First it will prepare your local repository.
Obviously you cloned this boilerplate repository but you don't want our history
in your new project's history. So first the fabfile delete the .git
folder and
.gitmodules
, run git init
, add submodules, copy local settings files
and run syncdb
and loaddata
.
After this you should be able to cd
into the project
folder, run
./manage.py runserver
and login to /admin-XXXX/
with username admin
and password test123
.
Next it will login to your Webfaction server and create a git repository, hook
up your local repo with the one on the server and do a push. It will install many
useful scripts for django-cleanup, database backups, media-files backups and
translation catalogues backups. It will install cronjobs, place a .pgpass file,
install virtualenv and virtualenvwrapper, make changes to the .bashrc file,
clone your repo into the folder /src
, install the requirements.txt
and
do a first deployment, which will run syncdb
, migrate
, collectstatic
and
makemessages
. And for all this goodness you only need one command:
# The task will only halt once and ask for your git password
fab install_everything
This will run for up to 20 minutes or so. Afterwards you will have a ready to go local project that is also deployed on your Webfaction server.
We even went one step further and provided initial fixtures which should give you everything you need for a normal website. In order to install the fixtures locally do the following. If you just want to create your own CMS pages and start creating your templates, you can skp this step:
cd website/webapps/django/project
fab rebuild
./manage.py runserver
The idea behind this rebuild command is that a new developer should never be forced
to download the lates database from production in order to get started. Instead
we should always provide fixtures that setup enough test data so that a new developer
can run fab rebuild
and as a result he will see a fresh database that has all
needed CMS pages and apphooks and lorem ipsum blog posts and other test data inside.
Your development workflows might differ, so you can just ignore this command.
At this point you are able to browse to username.webfactional.com
and see
the django-cms welcome screen. First you should login at /admin-XXXX/
with username admin
and password test123
and change your password.
The next thing you should do is ssh into your Webfaction server and change
the secret key in
$HOME/webapps/yourproject_django/project/settings/local/local_settings.py
.
If you want to make use of the fab rebuild
command on your server as well,
you should run:
workon yourproject
pip install fabric
pip install coverage
cd $HOME/webapps/yourproject_django/project/
fab rebuild
This setup assumes that you are deploying a multilingual project, so you would want to create your first translation catalogues now:
cd $HOME/webapps/yourproject_django/project/
workon yourproject
./manage.py makemessages -l ch_ZN
If you don't intend to use i18n, you can remove the scheduled backups from crontab:
crontab -e
# remove the line about locale-backup.sh
In your local project you should change the recepients for the contact form
app. Usually this should be your customers info@yourdomain.com
address.
You can find the file at
../project/settings/installed_apps/contact_form.py
.
You should also have a look at ../project/templates/base.html
and change
the site name that gets appended to the title. If you are using Google
Analytics, you should enter your ID, if not, you should delete the analytics
code snippet.
- Document what gets changed and how to revert in case of failure
- fab rebuild does not work because there is no test_media
- Why is there a
fabfile_settings.py-r
andurls.py-r
after install everything? - News text is not displayed
- Add
delete_project
task - Only add cronjobs if not there already
- Make sure django forwards to www
- Bug: Stuff gets appended to .bashrc even if it is already there
- Autogenerate secret key