- 
                Notifications
    You must be signed in to change notification settings 
- Fork 8
Django production dev
I'm on a WebFaction server, using Apache, mod_wsgi 4.2.8/Python 3.4
Follow these steps:
USE Python3.4 pyvenvinstead of the following
First, ssh to server and clone repo:
$ git clone https://[email protected]/repower/repower.gitNext, follow these steps via the terminal:
$ PYTHONVER=3.3
$ PYTHON=python${PYTHONVER}
$ mkdir -p $HOME/{bin,tmp,lib/$PYTHON,.virtualenvs}
$ easy_install-${PYTHONVER} pip
$ pip3 install virtualenv --no-use-wheel
$ pip3 install --install-option="--user" virtualenvwrapper --no-use-wheelAdd this to your .bashrc file:
# https://community.webfaction.com/questions/4253/simple-virtualenv-usage-with-django/10797
PATH="$HOME/bin:$PATH"
TEMP="$HOME/tmp"
alias python=${PYTHON}
export PYTHON=${PYTHON}
export WORKON_HOME="$HOME/.virtualenvs"
export VIRTUALENVWRAPPER_TMPDIR="$WORKON_HOME/tmp"
export VIRTUALENVWRAPPER_VIRTUALENV=`which virtualenv`
export VIRTUALENVWRAPPER_VIRTUALENV_ARGS='--no-site-packages'
export VIRTUALENVWRAPPER_PYTHON=`which python3`
export PIP_VIRTUALENV_BASE=$WORKON_HOME
export PIP_RESPECT_VIRTUALENV=true
if [[ -r `which virtualenvwrapper.sh` ]]; then
	source `which virtualenvwrapper.sh`
else
	echo "WARNING: Can't find virtualenvwrapper.sh"
fiAnd reload things:
source $HOME/.bashrc
hash -rMake a virtualenv:
$ mkvirtualenv --python=/usr/local/bin/python3 repower --no-site-packagesAdd a sitecustomize.py to your virtualenv:
$ touch ~/.virtualenvs/repower/sitecustomize.pyWhile you're in there, append this to the activate file inside your virtualenv:
export DJANGO_SETTINGS_MODULE="repower.settings.production"
echo $DJANGO_SETTINGS_MODULEActivate your virtualenv:
$ workon repower$ cd ~/webapps/appname_root
$ git clone [email protected]:user/repo.gitDo this:
Navigate to your version controlled git-installed project and enable your virtual environment:
$ repowerNow you can safely install your Django project's required modules:
$ pip install -r requirements.txtRestart apache:
$ ../apache2/bin/restart
# Or, if using custom alias:
$ arestRight about now is a good time to ssh into the server via a new terminal tab and run:
$ tail -f logs/user/error_repower.log
# Or, if using custom alias:
$ herrKeep this tab open and keep tabs on server errors as this will help you debug your setup.
Server setup stuffs follow …
ServerRoot "/home/mhulse/webapps/repower_root/apache2"
LoadModule dir_module        modules/mod_dir.so
LoadModule env_module        modules/mod_env.so
LoadModule log_config_module modules/mod_log_config.so
LoadModule mime_module       modules/mod_mime.so
LoadModule rewrite_module    modules/mod_rewrite.so
LoadModule setenvif_module   modules/mod_setenvif.so
LoadModule wsgi_module       modules/mod_wsgi.so
LogFormat "%{X-Forwarded-For}i %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
CustomLog /home/mhulse/logs/user/access_repower_root.log combined
ErrorLog /home/mhulse/logs/user/error_repower_root.log
KeepAlive Off
Listen 13171
MaxSpareThreads 3
MinSpareThreads 1
ServerLimit 1
SetEnvIf X-Forwarded-SSL on HTTPS=1
ThreadsPerChild 5
WSGIPythonPath /home/mhulse/webapps/repower_root:/home/mhulse/webapps/repower_root/repower:/home/mhulse/webapps/repower_root/lib/python3.4
WSGIDaemonProcess repower_root processes=2 threads=12 python-path=/home/mhulse/webapps/repower_root:/home/mhulse/webapps/repower_root/repower:/home/mhulse/webapps/repower_root/lib/python3.4
WSGIProcessGroup repower_root
WSGIRestrictEmbedded On
WSGILazyInitialization On
WSGIScriptAlias / /home/mhulse/webapps/repower_root/repower/repower/wsgi.pyImportant:
- Make sure Listen 13171is using the port of your WebFaction application
- Change username to match yours
- Change application repower_rootto match yours
- Change Django project name to match yours
"""
WSGI config for repower project.
This module contains the WSGI application used by Django's development server
and any production WSGI deployments. It should expose a module-level variable
named ``application``. Django's ``runserver`` and ``runfcgi`` commands discover
this application via the ``WSGI_APPLICATION`` setting.
Usually you will have the standard Django WSGI application here, but it also
might make sense to replace the whole Django WSGI application with a custom one
that later delegates to the Django one. For example, you could introduce WSGI
middleware here, or combine a Django application with an application of another
framework.
"""
import os
import site
import sys
lazy_path = lambda p1, p2: os.path.abspath(os.path.join(p1, p2))
# Dynamically resolve paths.
VIRTUALENV_PATH = '~/.virtualenvs'
SITE_PACKAGES_PATH = lazy_path(VIRTUALENV_PATH, 'repower/lib/python3.4/site-packages') 
WORKING_PATH = os.path.abspath(os.path.dirname(__file__))
ROOT_PATH = lazy_path(WORKING_PATH, '../')
site.addsitedir(SITE_PACKAGES_PATH)
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'repower.settings.production')
# check virtualenv site-packages FIRST!
sys.path.insert(0, SITE_PACKAGES_PATH)
sys.path.append(ROOT_PATH)
sys.path.append(lazy_path(ROOT_PATH, 'repower'))
# This application object is used by any WSGI server configured to use this
# file. This includes Django's development server, if the WSGI_APPLICATION
# setting points here.
from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()
# Apply WSGI middleware here.
# from helloworld.wsgi import HelloWorldApplication
# application = HelloWorldApplication(application)Put the above in your project's wsgi.py.
Restart Apache:
Restart apache:
$ ../apache2/bin/restart
# Or, if using custom alias:
$ arestAnd it couldn't hurt to reload your profile:
$ source ~/.bash_profileCreate a Static only (no .htaccess) app:

And add it to your existing website (no trailing slash on /static:

After a few minutes, you should be able to visit http://site.com/static
In your "common" or "base" settings file, use:
STATIC_ROOT = join(dirname(dirname(SITE_ROOT)), 'repower_static')Next, run:
$ python manage.py collectstaticBoom!
Note: You can use --dry-run to test collectstatic before anything gets copied.
Assuming you already created that and have your secrets.py setup properly:
$ python manage.py migrateFinally, create a super user so you can login to your admin:
$ python manage.py createsuperuser
… and follow on-screen instructions.
From here, it's a matter of pushing/pulling Git changes and running $ python manage.py makemigrations appname!
WOOT!