IT技术互动交流平台

mac osx上面部署Django项目apache+mysql+mod_wsgi

作者:OpenSoucre  来源:IT165收集  发布日期:2015-01-14 22:35:19

1、安装Xcode command line tools

首先,编译mysql和Homebrew需要用到Xcode command line tools,所以首先安装command line tools;

如果安装了Xcode,只需要“Preferences… > Downloads”,之后点击Command Line Tools安装按钮;

如果没有Xcode,去https://developer.apple.com/downloads,搜索Command Line Tools 下载安装

2、安装Homebrew(后面需要用Homebrew安装mod_wsgi),在命令行窗口输入

ruby -e "$(curl -fsSkL raw.github.com/mxcl/homebrew/go)"

3、配置Apache

Apache缺省安装在Mac osx中,osx 10.10 安装的apache版本是2.4,打开终端输入

sudo apachectl start

打开浏览器输入 http://localhost/,你能看到‘It Works’

3.1 启用mod_php

在apache中启用mod_php

cd /etc/apache2
sudo vi httpd.conf

不要注释这行(去掉前面的#号)

# LoadModule php5_module libexec/apache2/libphp5.so

拷贝php.ini.default到php.ini,拷贝后赋予php.ini写权限

cd /etc/
sudo cp php.ini.default php.ini
sudo chmod +w php.ini
sudo vi php.ini

在php.ini文件中,改变MySQL Unix socket(注意如果通过Homebrew安装MariaDB的缺省的是/tmp/mysql.sock)(应该有三处).

xxx.default_socket=/tmp/mysql.sock

测试apache配置ok,重启apache

apachectl configtest
sudo apachectl graceful

如果此时显示servername问题,打开/etc/apache2/httpd.conf, 找到ServerName,将其设为localhost

3.2  配置虚拟主机

我们将要在apache上配置虚拟主机,这将在你mac上提供一个简单管理多个网站的框架。我通常把文档根目录放在~/Sites/,

我们将为我们的网站在Sites下创建文档根目录~/Sites/mysite.com,只有Django app网站的静态内容放在~/Sites/mysite.com下,Django项目

放在~/Documents/mysite

cd /etc/apache2
sudo vi httpd.conf

不注释这行

#Include /private/etc/apache2/extra/httpd-vhosts.conf

测试Apache配置ok

apachectl configtest

这结果应该是

Warning: DocumentRoot [/usr/docs/dummy-host.example.com] does not exist
Warning: DocumentRoot [/usr/docs/dummy-host2.example.com] does not exist
Syntax OK

上面所有都ok了,我们将要配置虚拟主机配置文件

cd /etc/apache2/extra/ 
sudo vi httpd-vhosts.conf 

用下面内容替换掉httpd-vhosts.conf文件内容,下面是虚拟主机配置文件的一个好的模板

include /private/etc/apache2/extra/vhosts/localhost.conf
include /private/etc/apache2/extra/vhosts/dev.mysite.com.conf

对每个新的网站,都有一个对应的apache配置文件。我们的Django网站将要在http://dev.mysite.com, 我们将在Apache上虚拟主机文件管理这个网站

如果我们想管理其他网站,仅仅需要增加下面行

include /private/etc/apache2/extra/vhosts/dev.mysite2.com.conf
include /private/etc/apache2/extra/vhosts/dev.mysite3.com.conf
include /private/etc/apache2/extra/vhosts/dev.mysite4.com.conf
include /private/etc/apache2/extra/vhosts/dev.mysite5.com.conf

为localhost创建虚拟主机配置文件

sudo mkdir -p /etc/apache2/extra/vhosts/
cd /etc/apache2/extra/vhosts/
sudo vi localhost.conf 

粘贴下面内容到localhost.conf,保存

<VirtualHost *:80>
    DocumentRoot "/Users/xx/Sites/localhost"
    ServerName localhost
    ErrorLog "/Users/xx/Sites/logs/localhost-error_log"
    CustomLog "/Users/xx/Sites/logs/localhost-access_log" common
    <Directory "/Users/xx/Sites/localhost">
            Require all granted
    </Directory>
</VirtualHost>

为dev.mysite.com创建虚拟主机文件

cd /etc/apache2/extra/vhosts/
sudo vi dev.mysite.com.conf 

粘贴下面内容到dev.mysite.com.conf, 保存

<VirtualHost *:80>
    DocumentRoot "/Users/xx/Sites/mysite.com"
    ServerName dev.mysite.com
    ErrorLog "/Users/xx/Sites/logs/mysite.com-error_log"
    CustomLog "/Users/xx/Sites/logs/mysite.com-access_log" common
    <Directory "/Users/xx/Sites/mysite.com">
           Require all granted
    </Directory>
</VirtualHost>

创建日志和虚拟主机的根目录

mkdir -p  ~/Sites/logs/
mkdir -p  ~/Sites/localhost/
mkdir -p  ~/Sites/mysite.com/

测试apache为ok

apachectl configtest
Syntax OK

重启apache

sudo apachectl graceful

最后在浏览器输入http://dev.mysite.com,测试网站,在之前要,打开/etc/hosts:

sudo vi /etc/hosts

增加行

 打开终端,检测配置文件

ping dev.mysite.com

结果应该是:

最好在~/Sites/mysite.com/下面增加一个index.html, 在浏览器输入http://dev.mysite.com ,可以检查一下日志文件是否正常

3.3、安装MySQL(MariaDB)

不具体说明了,参考官网提供安装步骤https://mariadb.com/blog/installing-mariadb-10010-mac-os-x-homebrew

3.4、安装phpMyAdmin

下载最新版本的phpMyAdmin,在下面目录解压缩

/Users/xx/Sites/localhost/phpmyadmin

在浏览器输入http://localhost/phpmyadmin,登陆用root,密码为上面数据库设置的密码,打开Users标签,选择‘Add user’

创建一个用户project密码为project,选择‘Create database with same name and grant all privileges’,然后‘Add user’

这样,我们准备好了我们Django项目的数据库。

4、安装virtualenv

virtualenv就不多介绍,好处多多,每个环境可以有自己的python和django版本。我们将要先安装virtualenv,然后在虚拟环境中安装Django,

下载 virtualenv-1.9.1.tar.gz

tar xvzf virtualenv-1.9.1.tar.gz
cd virtualenv-1.9.1
sudo python setup.py install

5、用virtualenv创建Django项目

5.1、创建python2.7的虚拟环境

cd ~/Documents/VirtualEnvs/
virtualenv --python=/usr/bin/python2.7 --no-site-packages venv-python2.7-django

激活虚拟环境

cd ~/Documents/VirtualEnvs/venv-python2.7-django/
source bin/activate

在提示符前,你能看到当前虚拟环境被激活

(venv-python2.7-django) $

现在,运行一个python解析器,你将要用的是~/Documents/VirtualEnvs/venv-python2.7-django/bin的解析器,当你通过pip安装python模块时,这些模块都只安装在这个虚拟环境中,而不是系统中。用deactivate命令能退出虚拟环境,回到系统python。

最后测试系统安装:

which python

结果:

/Users/xx/Documents/VirtualEnvs/python2.7-django/bin/python

在虚拟环境中安装最新版本的Django,下载Django-1.5.1.tar.gz,注意终端虚拟环境要被激活

tar xzvf Django-1.5.1.tar.gz
cd Django-1.5.1
python setup.py install

安装distribute>=0.6.28(MySQLdb需要),注意依赖MySQLdb去安装distribute安装时要挂vpn,不然安装不上。下载 distribute-0.6.36.tar.gz 最新版本的是0.7

tar xvzf distribute-0.6.36.tar.gz 
cd distribute-0.6.36/
python setup.py install

5.2、创建Django项目

首先python的虚拟环境被激活(如果没有安装Django,需要在虚拟环境下安装Django),如果你是Django新手,跟着https://docs.djangoproject.com/en/1.5/intro/一步步的做,推荐阅读一下how to manage static files (CSS, images)

推荐两个入门的Django应用http://www.tangowithdjango.com/book/和http://www.ibm.com/developerworks/cn/linux/l-django/

cd ~/Documents
django-admin.py startproject mysite

编辑mysite/settings.py,设置MySQL数据库

DATABASES = {
    ’default’: {
        ’ENGINE’: ’django.db.backends.mysql’, 
        ’NAME’: ’project’,
        ’USER’: ’project’,
        ’PASSWORD’: ’project’,
        ’HOST’: ’’,                 # Empty for localhost
        ’PORT’: ’’,                 # Set to empty string for default.
    }
}

5.3、本地测试Django项目

cd ~/Documents/mysite/
python manage.py runserver

6、用mod_wsgi 部署Django项目

6.1、安装mod_wsgi

用Homebrew安装mod_wsgi,在安装前阅读https://github.com/Homebrew/homebrew-apache下面的文档。如果安装了Xcode就不用这步,没有则需要安装那个文档最下面给的命令去做。

完成后,加载新的Formulas

brew tap homebrew/apache

最后安装mod_wsgi

brew install mod_wsgi

当mod_wsgi安装好后,在apache中启用它,编辑/etc/apache2/http.conf,增加下面行

LoadModule wsgi_module /usr/local/Cellar/mod_wsgi/3.4/libexec/mod_wsgi.so

测试配置文件,重启apache

apachectl configtest
sudo apachectl restart 

6.2、为mod_wsgi配置虚拟主机文件

所有的静态文件指向/Users/xx/Sites/mysite.com/static,python app的WSGI在/Users/xx/Documents/mysite/mysite/wsgi.py

为dev.mysite.com配置虚拟主机配置文件,启用mod_wsgi。编辑 /etc/apache2/extra/vhosts/dev.mysite.com.conf ,拷贝下面行

<VirtualHost *:80>

    LogLevel info

    ServerName dev.mysite.com
    ServerAdmin my@mysite.com

    # Static files
    DocumentRoot "/Users/jc/Sites/mysite.com"
    Alias /static/ /Users/jc/Sites/mysite.com/static/

    <Directory "/Users/xx/Sites/mysite.com/static">
        Order deny,allow
        Allow from all
    </Directory>

    # WGSI configuration
    WSGIDaemonProcess mysite.com processes=2 threads=15 display-name=%{GROUP} python-path=/Users/xx/Documents/mysite/:/Users/xx/Documents/VirtualEnvs/python2.7-django/lib/python2.7/site-packages

    WSGIProcessGroup mysite.com

    WSGIScriptAlias / /Users/xx/Documents/mysite/mysite/wsgi.py

    <Directory "/Users/xx/Documents/mysite/mysite">
        <Files wsgi.py>
            Order allow,deny
            Allow from all
        </Files>
    </Directory>

</VirtualHost>

如果想在django中用apache和mod_wsgi,可以参考 How to use Django with Apache ad mod_wsgi和 official mod_wsgi documentation

最后,把apache访问的文件夹赋予权限

Chmod -R 755 ~/Documents/mysite/mysite
Chmod -R 755 ~/Documents/Sites/mysite.com

重启apache

 sudo apachectl graceful

6.3、收集静态文件

django项目的静态文件应该在~/Documents/Sites/mysite.com/static,通过http://dev.mysite.com/static,

打开django项目,编辑settings.py,改变STATIC_ROOT:

STATIC_ROOT = /Users/jc/Sites/mysite.com/static/

从Django项目中收集所有静态文件

python manage.py collectstatic

最后,在浏览器输入http://dev.mysite.com/admin ,你将要看到

Tag标签: 项目  
  • 专题推荐

About IT165 - 广告服务 - 隐私声明 - 版权申明 - 免责条款 - 网站地图 - 网友投稿 - 联系方式
本站内容来自于互联网,仅供用于网络技术学习,学习中请遵循相关法律法规