django+nginx+mod_wsgi+apache网站部署

软件安装

0.如果对selunix不熟就先把它停掉

  vi /etc/selinux/config

  改动selinux=diabled

  然后重启计算机

1.编译安装python

  mod_wsgi的安装需要使用到python的共享库,编译安装python时要启用共享库

  ./congifure --enable-shared

  make &&make install

  添加python链接库到路径

  sudo vi /etc/ld.so.conf

  /usr/local/Python2.7/lib #添加路径到文件

  sudo /sbin/ldconfig -v

2.安装apache yum -y install apache

3.安装mod_wsgi其实mod_wsgi有两种安装模式,除了单独安装(yum/编译)之外,还可以通过pip install mod_wsgi方式进行安装

  ./configure --with-apxs=/usr/local/apache/bin/apxs \

   --with-python=/usr/local/bin/python

4.安装django pip install django==1.8

三者的关系以及工作过程

  mod_wsgi是apache的一个模块,是遵循python的wsgi协议而开发的、用于连接python web框架的扩展。从这个关系可以看出,这几个软件的信息流是怎样的?

  首先,apache监控服务器主机的80端口,当接收到来自客户端请求的时候,apache会判断这个请求是否匹配,如果匹配其中的某个条件,那么apache就会将这个请求通过mod_wsgi来转发给Django进程进行处理,Django会对这个请求进行进一步处理,执行业务逻辑,最后通过wsgi协议返回响应给apache,apache接收到这个响应之后就会发送给客户端。注意,django再整个部署的过程中是不需要手动启动的,平时我们开发的时候使用python manage.py runserver只是开发过程中调试用的。

配置

配置django

  如果只采用默认的settings的话,是不需要再配置django文件的,如果想分别使用不同的进程来启动同一个项目中的不同应用的话,需要配置wsgi.py中的django环境变量。

配置mod_wsgi

  同样,mod_wsgi默认也是不需要配置的,除非有高级的需求,否则初级的配置只需要默认即可。

配置apache

  对apache这个服务器软件的所有操作都在其配置文件中完成。

  配置文件默认为/etc/httpd/conf/httpd.conf。

  配置文件的具体写法在其官方文档中有详细说明: http://httpd.apache.org/docs/2.2/configuring.html

  apache是一个模块化的软件,除了一些必要的模块在编译时嵌入之外,其它模块需要在配置文件中导入才能发挥作用,apache的所有模块都以mod开头。mod_wsgi毫无疑问需要导入才能使用:

  LoadModule wsgi_module modules/mod_wsgi.so

  另外,配置文件可以直接写在这个配置文件中,也可以写在别的地方,然后导入作为配置的一部分,例如可以把文件写在django项目的根目录下。在apache配置文件中导入这个文件

  Include /root/test1/apache_django_wsgi.conf

  这样就跟全部写在httpd.conf中一样了。

  最终的配置文件简单地配置成下面这个样子:

  1 LoadModule wsgi_module modules/mod_wsgi.so
  2 
  3 <IfModule mod_wsgi.c>
  4 
  5 # '/' 代表你想服务你的应用的base URL路径,'/'也就是root url
  6 
  7 # /path/to.../wsgi.py代表使用WSGI应用来服务该url下的所有请求
  8 
  9 # 如果应用在子目录中(https://example.com/mysite in this example),使用下面的设置
 10 
 11 #WSGIScriptAlias /mysite /path/to/mysite.com/mysite/wsgi.py process-group=example.com
 12 
 13 WSGIScriptAlias / /path/to/mysite.com/mysite/wsgi.py
 14 
 15  
 16 
 17 # 如果建立了虚拟环境,将此路径指向虚拟环境的python path
 18 
 19 WSGIPythonHome /path/to/venv
 20 
 21 # WSGIPythonPath让你的项目包能够使用import导入到python path,也就是说import mysite能够运行
 22 
 23 WSGIPythonPath /path/to/mysite.com
 24 
 25  
 26 
 27 # 下面的代码保证apache能使用wsgi.py文件
 28 
 29 <Directory /path/to/mysite.com/mysite>
 30 
 31 <Files wsgi.py>
 32 
 33 Order deny,allow
 34 
 35 Allow from all
 36 
 37 #apache2.4版本的命令
 38 
 39 #Require all granted
 40 
 41 </Files>
 42 
 43 </Directory>
 44 
 45  
 46 
 47 #守护模式下的配置,其中不能使用WSGIPythonHome和WSGIPythonPath,而要使用python-home和python-path
 48 
 49 # 进程名字随意起
 50 
 51 WSGIDaemonProcess example.com python-home=/path/to/venv python-path=/path/to/mysite.com
 52 
 53 user=apache  group=apache
 54 
 55 WSGIProcessGroup example.com
 56 
 57  
 58 
 59 #由于django本身不会serve files,所以需要别的web server承担这个工作,可以选择其它没有运行django的服务器来承担
 60 
 61 #但是如果必须用同一台apache的话,可以将一些url设置成静态文件路径
 62 
 63 #例如
 64 
 65 # 相当于 www.xxx.com/robot.txt  -->/path/to/mysite.com/static/robots.txt
 66 
 67 Alias /robots.txt /path/to/mysite.com/static/robots.txt
 68 
 69 Alias /favicon.ico /path/to/mysite.com/static/favicon.ico
 70 
 71 Alias /media/ /path/to/mysite.com/media/
 72 
 73 Alias /static/ /path/to/mysite.com/static/
 74 
 75  
 76 
 77 <Directory /path/to/mysite.com/static>
 78 
 79 Require all granted
 80 
 81 </Directory>
 82 
 83  
 84 
 85 <Directory /path/to/mysite.com/media>
 86 
 87 Require all granted
 88 
 89 </Directory>
 90 
 91  
 92 
 93 <Directory /path/to/mysite.com/mysite>
 94 
 95 <Files wsgi.py>
 96 
 97 Require all granted
 98 
 99 </Files>
100 
101 </Directory>
102 
103  
104 
105 AddType text/html  .py
106 
107 WSGISocketPrefix /var/run/
108 
109  
110 
111 </IfModule>

  当然也可以将相关的配置写在虚拟主机的配置中。

  apache配置文件:虚拟主机的配置参数(略)

mod_wgsi配置过程中可能遇到的问题:

5xx服务器内部错误

这种问题可以通过检查apache的错误文件发现问题,错误文件/var/log/httpd/error.log中出现类似于 mod_wsgi (p/var/www/test0/test0/wsgi.py' cannot be loaded as Python module.

  问题很可能出在所安装的mod_wsgi扩展没有找到相应的链接库。

  解决方法:

    1.检查python编译安装要安装共享库

      ./configure --enabled-shared

      make && make install

    2.添加共享库到路径

      sudo vi /etc/ld.so.conf

      /usr/local/Python2.7/lib

      sudo /sbin/ldconfig -v

    3.使用编译安装mod_wsgi

      ./configure --with-apxs=/usr/local/apache/bin/apxs \

      --with-python=/usr/local/bin/python

报错:Permission denied: mod_wsgi (pautotester' on '/etc/httpd/logs/wsgi.2076.0.1.sock' after multiple attempts

  可在apache配置文件或者wsgi.conf中添加

  WSGISocketPrefix /var/run/

  来自 <https://my.oschina.net/crazyharry/blog/336811>

使用.configure --enable-shared 安装python2.7之后出现下面的报错:

  error while loading shared libraries: libpython2.7.so.1.0: cannot open shared object file: No such file or directory

  解决方法如下:

    来自 <http://blog.csdn.net/wanyanxgf/article/details/8021641>

    1.编辑 vi /etc/ld.so.conf

      如果是非root权限帐号登录,使用 sudo vi /etc/ld.so.conf

      添加上python2.7的lib库地址,如我的/usr/local/Python2.7/lib,保存文件

    2.执行 /sbin/ldconfig -v命令,如果是非root权限帐号登录,使用 sudo /sbin/ldconfig -v。这样 ldd 才能找到这个库,执行python2.7就不会报错了

      /etc/ld.so.conf:

      这个文件记录了编译时使用的动态链接库的路径。

      默认情况下,编译器只会使用/lib和/usr/lib这两个目录下的库文件

      如果你安装了某些库,没有指定 --prefix=/usr 这样lib库就装到了/usr/local下,而又没有在/etc/ld.so.conf中添加/usr/local/lib,就会报错了

    ldconfig是个什么东东吧 :

      它是一个程序,通常它位于/sbin下,是root用户使用的东东。具体作用及用法可以man ldconfig查到

      简单的说,它的作用就是将/etc/ld.so.conf列出的路径下的库文件 缓存到/etc/ld.so.cache 以供使用

      因此当安装完一些库文件,(例如刚安装好glib),或者修改ld.so.conf增加新的库路径后,需要运行一下/sbin/ldconfig

      使所有的库文件都被缓存到ld.so.cache中,如果没做,即使库文件明明就在/usr/lib下的,也是不会被使用的,结果编译过程中抱错,缺少xxx库。