在Debian下配置Python+Django+Nginx+uWSGI+MySQL的教程
最近尝试把项目迁移到Python环境下,特别新装了一台干净的Debian系统,准备重新配置环境,上网找了一些运行PythonWeb的环境方案,最后敲定Nginx+uWSGI组合,Nginx用得比较多,熟练些;uWSGI据说性能不错,想尝试一下。
网上大部分教程都是要求到uWSGI官方网站下载源码包,然后通过编译的方式安装,比如对于一台新Debian系统,可以通过下面的命令安装:
apt-getupdate apt-getupgrade apt-getinstallbuild-essentialpsmisc apt-getinstallpython-devlibxml2libxml2-dev apt-getinstallpython-setuptools cd/opt/ wgethttp://projects.unbit.it/downloads/uwsgi-latest.tar.gz tar-zxvfuwsgi-latest.tar.gz mvuwsgi-latest/uwsgi/ cduwsgi/ pythonsetup.pyinstall
还有一些配置我就不介绍了,大家可以参考LinodeLibrary的《DeployPythonCodewithWSGIusinguWSGIandnginxonDebian6(Squeeze)》介绍。
今天要介绍的是利用APT源直接apt-getinstall安装配置我们所需要的环境,首先按惯例先安装MySQL和Nginx:
然后通过DebianPackages网站找到我们所需要的uWSGI在sid里,sid版里的东西表示仍在开发测试中,不是最终稳定版,不过对于我们测试来说是够用了,为了用sid里面的软件包,我们还需要修改我们的/etc/apt/sources.list源,添加debhttp://ftp.tw.debian.org/debiansidmainnon-freecontrib这一行,或者直接输入命令:
echo"debhttp://ftp.tw.debian.org/debiansidmainnon-freecontrib">>/etc/apt/sources.list
配置过源列表后,我们就可以通过下面的命令安装了:
apt-getupdate apt-getinstalluwsgiuwsgi-coreuwsgi-plugin-python
安装完成后,配置文件按惯例放在了/etc/uwsgi里面,服务控制可以通过invoke-rc.duwsgi后面跟命令参数来实现,不过这里有个小插曲我不得不提一下,安装时可能会报这样的错误:
Thefollowingpackageshaveunmetdependencies: libc6-dev:Breaks:gcc-4.4(<4.4.6-4)but4.4.5-8istobeinstalled. E:Brokenpackages
看样子是依赖包gcc版本不匹配,我后来通过下面的方式解决了:
apt-getupdate apt-getupgrade#先尝试升级系统软件包 apt-getinstalllibc6-dev
接下来就是安装django以及Python的MySQL支持,继续APT命令:
apt-getinstallpython-djangopython-mysqldb
通过上面的步骤,Python环境应该安装到你的系统里了,切换到/usr/lib:
cd/usr/lib ls-l|greppython
你可能会发现系统内被默认安装了几个版本的Python,比如我这里就安装有3个版本:
/usr/lib/python2.6 /usr/lib/python2.7 /usr/lib/python3
如何确定当前的Python默认版本呢?很容易,直接通过下面的命令就可以了:
python--version
大家知道django是安装到python目录下的site-packages下的,但是这几个python目录下都没有site-packages这个文件夹,其实我们可以先通过下面的命令定位一下:
python-c"fromdistutils.sysconfigimportget_python_lib;printget_python_lib()"
上面的命令会在控制台上打印Python包路径,比如这里我们可能获得dist-packages这个目录,切换到这个目录你就会发现django在那儿啦。给django-admin.py加上权限,再做个符号连接,便于我们以后操作(我这里Django在Python2.7下):
chmod777/usr/lib/python2.7/dist-packages/django/bin/django-admin.py ln-s/usr/lib/python2.7/dist-packages/django/bin/django-admin.py/usr/local/bin
记下Django所在的Python版本,然后通过下面的命令切换uwsgi的默认Python版本(一般不需要切换):
update-alternatives--configuwsgi-plugin-python
好啦,到这里基本上安装部分就介绍完了,下面讲解配置部分,首先建立我们项目的文件夹,比如说放在/home/user/www下,然后通过下面的命令创建名为mysite的Django项目:
cd/home/user/www django-admin.pystartprojectmysite
好了,这下/home/user/www目录下应该有个子文件夹名字叫mysite,我们需要丢个wsgi的配置文件到/home/user/www/mysite/里面去,配置文件命名为wsgi.py,内容如下:
接下来是修改uwsgi配置文件,先通过如下命令按照刚才的设置建立个配置文件:
cat>/etc/uwsgi/apps-enabled/www.ini<<EOF [uwsgi] socket=/var/run/uwsgi/app/www/socket chmod-socket=666 limit-as=256 processes=6 max-request=2000 memory-report=true enable-threads=true pythonpath=/home/user/www chdir=/home/user/www/mysite wsgi-file=/home/user/www/mysite/wsgi.py EOF #重启uwsgi invoke-rc.duwsgirestart
注意上面的socket配置,这个在我机子上是这个路径,大家可以cd/var/run里面找下,然后配置正确,接下来建立Nginx配置文件:
cat>/etc/nginx/sites-enabled/www<<EOF server{ listen80; server_namelocalhost; location/{ includeuwsgi_params; uwsgi_passunix:///var/run/uwsgi/app/www/socket; } } EOF
这里的uwsgi_pass依旧是上面我们找到的socket,注意一下server_name,这个是我们绑定的域名,通过nginx-sreload重新加载nginx。
好了,现在可以访问看看是不是成功了?如果出现502BadGateway,可以检查一下uwsgi是否正常启动,通过psaux|grepuwsgi看下进程列表,最后在检查下socket路径是否正确。
假如出现uWSGIError:Pythonapplicationnotfound这个问题,主要是路径配置问题,这点你可以查阅/var/log/uwsgi下面的日志文件,比如我就遇到过ImportError:Nomodulenameddjango.core.handlers.wsgi这个问题,实际上是wsgi.py里面路径配置不正确。