nginx+uWSGI

ubuntu下先安装下C编译器和Python环境:

sudo apt-get install build-essential python-dev

使用pip安装uWSGI:

pip install uwsgi

nginx配置:

可以单独为站点设置一个配置文件:

sudo vim /etc/nginx/sites-enabled/mysite

或者直接在nginx.conf中设置:

sudo vim /etc/nginx/nginx.conf

设置:

server {
listen 80; ## listen for ipv4; this line is default and implied
#listen [::]:80 default ipv6only=on; ## listen for ipv6 server_name 站点域名;
location / {
uwsgi_pass 127.0.0.1:8080;
include uwsgi_params;
}
#设置该网站应用中所需要的静态文件的根目录,需要将admin和用到的第三方库像restframework的静态文件都放到此目录中
location ~/static/ {
root /home/user/mysite/; #项目地址
# root html;
# index index.html index.htm;
break;
}
#设置媒体文件的根目录
location ~/media/ {
root /home/user/mysite/;
# root html;
# index index.html index.htm;
break;
}
}

自己电脑上搭建localhost服务器时,注意别被/etc/nginx/sites-enabled/default中的配置覆盖掉了,最好将其注释掉。

然后设置uWSGI,建立文件myfile.ini:

[uwsgi]
socket = 127.0.0.1:8080 #与nginx配置中的uwsgi_pass相同
chdir = /home/user/mysite/ #项目地址
wsgi-file = mysite/wsgi.py
processes = 4
threads = 2
pidfile=/tmp/project-master.pid
stats = 127.0.0.1:9191
virtualenv = <path to env> #virtualenv

其中wsgi-file是django(1.4版本以上)项目自动建立的文件,里面内容为:

import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "weixian.settings") from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()

如果django版本过低无此文件的话,可以自己建立,或者在myfile.ini中设置env,module,pythonpath:

[uwsgi]
socket = 127.0.0.1:8080
chdir = /home/user/mysite/
pythonpath = ..
env = DJANGO_SETTINGS_MODULE=mysite.settings
module = django.core.handlers.wsgi:WSGIHandler()
processes = 4
threads = 2
stats = 127.0.0.1:9191
virtualenv = <path to env>

按配置重启nginx:

/usr/sbin/nginx -s reload

或者:

killall -9 nginx
nginx -c /etc/nginx/nginx.conf

启动uWSGI:

uwsgi myfile.ini

重启uWSGI:

# using kill to send the signal
kill -HUP `cat /tmp/project-master.pid`
# or the convenience option --reload
uwsgi --reload /tmp/project-master.pid
# or if uwsgi was started with touch-reload=/tmp/somefile
touch /tmp/somefile

ini文件也可以用xml文件来设置。

添加xml支持:

sudo apt-get install libxml2-dev

配置myfile.xml

<uwsgi>
<socket>127.0.0.1:8080</socket>
<chdir>/home/user/mysite/</chdir>
<module>mysite/wsgi</module>
</uwsgi>

启动:

uwsgi -x myfile.xml

nginx+fastcgi

fastcgi需要安装flup:

wget http://www.saddi.com/software/flup/dist/flup-1.0.2.tar.gz
tar zxvf flup-1.0.2.tar.gz
cd flup-1.0.2
python setup.py install

或者:

sudo apt-get install  python-flup

nginx配置:

server {
listen 80;
server_name localhost; #设置该网站应用中所需要的静态文件的根目录
location ~/static/ {
root /home/user/mysite/;
# root html;
# index index.html index.htm;
break;
}
#设置媒体的根目录
location ~/media/ {
root /home/user/mysite/;
# root html;
# index index.html index.htm;
break;
}
#host and port to fastcgi server
location / {
fastcgi_pass 127.0.0.1:8080;
fastcgi_param PATH_INFO $fastcgi_script_name;
fastcgi_param REQUEST_METHOD $request_method;
fastcgi_param QUERY_STRING $query_string;
fastcgi_param CONTENT_TYPE $content_type;
fastcgi_param CONTENT_LENGTH $content_length;
fastcgi_param pass_header Authorization;
fastcgi_intercept_errors off;
}
#设置浏览器缓存这些图片格式文件浏览器缓存时间是30天,css/js缓存时间1小时
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
expires 30d;
} location ~ .*\.(js|css)?$
{
expires 1h;
}
}

重启nginx,然后启动fcgi:

python manage.py runfcgi host=127.0.0.1 port=8080 method=prefork --settings=mysite.settings  #采用静态进程池的话性能会比动态线程生成高2倍左右

ok。

要更新django项目的话,

ps -ef |grep fcgi

找出主进程号kill掉,再重启fcgi即可。

也可以写个重启脚本。使用pidfile选项将fcgi的pid存储到文件中,重启时读取kill掉。

#!/bin/bash

PROJDIR="/home/user/myproject"
PIDFILE="$PROJDIR/mysite.pid" cd $PROJDIR
if [ -f $PIDFILE ]; then
kill `cat -- $PIDFILE`
rm -f -- $PIDFILE
fi exec python manage.py runfcgi host=127.0.0.1 port=8080 method=prefork pidfile=$PIDFILE --settings=mysite.settings

  

Nginx+uWSGI或fastcgi部署Django项目的更多相关文章

  1. Ubuntu Nginx Uwsgi Python布置服务器Django项目

     1 安装python 3.6 ubuntu预装了2.7,不需要卸载预装库,直接安装python3.6(其实现在的阿里云18.04会给你自动装python2.7.15和3.6.8) 你可以分别查看一下 ...

  2. 基于Nginx和uWSGI在Ubuntu上部署Django项目

    前言: 对于做Django web项目的童鞋,重要性不言而喻. 参考:https://www.cnblogs.com/alwaysInMe/p/9096565.html https://blog.cs ...

  3. 使用uWSGI+nginx部署Django项目

    最近使用django写了一些项目,不过部署到服务器上碰到一些问题,还有静态文件什么的一堆问题,这里总结一下碰到的问题和解决方案,总体思路是按照官方文档走的. 原文地址:http://uwsgi-doc ...

  4. docker 部署django项目(nginx + uwsgi +mysql)

    最近在学习用docker部署Django项目,经过百折不挠的鼓捣,终于将项目部署成功,爬过好多坑,也发现很多技能需要提高.特此写下随笔与小伙伴们分享,希望能对大家有所启发. docker的理论我就不赘 ...

  5. 使用Nginx+uWSGI部署Django项目

    1.linux安装python3环境 参考链接:https://www.cnblogs.com/zzqit/p/10087680.html 2.安装uwsgi pip3 install uwsgi l ...

  6. ubuntu18+uwsgi+nginx部署django项目

    更新系统软件源 sudo apt-get update pip3安装 sudo apt install python3-pip 安装virtualenvwrapper pip3 install vir ...

  7. nginx + uwsgi 部署django项目

    因项目需求,需要部署django项目,这里是基础的nginx配合uwsgi部署django,后续会采用docker部署的方式 环境: centos7 python3.5.4 django2.1.4 u ...

  8. nginx+uwsgi部署Django项目到Ubuntu服务器全过程,以及那些坑!!!

    前言:自己在windows上用PyCharm编写的Django项目,编写完后在windows上运行一点问题都没有,但是部署到服务器上时却Bug百出.百度,CSDN,sf,各种搜索寻求解决方案在历时3天 ...

  9. linux上使用nginx、uwsgi部署django项目

    参考:CentOS7下部署Django项目详细操作步骤 注意事项: 在虚拟环境中操作,虚拟环境中安装nginx.uwsgi,虚拟环境外需安装uwsgi -- 临时关闭防火墙:systemctl sto ...

随机推荐

  1. GDI+

    1, 编译error的话一般是却 #include <comdef.h>#include <Windows.h> Windows.h内会包含Windows.h,但是因为在std ...

  2. VC6配置OpenCV1.0

    懒得写字,故扫描:

  3. 第六章 Qt布局管理器Layout

    第六章 Qt布局管理器Layout 大家有没有发现一个现象,我们放置一个组件,给组件最原始的定位是给出这个控件的坐标和宽高值,这样Qt就知道这个组件的位置.当用户改变窗口的大小,组件还静静地呆在原来的 ...

  4. Kakfa揭秘 Day7 Producer源码解密

    Kakfa揭秘 Day7 Producer源码解密 今天我们来研究下Producer.Producer的主要作用就是向Kafka的brokers发送数据.从思考角度,为了简化思考过程,可以简化为一个单 ...

  5. 【转】#ifdef __cplusplus深度剖析

    原文:http://bbs.ednchina.com/BLOG_ARTICLE_251752.HTM 时常在cpp的代码之中看到这样的代码:     #ifdef __cplusplus extern ...

  6. hdu 3518 Boring counting 后缀数组LCP

    题目链接 题意:给定长度为n(n <= 1000)的只含小写字母的字符串,问字符串子串不重叠出现最少两次的不同子串个数; input: aaaa ababcabb aaaaaa # output ...

  7. MySQL的alter的使用

    ALTER TABLE 语句用于在已有的表中添加.修改或删除列 1.ADD [COLUMN] column name (column definitions) [FIRST or AFTER colu ...

  8. iOS通过http post上传图片 (转)

    转载自:http://www.cocoachina.com/bbs/read.php?tid=89985 由于iOS无法通过html表单来上传图片,因此想要上传图片,必须实现http请求,而不能像其他 ...

  9. C++ 字符串各种处理

    要想使用标准C++中string类,必须要包含 #include <string>// 注意是<string>,不是<string.h>,带.h的是C语言中的头文件 ...

  10. javascript高级编程笔记04(基本概念)

    Function类型 Es5中规范了另一个函数对象的属性:caller,这个属性中保存着调用当前函数的函数的引用,如果是在全局作用域中调用当前函数,这它的值为null function outer() ...