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

  在这种方式中,我们的通常做法是,将nginx作为服务器最前端,它将接收WEB的所有请求,统一管理请求。nginx把所有静态请求自己来处理(这是NGINX的强项)。然后,NGINX将所有非静态请求通过uwsgi传递给Django,由Django来进行处理,从而完成一次WEB请求。

  可见,uwsgi的作用就类似一个桥接器。起到桥梁的作用。

  Linux的强项是用来做服务器,所以,下面的整个部署过程我们选择在Ubuntu下完成。

一、安装Nginx

  Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好。

  Nginx同样为当前非常流行的web服务器。利用其部署Django,我们在此也做简单的介绍。

wuzlxadmin@WUZLX004:/$ sudo apt-get install nginx  # 安装nginx

  启动nginx:

wuzlxadmin@WUZLX004:~$ /etc/init.d/nginx start 

wuzlxadmin@WUZLX004:~$ /etc/init.d/nginx stop

wuzlxadmin@WUZLX004:~$ /etc/init.d/nginx restart 

  配置nginx

nginx默认会读取/etc/nginx/sites-enabled/default文件中的配置:

server {
listen default_server;
listen [::]: default_server;
...........

输入你的ubuntu ip即可访问, 正常是127.0.0.1:80

如果出现上图,则说明Nginx已经安装配置成功。

二、安装uwsgi

wuzlxadmin@WUZLX004:~$ pip3 install uwsgi

测试uwsgi,创建test.py文件:

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

通过uwsgi运行该文件

wuzlxadmin@WUZLX004:~$ uwsgi --http: --wsgi-file test.py

接下来配置Django与uswgi连接。我的Django项目位置为:

uwsgi支持通过配置文件的方式启动,可以接受更多的参数,高度可定制。我们在Django项目下新建ini文件default_app_uwsgi.ini(注意:不是django目录下的同名子文件夹)

# Django-related settings

socket = :

# the base directory (full path)
chdir = /usr/app/DataAnalysis # Django s wsgi file
module = DataAnalysis.wsgi # process-related settings
# master
master = true # maximum number of worker processes
processes = # ... with appropriate permissions - may be needed
# chmod-socket =
# clear environment on exit
vacuum = true

其中chdir是django项目的根目录、module是相对路径指向项目同名目录下的wsgi.py文件

接下来,切换到Django项目目录下,通过uwsgi命令读取default_app_uwsgi.ini文件启动项目。

wuzlxadmin@WUZLX004:/usr/app/DataAnalysis$ uwsgi --ini default_app_uwsgi.ini
[uWSGI] getting INI configuration from default_app_uwsgi.ini
*** Starting uWSGI 2.0. (64bit) on [Tue Jun :: ] ***
compiled with version: 5.4. on May ::
os: Linux-4.10.--generic #~16.04.-Ubuntu SMP Thu Jul :: UTC
nodename: WUZLX004
machine: x86_64
clock source: unix
detected number of CPU cores:
current working directory: /usr/app/DataAnalysis/DataAnalysis
detected binary path: /home/wuzlxadmin/.local/bin/uwsgi
!!! no internal routing support, rebuild with pcre support !!!
chdir() to /usr/app/DataAnalysis
your processes number limit is
your memory page size is bytes
detected max file descriptor number:
lock engine: pthread robust mutexes
thunder lock: disabled (you can enable it with --thunder-lock)
uwsgi socket bound to TCP address : fd
Python version: 3.5. (default, Nov , ::) [GCC 5.4. ]
*** Python threads support is disabled. You can enable it with --enable-threads ***
Python main interpreter initialized at 0x1d6b0d0
your server socket listen backlog is limited to connections
your mercy for graceful operations on workers is seconds
mapped bytes ( KB) for cores
*** Operational MODE: preforking ***
ImportError: No module named '/DataAnalysis'
unable to load app (mountpoint='') (callable not found or import error)
*** no app loaded. going in full dynamic mode ***
*** uWSGI is running in multiple interpreter mode ***
spawned uWSGI master process (pid: )
spawned uWSGI worker (pid: , cores: )
spawned uWSGI worker (pid: , cores: )
spawned uWSGI worker (pid: , cores: )
spawned uWSGI worker (pid: , cores: )

再接下来要做的就是修改nginx.conf配置文件。打开/etc/nginx/nginx.conf文件,如下内容,添加在http花括号里面。

server {
listen ;
server_name 10.202.143.240
charset UTF-;
access_log /var/log/nginx/DataAnalysis_access.log;
error_log /var/log/nginx/DataAnalysis_error.log; client_max_body_size 75M; location / {
include /etc/nginx/uwsgi_params;
uwsgi_pass 10.202.143.240:;
uwsgi_read_timeout ;
}
location /static {
expires 30d;
autoindex on;
add_header Cache-Control private;
alias /usr/app/DataAnalysis/static/;
}
}

listen 指定的是nginx代理uwsgi对外的端口号。

uwsgi_pass 10.202.143.240:8001;指的本机IP的端口号与ini文件配置中的必须一致。

/static 是配置静态文件的地方。可以直接通过10.202.143.240:8081/static访问此文件夹了。

重启nginx。

PS:

操作/etc/nginx/nginx.conf文件的时候,将下面这一句的注释去掉。

server_names_hash_bucket_size ;

另外注意一下  新加的server的位置问题:

http{
server{}
}

测试nginx的configuration是否ok

nginx -t -c /etc/nginx/nginx.conf

有时候我们会遇到报错说host不存在、那是因为没有把host加入到django项目的settings.py文件中。

ALLOWED_HOSTS = ['*']

改一下settings设置如上即可。记得重新运行一下。

Django admin css问题

1、修改django项目的settings.py文件

STATIC_ROOT = os.path.join(BASE_DIR, 'static')

2、执行语句将文件整体从django default路径copy到static文件中

python manage.py collectstatic

现在你会发现static文件夹下面多了一个子文件夹admin。

重启下uwsgi。

这里没找到什么好的方法,只能通过杀死进程、重新开启来执行。

killall - uwsgi

uwsgi --ini /usr/app/DataAnalysis/default_app_uwsgi.ini

Python 关于在ubuntu部署Django项目的更多相关文章

  1. ubuntu 部署Django项目+uwsgi+Nginx

    1.部署框架 Nginx负责静态资源请求,并且把无法处理的请求转发至uwsgi处理 2.安装并配置Nginx 2.1安装 apt-get install nginx (如果安装失败请先升级apt-ge ...

  2. ubuntu部署django详细教程

    教程使用的软件版本:Ubuntu 18.04.1 LTS,django2.0,Python 3.6.5.nginx-1.13.7.uWSGI (2.0.17.1),Ubuntu是纯净的,全新的.下面我 ...

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

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

  4. Ubuntu+uWSGI部署Django项目【鸿篇巨制,事无巨细】

    背景 任务: 视频翻译项目需要在两个服务器上进行通信(国内&海外的阿里服务器). 因为python是主语言,选用了Django 来快速部署API. 注:Django中文文档:https://d ...

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

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

  6. 打造专属测试平台4-使用Docker部署Django项目

    编写完项目代码后,为了稳定的运行,需要将其部署至服务器.这里我选择了Docker去部署Django后端代码. 首先来看看Runoob对Docker的介绍: Docker 是一个开源的应用容器引擎,基于 ...

  7. mac osx 上面部署Django项目 apache+mysql+mod_wsgi

    1.安装Xcode command line tools 首先,编译mysql和Homebrew需要用到Xcode command line tools,所以首先安装command line tool ...

  8. Docker 部署Django项目

    使用docker部署django项目也很简单,挺不错,分享下 环境 默认你已安装好docker环境 django项目大概结构 (p3s) [root@opsweb]# tree opsweb opsw ...

  9. CentOS 6.8 部署django项目一

    CentOS 6.8 部署django项目二 1.安装python3.5(默认是2.6) 参考:http://blog.csdn.net/shaobingj126/article/details/50 ...

随机推荐

  1. Django(十五)Form组件

    参考博客: https://www.cnblogs.com/haiyan123/p/7778888.html http://www.cnblogs.com/wupeiqi/articles/61441 ...

  2. Solr7.1--- 指定ConfigSets

    我们都知道Solr提供了一个默认的配置,以及一个demo 但是实际场景是我们需要自己独立配置,不用默认的,主要为了方便管理. 进入目录: D:\solr-7.1.0\server\solr\confi ...

  3. AOP和IOC

    AOP切面编程,作用:事务,日志,统一调用,统一实现,拦截,分发: 切点:告诉编译器切面作用于哪个package中的class IOC:控制反转,相对于new 对象来说的,依赖注入:AuthorWar ...

  4. 彻底删除与安装MySQL

    一.下载msi安装版:https://dev.mysql.com/downloads/mysql/ 二.安装前一定要彻底删除已有的MySQL:(从未安装过,忽略此步) 1.计算机处右键快捷菜单,管理, ...

  5. CodeForces7D 字符串hash + dp

    https://cn.vjudge.net/problem/20907/origin 长度是 n 的字符串 s,如果它自身是回文数,且它的长度为 的前缀和后缀是 (k - )-回文数,则它被称作 k- ...

  6. springboot学习笔记-5 springboot整合shiro

    shiro是一个权限框架,具体的使用可以查看其官网 http://shiro.apache.org/  它提供了很方便的权限认证和登录的功能. 而springboot作为一个开源框架,必然提供了和sh ...

  7. Hadoop记录-HDFS balancer配置

    HDFS balancer配置(可通过CM配置)dfs.datanode.balance.max.concurrent.moves 并行移动的block数量,默认5 dfs.datanode.bala ...

  8. 清理sql2012数据库日志

    --1.先把数据库设置为简单模式(右击数据库名->点'属性'->点'选项'->恢复模式改成'简单'->点'确定'按钮,--2.再执行下面的语句(或者右击数据库点'任务'-> ...

  9. springboot 日志【转】【补】

    市面上的日志框架 日志门面 (日志的抽象层) 日志实现 JCL(Jakarta Commons Logging)(2014) SLF4j(Simple Logging Facade for Java) ...

  10. Storm安装部署

    1.从官网下载安装包,并通过Xftp5上传到机器集群上 下载apache-storm-1.2.1.tar.gz 版本,并通过Xftp5上传到hadoop机器集群的第一个节点node1上的/opt/up ...