1.linux安装python3环境

参考链接:https://www.cnblogs.com/zzqit/p/10087680.html

2.安装uwsgi

pip3 install uwsgi

ln -s /usr/local/python3/bin/uwsgi /usr/local/bin/uwsgi  #建立软链接

uwsgi --version  #检查安装成功

3.基于uwsgi+django项目部署

django项目目录结构(orange_manage为app):

uwsgi --http 172.16.0.4:8001/ --file orange_web/wsgi.py --static-map=/static=static  //使用uwsgi启动Django项目

uwsgi参数详解:

--http   这个就和runserver一样指定IP 端口
--file   这个文件就里有一个反射,如果你在调用他的时候没有指定Web Server就使用默认的
-- static   做一个映射,指定静态文件

这里就可以使用uwsgi启动Django项目了

4.基于uwsgi的配置文件启动Django项目

1.新建一个目录script,存放uwsgi的启动文件,后续生成的日志以及进程号等

mkdir -p /var/www/script

2.在script目录下新建启动文件uwsgi.ini,并编辑配置

 vi uwsgi.ini          // 新建uwsgi.ini文件

 # uwsgi使用配置文件启动,配置如下

 [uwsgi]
#项目目录
chdir=/var/www/orange_web/
#指定项目application
module=orange_web.wsgi:application
#指定sock的文件路径(nginx使用)
socket=/var/www/script/uwsgi.sock
# 进程个数(processess一样效果)
workers=2
#指定启动时的pid文件路径
pidfile=/var/www/script/uwsgi.pid
#指定ip及端口(配置nginx就不需要单独启动uwsgi需要填写)
#http=172.16.0.4:8001
#指定静态文件(配置nginx不需要,单独启动uwsgi加载静态文件)
#static-map=/static=/var/www/orange_web/static
#启动uwsgi的用户名和用户组
uid=root
gid=root
#启用主进程
master=true
# 启用线程
enable-threads=true
#自动移除unix Socket和pid文件当服务停止的时候
vacuum=true
#设置日志目录
daemonize=/var/www/script/uwsgi.log
#不记录信息日志,只记录错误以及uwsgi内部消息
disable-logging=true
# 序列化接受的内容,如果可能的话
thunder-lock=true

uwsgi常用配置:

 master = true
#启动主进程,来管理其他进程,其它的uwsgi进程都是这个master进程的子进程,如果kill这个master进程,相当于重启所有的uwsgi进程。 chdir = /web/www/mysite
#在app加载前切换到当前目录, 指定运行目录 module = mysite.wsgi
# 加载一个WSGI模块,这里加载mysite/wsgi.py这个模块 py-autoreload=1
#监控python模块mtime来触发重载 (只在开发时使用) lazy-apps=true
#在每个worker而不是master中加载应用 socket = /test/myapp.sock
#指定socket文件,也可以指定为127.0.0.1:9000,这样就会监听到网络套接字 processes = 2 #启动2个工作进程,生成指定数目的worker/进程 buffer-size = 32768
#设置用于uwsgi包解析的内部缓存区大小为64k。默认是4k。 daemonize = /var/log/myapp_uwsgi.log
# 使进程在后台运行,并将日志打到指定的日志文件或者udp服务器 log-maxsize = 5000000 #设置最大日志文件大小 disable-logging = true #禁用请求日志记录 vacuum = true #当服务器退出的时候自动删除unix socket文件和pid文件。 listen = 120 #设置socket的监听队列大小(默认:100) pidfile = /var/run/uwsgi.pid #指定pid文件 enable-threads = true
#允许用内嵌的语言启动线程。这将允许你在app程序中产生一个子线程 reload-mercy = 8
#设置在平滑的重启(直到接收到的请求处理完才重启)一个工作子进程中,等待这个工作结束的最长秒数。这个配置会使在平滑地重启工作子进程中,如果工作进程结束时间超过了8秒就会被强行结束(忽略之前已经接收到的请求而直接结束) max-requests = 5000
#为每个工作进程设置请求数的上限。当一个工作进程处理的请求数达到这个值,那么该工作进程就会被回收重用(重启)。你可以使用这个选项来默默地对抗内存泄漏 limit-as = 256
#通过使用POSIX/UNIX的setrlimit()函数来限制每个uWSGI进程的虚拟内存使用数。这个配置会限制uWSGI的进程占用虚拟内存不超过256M。如果虚拟内存已经达到256M,并继续申请虚拟内存则会使程序报内存错误,本次的http请求将返回500错误。 harakiri = 60
#一个请求花费的时间超过了这个harakiri超时时间,那么这个请求都会被丢弃,并且当前处理这个请求的工作进程会被回收再利用(即重启)

通过uwsgi.ini启动项目

uwsgi --ini /var/www/script/uwsgi.ini        //后面为uwsgi.ini文件路径,因为设置了uwsgi软连接,可以不用写uwsgi启动路径

uwsgi辅助命令

lsof -i :8001    //按照端口号查询

ps aux | grep uwsgi   //按照程序名查询

kill -9 13844 13852      //杀死进程13844跟13852

uwsgi --stop /var/www/script/uwsgi.pid      //通过uwsg停止uwsgi

走到这里,uwsgi+Django部署就已经完美结合了。uwsgi处理动态请求能力高,但是对于静态请求(静态文件)处理能力就不是很好,就需要结合nginx使用。

5.安装Nginx及需要的包

sudo yum install epel-release

sudo yum install python-devel nginx

nginx常用命令:

service nginx start        //启动nginx服务

service nginx stop        //关闭nginx服务

service nginx restart     //重启nginx服务

service nginx status     //查看nginx服务状态

6.配置Nginx

1.进入nginx的默认目录

cd /etc/nginx/conf.d    //进入nginx默认目录

2.创建Django项目的对应配置文件并配置

 server {
listen 80; # 我要监听那个端口
server_name www.cnblogs.com/zzqit; # 你访问的路径前面的url名称ip地址也可以
pid /var/run/nginx.pid; #进程文件
error_log /var/log/nginx/error.log; #错误日志定义等级,[ debug | info | notice | warn | error | crit ]
access_log /var/log/nginx/access.log main; # Nginx日志配置
charset utf-8; # Nginx编码
gzip_types text/plain application/x-javascript text/css text/javascript application/x-httpd-php application/json text/json image/jpeg image/gif image/png application/octet-stream; # 支持压缩的类型 # 指定项目路径uwsgi
location / { # 这个location就和咱们Django的url(r'^admin/', admin.site.urls),
include uwsgi_params; # 导入一个Nginx模块他是用来和uWSGI进行通讯的
uwsgi_connect_timeout 30; # 设置连接uWSGI超时时间
uwsgi_pass unix:///var/www/script/uwsgi.sock; # 指定uwsgi的sock文件所有动态请求就会直接丢给他
} # 指定静态文件路径
location /static/ {
alias /var/www/orange_web/static/;
}
}

3.配置nginx完成,重启nginx服务

service nginx restart    //重启nginx服务

service nginx reload    //如果是生产环境,影响最小

到这里全部就配置完成,啦啦啦,美滋滋。

7.项目部署可能遇到的问题

Nginx是什么       https://www.cnblogs.com/zzqit/p/10172307.html

Nginx详细配置说明     https://www.cnblogs.com/zzqit/p/11497169.html

静态文件加载失败     https://www.cnblogs.com/zzqit/p/10127070.html

uwsgi ini 配置文件     https://uwsgi-docs.readthedocs.io/en/latest/tutorials/Django_and_nginx.html#configuring-uwsgi-to-run-with-a-ini-file

官方gunicorn部署教程    https://docs.djangoproject.com/en/dev/howto/deployment/wsgi/gunicorn/

官方uwsgi部署教程       https://docs.djangoproject.com/en/dev/howto/deployment/wsgi/uwsgi/    

使用Nginx+uWSGI部署Django项目的更多相关文章

  1. nginx + uwsgi 部署django项目

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

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

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

  3. nginx+uwsgi部署django项目

    1.django项目部署前需要生成admin的静态资源文件 (1)生成admin的静态资源文件 # 关闭debug模型 DEBUG = False # 允许所有域名访问 ALLOWED_HOSTS = ...

  4. Nginx + uWSGI 部署Django 项目,并实现负载均衡

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

  5. CENTOS7 使用 Nginx + Uwsgi 部署 Django 项目

    写在前面的话 最近总是见到有新学 Django 的朋友在部署自己的项目到 Linux 上面的时候运行不起来,所以就动手写了这篇博客. 对于不会搭建 Python 3 环境的朋友可以参考前面的博客[CE ...

  6. Python3.6+nginx+uwsgi部署Django程序到阿里云Ubuntu16.04系统

    Python3.6+nginx+uwsgi部署Django程序到阿里云Ubuntu16.04系统 这个是写好的Django程序在本地机运行的情况,一个查询接口. 准备工作 1.首先购买一台阿里云的EC ...

  7. nginx + uwsgi 部署 Django+Vue项目

    nginx + uwsgi 部署 Django+Vue项目 windows 本地 DNS 解析 文件路径 C:\Windows\System32\drivers\etc 单机本地测试运行方式,调用dj ...

  8. 填坑!!!virtualenv 中 nginx + uwsgi 部署 django

    一.为什么会有这篇文章 第一次接触 uwsgi 和 nginx ,这个环境搭建,踩了太多坑,现在记录下来,让后来者少走弯路. 本来在 Ubuntu14.04 上 搭建好了环境,然后到 centos7. ...

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

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

随机推荐

  1. BZOJ4544 椭圆上的整点(数论)

    https://www.cnblogs.com/Gloid/p/9538413.html 基本思路没有太大差别.得到2n=d(a2+3b2),其中d=gcd(n-x,n+x),n-x==a2& ...

  2. ShareSDK入门指南:Android 10分钟快速集成

    ShareSDK 官方已提供Android 快速集成教程,以官方教程为参考,本文重点指导大家在集成中遇到的问题. Android 快速集成官方教程:http://wiki.mob.com/Androi ...

  3. koala 编译scss不支持中文解决方案

    方法一: 在scss文件第一行加上代码:@charset "utf-8"; 方法二: 进入到Koala 安装目录 C:\Koala\rubygems\gems\sass-3.4.9 ...

  4. css和javascript中图片路径的不同

    之前在写前端代码时,在图片路径的设置那里经常会遇到一个问题.比方说,我 (1)在根目录下面新建了个"images"文夹,里面放了张图片top.gif (2)在根目录下另外新建了两个 ...

  5. NodeJS概述

    NodeJS中文API 一.概述 Node.js 是一种建立在Google Chrome’s v8 engine上的 non-blocking (非阻塞), event-driven (基于事件的) ...

  6. struts2学习笔记(二)

    一. 国际化的目标 1). 如何配置国际化资源文件 I. Action 范围资源文件: 在Action类文件所在的路径建立名为 ActionName_language_country.properti ...

  7. linux编译动态库 fPIC作用

    在生成动态库时,常常习惯性的加上fPIC选项,fPIC有什么作用和意义,加不加有什么区别,这里做下小结: fPIC的全称是 Position Independent Code, 用于生成位置无关代码. ...

  8. bzoj 2064 DP

    这道题可以抽象成两个数列,将一个数列变换为另一个 数列的代价最小 首先我们可以处理出所有的状态代表,对于每个状态 用二进制来表示,代表的是两个数列中的每一项选还是不选 那么答案最多为n1+n2-2,也 ...

  9. bzoj 2753 最小生成树变形

    我们根据高度建图,将无向边转化为有向边 首先对于第一问,直接一个bfs搞定,得到ans1 然后第二问,我们就相当于要求找到一颗最小生成树, 满足相对来说深度小的高度大,也就是要以高度为优先级 假设现在 ...

  10. compositionstart 、 compositionend 、 input都存在时的解决办法

    $(function () { var cpLock = true; $('#textbox').off().on({ compositionstart: function () {//中文输入开始 ...