在Debian下配置Python+Django+Nginx+uWSGI+MySQL的教程


Posted in Python onApril 25, 2015

最近尝试把项目迁移到Python环境下,特别新装了一台干净的Debian系统,准备重新配置环境,上网找了一些运行Python Web的环境方案,最后敲定Nginx+uWSGI组合,Nginx用得比较多,熟练些;uWSGI据说性能不错,想尝试一下。

网上大部分教程都是要求到uWSGI官方网站下载源码包,然后通过编译的方式安装,比如对于一台新Debian系统,可以通过下面的命令安装:

apt-get update
apt-get upgrade
apt-get install build-essential psmisc
apt-get install python-dev libxml2 libxml2-dev
apt-get install python-setuptools
cd /opt/
wget http://projects.unbit.it/downloads/uwsgi-latest.tar.gz
tar -zxvf uwsgi-latest.tar.gz
mv uwsgi-latest/ uwsgi/
cd uwsgi/
python setup.py install

还有一些配置我就不介绍了,大家可以参考Linode Library的《Deploy Python Code with WSGI using uWSGI and nginx on Debian 6 (Squeeze)》介绍。

今天要介绍的是利用APT源直接apt-get install安装配置我们所需要的环境,首先按惯例先安装MySQL和Nginx:

然后通过Debian Packages网站找到我们所需要的uWSGI在sid里,sid版里的东西表示仍在开发测试中,不是最终稳定版,不过对于我们测试来说是够用了,为了用sid里面的软件包,我们还需要修改我们的/etc/apt/sources.list源,添加deb http://ftp.tw.debian.org/debian sid main non-free contrib这一行,或者直接输入命令:

echo "deb http://ftp.tw.debian.org/debian sid main non-free contrib" >> /etc/apt/sources.list

配置过源列表后,我们就可以通过下面的命令安装了:

apt-get update
apt-get install uwsgi uwsgi-core uwsgi-plugin-python

安装完成后,配置文件按惯例放在了/etc/uwsgi里面,服务控制可以通过invoke-rc.d uwsgi后面跟命令参数来实现,不过这里有个小插曲我不得不提一下,安装时可能会报这样的错误:

The following packages have unmet dependencies: 
libc6-dev : Breaks: gcc-4.4 (< 4.4.6-4) but 4.4.5-8 is to be installed. 
E: Broken packages

看样子是依赖包gcc版本不匹配,我后来通过下面的方式解决了:

apt-get update
apt-get upgrade # 先尝试升级系统软件包
 
apt-get install libc6-dev

接下来就是安装django以及Python的MySQL支持,继续APT命令:

apt-get install python-django python-mysqldb

通过上面的步骤,Python环境应该安装到你的系统里了,切换到/usr/lib:

cd /usr/lib
ls -l | grep python

你可能会发现系统内被默认安装了几个版本的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 "from distutils.sysconfig import get_python_lib; print get_python_lib()"

上面的命令会在控制台上打印Python包路径,比如这里我们可能获得dist-packages这个目录,切换到这个目录你就会发现django在那儿啦。给django-admin.py加上权限,再做个符号连接,便于我们以后操作(我这里Django在Python2.7下):

chmod 777 /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 --config uwsgi-plugin-python

好啦,到这里基本上安装部分就介绍完了,下面讲解配置部分,首先建立我们项目的文件夹,比如说放在/home/user/www下,然后通过下面的命令创建名为mysite的Django项目:

cd /home/user/www
django-admin.py startproject mysite

好了,这下/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.d uwsgi restart

注意上面的socket配置,这个在我机子上是这个路径,大家可以cd /var/run里面找下,然后配置正确,接下来建立Nginx配置文件:

cat > /etc/nginx/sites-enabled/www << EOF
server {
    listen  80;
    server_name localhost;
    location / {
        include uwsgi_params;
        uwsgi_pass unix:///var/run/uwsgi/app/www/socket;
    }
}
EOF

这里的uwsgi_pass依旧是上面我们找到的socket,注意一下server_name,这个是我们绑定的域名,通过nginx -s reload重新加载nginx。

好了,现在可以访问看看是不是成功了?如果出现502 Bad Gateway,可以检查一下uwsgi是否正常启动,通过ps aux | grep uwsgi看下进程列表,最后在检查下socket路径是否正确。

假如出现uWSGI Error:Python application not found这个问题,主要是路径配置问题,这点你可以查阅/var/log/uwsgi下面的日志文件,比如我就遇到过ImportError: No module named django.core.handlers.wsgi这个问题,实际上是wsgi.py里面路径配置不正确。

Python 相关文章推荐
Python异常处理总结
Aug 15 Python
Python实现把回车符\r\n转换成\n
Apr 23 Python
HTML中使用python屏蔽一些基本功能的方法
Jul 07 Python
python安装模块如何通过setup.py安装(超简单)
May 05 Python
python:print格式化输出到文件的实例
May 14 Python
有关Python的22个编程技巧
Aug 29 Python
详解python中TCP协议中的粘包问题
Mar 22 Python
详解python3 + Scrapy爬虫学习之创建项目
Apr 12 Python
详解python3安装pillow后报错没有pillow模块以及没有PIL模块问题解决
Apr 17 Python
python中os包的用法
Jun 01 Python
详解Python3 定义一个跨越多行的字符串的多种方法
Sep 06 Python
Python代码风格与编程习惯重要吗?
Jun 03 Python
使用PDB简单调试Python程序简明指南
Apr 25 #Python
Python脚本判断 Linux 是否运行在虚拟机上
Apr 25 #Python
在Python中使用cookielib和urllib2配合PyQuery抓取网页信息
Apr 25 #Python
使用Python的Tornado框架实现一个一对一聊天的程序
Apr 25 #Python
使用Python发送邮件附件以定时备份MySQL的教程
Apr 25 #Python
安装Python的web.py框架并从hello world开始编程
Apr 25 #Python
用Python编写一个基于终端的实现翻译的脚本
Apr 24 #Python
You might like
PHP生成制作验证码的简单实例
2016/06/12 PHP
php利用云片网实现短信验证码功能的示例代码
2017/11/18 PHP
基于php解决json_encode中文UNICODE转码问题
2020/11/10 PHP
javascript入门·图片对象(无刷新变换图片)\滚动图像
2007/10/01 Javascript
js有序数组的连接问题
2013/10/01 Javascript
调用HttpHanlder的几种返回方式小结
2013/12/20 Javascript
对table和ul实现js分页示例分享
2014/02/24 Javascript
Seajs的学习笔记
2014/03/04 Javascript
jQuery Ajax调用WCF服务详细教程
2015/03/31 Javascript
JavaScript模拟深蓝vs卡斯帕罗夫的国际象棋对局示例
2015/04/22 Javascript
JS实现可关闭的对联广告效果代码
2015/09/14 Javascript
基于jQuery实现数字滚动效果
2017/01/16 Javascript
jQuery实现复制到粘贴板功能
2017/02/11 Javascript
Vue.js基础学习之class与样式绑定
2017/03/20 Javascript
zTree树形插件异步加载方法详解
2017/06/14 Javascript
JS检测是否可以访问公网服务器功能代码
2017/06/19 Javascript
vue-cli构建项目下使用微信分享功能
2018/05/28 Javascript
Canvas实现微信红包照片效果
2018/08/21 Javascript
[01:44]《为梦想出发》—联想杯DOTA2完美世界全国高校联赛
2015/09/30 DOTA
Python聊天室实例程序分享
2016/01/05 Python
简单了解Python matplotlib线的属性
2019/06/29 Python
解决TensorFlow训练内存不断增长,进程被杀死问题
2020/02/05 Python
Python中断多重循环的几种方式详解
2020/02/10 Python
基于Keras中Conv1D和Conv2D的区别说明
2020/06/19 Python
Python中使用aiohttp模拟服务器出现错误问题及解决方法
2020/10/31 Python
python实现图像高斯金字塔的示例代码
2020/12/11 Python
python实现发送邮件
2021/03/02 Python
教师岗位职责
2013/11/17 职场文书
转党组织关系介绍信
2014/01/08 职场文书
母亲节感恩寄语
2014/02/21 职场文书
学生安全责任书范本
2014/07/24 职场文书
煤矿隐患排查制度
2015/08/05 职场文书
MySQL 常见的数据表设计误区汇总
2021/06/07 MySQL
redis cluster支持pipeline的实现思路
2021/06/23 Redis
mysql数据插入覆盖和时间戳的问题及解决
2022/03/25 MySQL
Java设计模式之代理模式
2022/04/22 Java/Android