uwsgi加nginx部署django restframework前后端分离项目

一.uwsgi和nginx简介

  1.uwsgi(摘抄于百度百科):

    uWSGI是一个Web服务器,它实现了WSGI协议、uwsgi、http等协议。Nginx中HttpUwsgiModule的作用是与uWSGI服务器进行交换。WSGI是一种Web服务器网关接口。它是一个Web服务器(如nginx,uWSGI等服务器)与web应用(如用Flask框架写的程序)通信的一种规范。

  2.nginx(摘抄于百度百科):

    Nginx (engine x) 是一个高性能的HTTP和反向代理服务,也是一个IMAP/POP3/SMTP服务。Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。

其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。

    Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。

二.使用uwsgi启动django rest framework项目(和django一样)

  1.测试:

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,使用该命令启动测试文件test.py,然后访问8000端口,看是否成功。

  2.配置.ini文件(新建,任意命名,位置也可以自己选择):

    2.1我这里新建的是Label_System.ini(我放在项目根目录下),现在还未使用nginx,可以先使用http端口,不适用socket:

[uwsgi]#http是项目启动端口
#http = :9200#socket是于=与nginx通信的端口
socket = 127.0.0.1:8001
#the local unix socket file than commnuincate to Nginx
#socket = 0.0.0.0:8001
# the base directory (full path)项目目录
chdir = /projects/bishe
# Django‘s wsgi file
wsgi-file = bishe/wsgi.py
# maximum number of worker processes(进程数)
processes = 4
#thread numbers startched in each worker process(线程数)
threads = 4#这是python虚拟环境的位置
pythonpath=/root/#ROOT/.virtualenvs/vueshop/lib/python3.5/site-packages#缓冲大小
buffer-size=65535
#monitor uwsgi status#这是静态文件
static-map=/static=static
#stats = 127.0.0.1:9200
# clear environment on exit
vacuum = true
#daemonize = shops/uwsgi.log

    2.2启动怕配置文件(uwsgi +配置文件名):

     可以很容易看出启动了四个进程和对应的进程号

    2.3这时查看端口8001就可以访问了。

三.使用nginx实现反向代理:

  1.在/etc/nginx/conf.d目录下创建配置文件(路径可能不同,是自己安装的位置):

    我创建了一个my.conf,配置如下:

  

#监听的端口号
listen         9200;
    server_name    127.0.0.1;
    charset UTF-8;
#nginx日志位置
    access_log      /var/log/nginx/my_web_access.log;
    error_log       /var/log/nginx/my_web_error.log;

    client_max_body_size 75M;

    location / {
        include uwsgi_params;#这个很重要,是uwsgi的通信端口,即socket,而不是http
        uwsgi_pass 127.0.0.1:8001;
        uwsgi_read_timeout 2;
    }
#静态文件
    location /static {
        expires 30d;
        autoindex on;
        add_header Cache-Control private;
        alias /projects/bishe/static/;
     }
#前端页面
     location ~\.html$ {
        root /var/mytest/index/;
        index index.html index.htm;
     }
#前端js,css,jpg,png等路径,可以和drf的静态文件一起配置,防止前后台有一个找不到
        location ~.*\.(js|css|jpg|png)$ {
        root /var/mytest/;
     }
    

  

重启nginx即可,记得uwsgi和nginx中的配置文件通信端口要一致

  2.这时访问nginx监听端口(9000即可),这是其中的一个界面(index.html):

  

        当然测试的界面依旧如上(这里提一下,静态文件可能找不到,需要在设置中配置(STATIC_ROOT="路径")python manage.py collectstatic生成静态文件)

  3.如何关闭测试形成json数据格式呐:

    在setting.py中的rest_framework配置如下即可(默认是BrowsableAPIRenderer):

REST_FRAMEWORK = {

‘DEFAULT_RENDERER_CLASSES‘:

( ‘rest_framework.renderers.JSONRenderer‘, ),

}

  

      

      

原文地址:https://www.cnblogs.com/lyq-biu/p/10287088.html

时间: 2024-11-06 21:16:14

uwsgi加nginx部署django restframework前后端分离项目的相关文章

docker-compose 部署 Vue+SpringBoot 前后端分离项目

一.前言 本文将通过docker-compose来部署前端Vue项目到Nginx中,和运行后端SpringBoot项目 服务器基本环境: CentOS7.3 Dokcer MySQL 二.docker-compose 部署Vue+SpringBoot 前后端分离项目 整体项目配置结构,这里在不影响原来项目的结构,因此将所有配置文件都提出来存放到docker文件夹内了,但注意docker-compose文件须放到项目总的根目录下哦! 1.新增后端所需配置文件api-Dockerfile # 指定基

Docker环境下的前后端分离项目部署与运维(一)项目简介及环境要求

项目简介 本教程将从零开始部署一个前后端分离的开源项目,利用docker虚拟机的容器技术,采用分布式集群部署,将项目转换成为高性能.高负载.高可用的部署方案.包括了MySQL集群.Redis集群.负载均衡.双机热备等等. 部署图 所用到的主流技术 Docker容器.前后端集群.MySQL集群.Redis集群.Haproxy负载均衡.Nginx负载均衡.Keepalived实现双机热备 前后端分离项目部署图 前后端分离项目开源框架介绍 本次教程所采用的前后端分离的项目开源框架是人人网的renren

python 记录Django与Vue前后端分离项目搭建

python 记录Django与Vue前后端分离项目搭建 参考链接: https://blog.csdn.net/liuyukuan/article/details/70477095 1. 安装python与vue 2. 创建Django项目 django-admin startproject ulb_manager 3. 进入项目并创建名为backeng的app cd ulb_manager   python manage.py startapp backend 4. 使用vue-cli创建v

Docker环境下的前后端分离项目部署与运维

const 课程地址 = " http://icourse8.com/Dockerbushu.html "; 详细信息第1章 课程介绍 第2章 人人开源前后端分离项目下载与配置 第3章 Linux基础知识强化 第4章 搭建MySQL集群 第5章 搭建Redis集群 第6章 部署前后端分离项目 第7章 课后作业 第8章 云平台部署前后端分离 第9章 课程总结 var countAndSay = function(n) { return createStr(1, '1', n) funct

Aspnet前后端分离项目手记(二)关于token认证

在前后端分离的项目中,首先我们要解决的问题就是身份认证 以往的时候,我们使用cookie+session,或者只用cookie来保持会话. 一,先来复习一下cookie和session 首先我们来复习一下在aspnet中cookie和session的关系,做一个简单试验 这是一个普通的view没有任何处理 可以看到,没有任何东西(cookie),然后当我们写入一个session之后 \ 会发现多了一个名为ASP.NET_SessionId的cookie.我们都知道在aspnet中,session

Aspnet Mvc 前后端分离项目手记(二)关于token认证

在前后端分离的项目中,首先我们要解决的问题就是身份认证 以往的时候,我们使用cookie+session,或者只用cookie来保持会话. 一,先来复习一下cookie和session 首先我们来复习一下在aspnet中cookie和session的关系,做一个简单试验 这是一个普通的view没有任何处理 可以看到,没有任何东西(cookie),然后当我们写入一个session之后 会发现多了一个名为ASP.NET_SessionId的cookie.我们都知道在aspnet中,session是保

基于Vue的前后端分离项目实践

一.为什么需要前后端分离 1.1什么是前后端分离  前后端分离这个词刚在毕业(15年)那会就听说过,但是直到17年前都没有接触过前后端分离的项目.怎么理解前后端分离?直观的感觉就是前后端分开去做,即功能和职责上的一种划分,前端负责页面的渲染,部分页面交互的逻辑,然后通过网络请求与后端进行数据的交互:后端则着重关注业务逻辑的处理,直接操控数据库. 1.2前后端未分离前(1)jsp + servlet 开发模式: JSP页面:负责视图层的渲染及交互,内部可以嵌入java 代码,在某些场景下开发起来比

七个开源的 Spring Boot 前后端分离项目,一定要收藏!

前后端分离已经在慢慢走进各公司的技术栈,根据松哥了解到的消息,不少公司都已经切换到这个技术栈上面了.即使贵司目前没有切换到这个技术栈上面,松哥也非常建议大家学习一下前后端分离开发,以免在公司干了两三年,SSH 框架用的滚瓜烂熟,出来却发现自己依然没有任何优势! 其实前后端分离本身并不难,后段提供接口,前端做数据展示,关键是这种思想.很多人做惯了前后端不分的开发,在做前后端分离的时候,很容易带进来一些前后端不分时候的开发思路,结果做出来的产品不伦不类,因此松哥这里给大家整理了几个开源的前后端分离项

《Spring Boot 入门及前后端分离项目实践》系列介绍

课程计划 课程地址点这里 本课程是一个 Spring Boot 技术栈的实战类课程,课程共分为 3 个部分,前面两个部分为基础环境准备和相关概念介绍,第三个部分是 Spring Boot 项目实践开发.Spring Boot 介绍.前后端分离.API 规范等内容旨在让读者更加熟悉 SpringBoot 及企业开发中需要注意的事项并具有使用 SpringBoot 技术进行基本功能开发的能力:这最后的项目实战为课程的主要部分,我会带着大家实际的开发一个前后端分离的 Spring Boot 实践项目,