Django+Uwsgi+Nginx如何实现生产环境部署


Posted in Python onJuly 31, 2020

如何在生产上部署Django?

Django的部署可以有很多方式,采用nginx+uwsgi的方式是其中比较常见的一种方式。

uwsgi介绍

uWSGI是一个Web服务器,它实现了WSGI协议、uwsgi、http等协议。Nginx中HttpUwsgiModule的作用是与uWSGI服务器进行交换。

要注意 WSGI / uwsgi / uWSGI 这三个概念的区分。

  • WSGI是一种Web服务器网关接口。它是一个Web服务器(如nginx,uWSGI等服务器)与web应用(如用Flask框架写的程序)通信的一种规范。
  • uwsgi是一种线路协议而不是通信协议,在此常用于在uWSGI服务器与其他网络服务器的数据通信。
  • 而uWSGI是实现了uwsgi和WSGI两种协议的Web服务器。
  • uwsgi协议是一个uWSGI服务器自有的协议,它用于定义传输信息的类型(type of information),每一个uwsgi packet前4byte为传输信息类型描述,它与WSGI相比是两样东西。

uwsgi性能非常高

Django+Uwsgi+Nginx如何实现生产环境部署

uWSGI的主要特点如下

  • 超快的性能
  • 低内存占用(实测为apache2的mod_wsgi的一半左右)
  • 多app管理(终于不用冥思苦想下个app用哪个端口比较好了-.-)
  • 详尽的日志功能(可以用来分析app性能和瓶颈)
  • 高度可定制(内存大小限制,服务一定次数后重启等)

总而言之uwgi是个部署用的好东东,正如uWSGI作者所吹嘘的:

If you are searching for a simple wsgi-only server, uWSGI is not for you, but if you are building a real (production-ready) app that need to be rock-solid, fast and easy to distribute/optimize for various load-average, you will pathetically and morbidly fall in love (we hope) with uWSGI.

Uwsgi 安装使用

# Install the latest stable release:
pip install uwsgi
# ... or if you want to install the latest LTS (long term support) release,
pip install https://projects.unbit.it/downloads/uwsgi-lts.tar.gz

基本测试

Create a file called test.py:

# test.py
def application(env, start_response):
  start_response('200 OK', [('Content-Type','text/html')])
  return [b"Hello World"] # python3
  #return ["Hello World"] # python2

运行

uwsgi --http :8000 --wsgi-file test.py

用uwsgi 启动django

uwsgi --http :8000 --module mysite.wsgi

可以把参数写到配置文件里

alex@alex-ubuntu:~/uwsgi-test$ more crazye-uwsgi.ini
 
 
[uwsgi]
http = :9000
#the local unix socket file than commnuincate to Nginx
socket = 127.0.0.1:8001
# the base directory (full path)
chdir = /home/alex/CrazyEye
# Django's wsgi file
wsgi-file = CrazyEye/wsgi.py
# maximum number of worker processes
processes = 4
#thread numbers startched in each worker process
threads = 2
 
#monitor uwsgi status
stats = 127.0.0.1:9191
# clear environment on exit
vacuum     = true

启动

/usr/local/bin/uwsgi crazye-uwsgi.ini

Nginx安装使用

sudo apt-get install nginx
sudo /etc/init.d/nginx start # start nginx

为你的项目生成Nginx配置文件

You will need the uwsgi_params file, which is available in the nginx directory of the uWSGI distribution, or from https://github.com/nginx/nginx/blob/master/conf/uwsgi_params

Copy it into your project directory. In a moment we will tell nginx to refer to it.

Now create a file called mysite_nginx.conf, and put this in it:

# mysite_nginx.conf
 
# the upstream component nginx needs to connect to
upstream django {
  # server unix:///path/to/your/mysite/mysite.sock; # for a file socket
  server 127.0.0.1:8001; # for a web port socket (we'll use this first)
}
 
# configuration of the server
server {
  # the port your site will be served on
  listen   8000;
  # the domain name it will serve for
  server_name .example.com; # substitute your machine's IP address or FQDN
  charset   utf-8;
 
  # max upload size
  client_max_body_size 75M;  # adjust to taste
 
  # Django media
  location /media {
    alias /path/to/your/mysite/media; # your Django project's media files - amend as required
  }
 
  location /static {
    alias /path/to/your/mysite/static; # your Django project's static files - amend as required
  }
 
  # Finally, send all non-media requests to the Django server.
  location / {
    uwsgi_pass django;
    include   /path/to/your/mysite/uwsgi_params; # the uwsgi_params file you installed
  }
}

This conf file tells nginx to serve up media and static files from the filesystem, as well as handle requests that require Django's intervention. For a large deployment it is considered good practice to let one server handle static/media files, and another handle Django applications, but for now, this will do just fine.

Symlink to this file from /etc/nginx/sites-enabled so nginx can see it:

sudo ln -s ~/path/to/your/mysite/mysite_nginx.conf /etc/nginx/sites-enabled/

Deploying static files

Before running nginx, you have to collect all Django static files in the static folder. First of all you have to edit mysite/settings.py adding:

STATIC_ROOT = os.path.join(BASE_DIR, "static/")

and then run

python manage.py collectstatic

此时启动Nginx 和Uwsgi,你的django项目就可以实现高并发啦!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python基础教程之lambda表达式使用方法
Feb 12 Python
python实现模拟按键,自动翻页看u17漫画
Mar 17 Python
浅谈Python浅拷贝、深拷贝及引用机制
Dec 15 Python
python爬虫_自动获取seebug的poc实例
Aug 05 Python
浅谈numpy数组的几种排序方式
Dec 15 Python
python中返回矩阵的行列方法
Apr 04 Python
opencv python 傅里叶变换的使用
Jul 21 Python
python写程序统计词频的方法
Jul 29 Python
python Event事件、进程池与线程池、协程解析
Oct 25 Python
django商品分类及商品数据建模实例详解
Jan 03 Python
python读取csv文件指定行的2种方法详解
Feb 13 Python
openCV提取图像中的矩形区域
Jul 21 Python
Python 如何测试文件是否存在
Jul 31 #Python
Python高并发解决方案实现过程详解
Jul 31 #Python
Python如何执行精确的浮点数运算
Jul 31 #Python
Python使用shutil模块实现文件拷贝
Jul 31 #Python
Python基于pyjnius库实现访问java类
Jul 31 #Python
Python如何将字符串转换为日期
Jul 31 #Python
Python在字符串中处理html和xml的方法
Jul 31 #Python
You might like
php中将字符串转为HTML的实体引用的一个类
2013/02/03 PHP
PHP发送AT指令实例代码
2016/05/26 PHP
thinkPHP5使用Rabc实现权限管理
2019/08/28 PHP
让你的PHP,APACHE,NGINX支持大文件上传
2021/03/09 PHP
formStorage 基于jquery的一个插件(存储表单中元素的状态到本地)
2012/01/20 Javascript
javascript编码的几个方法详细介绍
2013/01/06 Javascript
jQuery中:selected选择器用法实例
2015/01/04 Javascript
jQuery实现带滚动导航效果的全屏滚动相册实例
2015/06/19 Javascript
JavaScript的类型、值和变量小结
2015/07/09 Javascript
jquery实现表格隔行换色效果
2015/11/19 Javascript
总结jQuery插件开发中的一些要点
2016/05/16 Javascript
javascript insertAfter()定义与用法示例
2016/07/25 Javascript
mui back 返回刷新页面的实例
2017/12/06 Javascript
javascript异常处理实现原理详解
2020/02/17 Javascript
在nuxt中使用路由重定向的实例
2020/11/06 Javascript
vue编写简单的购物车功能
2021/01/08 Vue.js
jQuery实现穿梭框效果
2021/01/19 jQuery
Python中的闭包总结
2014/09/18 Python
Python中使用MELIAE分析程序内存占用实例
2015/02/18 Python
利用python解决mysql视图导入导出依赖的问题
2017/12/17 Python
ubuntu中配置pyqt4环境教程
2017/12/27 Python
Python使用selenium实现网页用户名 密码 验证码自动登录功能
2018/05/16 Python
使用Python AIML搭建聊天机器人的方法示例
2018/07/09 Python
在python3中pyqt5和mayavi不兼容问题的解决方法
2019/01/08 Python
Python统计学一数据的概括性度量详解
2020/03/03 Python
python正则表达式 匹配反斜杠的操作方法
2020/08/07 Python
CSS3 flex布局之快速实现BorderLayout布局
2015/12/03 HTML / CSS
Bealls Florida百货商店:生活服饰、家居装饰和鞋子
2018/02/23 全球购物
英国婴儿及儿童产品商店:TigerParrot
2019/03/04 全球购物
消防安全检查制度
2014/02/04 职场文书
烹饪大赛策划方案
2014/05/26 职场文书
护林防火标语
2014/06/27 职场文书
2015年党员承诺书
2015/01/21 职场文书
红领巾广播站广播稿
2015/08/19 职场文书
Css预编语言及区别详解
2021/04/25 HTML / CSS
JavaScript中时间格式化新思路toLocaleString()
2021/11/07 Javascript