云顶娱乐平台 16

【云顶娱乐平台】uWSGI+Nginx+Django安装和配置

前面超哥也对nginx简单的介绍了,本文将nginx、WSGI、uwsgi、uWSGI、django这几个关系梳理一下。

云顶娱乐平台 1

4.
django在debug=False下对静态文件的处理能力不是很好,而用nginx来处理更加高效。

三、安装与配置

首先,确保你已经安装好了nginx并可以正常使用
其次,确保自己安装完成了python,并已经完成了pip的安装。如果没有,请先安装。
接着,别忘了确认自己项目所需的django已经完成安装正常工作
没有的话参考以下命令安装django ,
建立一个工程或利用已经写好的工程,打开浏览器,输入部署地址(如:

安装:sudo pip install django==1.10
测试:python manage.py runserver 0.0.0.0:8000

云顶娱乐平台 2

上面的工作都完成了,接着安装uWSGI

sudo pip install uwsgi

云顶娱乐平台 3

测试uWSGI: 新建文件test.py,写入以下内容

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

运行

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

如果端口占用,使用

lsof -i :8000

云顶娱乐平台 4

列出占用端口的程序的pid号,并使用以下命令杀掉所有占用端口的程序

sudo kill -9 pid

然后浏览

World”输出即安装成功。

下一步,建立工程单独的nginx配置文件
首先确认自己准确的知道nginx的默认配置文件目录(nginx.conf)的路径,如果不清楚,请使用如下命令获取:

nginx -t

大概会列出以下类似信息:

nginx: the configuration file /etc/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/conf/nginx.conf test is successful

里面说明了nginx默认配置文件的路径是:/etc/nginx/conf/nginx.conf;

然后,确保nginx.conf的同目录下有uwsgi_params文件(/etc/nginx/conf/uwsgi_params),没有的话根据链接获取,
后面要用到。

自己的工程目录下,建立如destiny.conf(/wwwroot/destiny/destiny.conf)的配置文件;复制nginx.conf里面全部的内容,全部写入destiny.conf中。
然后按照下面写的,把destiny.conf配置文件中的server段部分全部替换掉。

server {
    listen 80;
    server_name localhost;
    charset     utf-8;
    access_log      /wwwroot/destiny/nginx_access.log;
    error_log       /wwwroot/destiny/nginx_error.log;
    client_max_body_size 75M;


    location /static {
        alias /wwwroot/destiny/destiny/static;
    }

    location / {
        include     /etc/nginx/conf/uwsgi_params;
        uwsgi_pass  127.0.0.1:9090;
    }
}

云顶娱乐平台 5

其中的 listen 80代表服务器开放80端口;
location [目录名]代表项目路径的引导;
access_log 和error_log是定义nginx访问日志和错误日志的存放路径。
“location
/static”中的”/static”是自己定义的项目引用静态文件时,浏览器中显示的静态资源所在的根目录名;这样的话,用户在浏览器中查看到的所有image、css或js资源都是处在
django静态文件的绝对路径是根据自己的实际情况来确定的,一般在自己的django的app名/static目录下,或自己python manage.py collectstatic后的路径下。像我的是在/wwwroot/destiny/destiny/static根目录下。
“location /”是指访问项目根目录时,nginx要做的事。其中需要指定
uwsgi_params文件的绝对路径,上面已经提到了;如果还有media文件之类的静态目录,仿照static的写法��自己补充。
127.0.0.1:9090是指uWSGI绑定的监听地址,这里使用了9090端口。
需要注意的是,请确认自己django的静态文件目录所有者是www用户,如果不是,请用以下命令更改静态目录权限归属者:

sudo chown -R www:www /wwwroot/destiny/destiny/static

下面接着建立uWSGI的配置文件,在自己工程目录下创建uwsgi.ini文件,写入以下内容

[uwsgi]
socket = 127.0.0.1:9090
chdir=/wwwroot/destiny
module=destiny.wsgi
master = true         
processes=2
threads=2
max-requests=2000
chmod-socket=664
vacuum=true
daemonize = /wwwroot/destiny/uwsgi.log

云顶娱乐平台 5

其中的socket字段值”127.0.0.1:9090”必须要和上面写的density.conf配置文件中的uWSGI监听地址完全一样;
chdir指自己工程的绝对路径;
module指的是wsgi.py在自己工程中的相对路径,”.”指代一层目录;我的django工程的wsgi.py文件是在”/wwwroot/destiny/destiny/wsgi.py”,所以写成destiny.wsgi;
daemonize指定uWSGI日志的存储路径。

好了,现在理一下路径:

工程路径:                  /wwwroot/destiny
工程静态文件路径:            /wwwroot/destiny/destiny/static
wsgi.py的路径:             /wwwroot/destiny/destiny/wsgi.py
uwsgi.ini的路径:           /wwwroot/destiny/uwsgi.ini
uwsgi日志路径:             /wwwroot/destiny/uwsgi.log
destiny.conf的路径:        /wwwroot/destiny/destiny.conf
uwsgi_params的路径:        /etc/nginx/conf/uwsgi_params
nginx访问日志路径:          /wwwroot/destiny/nginx_access.log
nginx错误日志路径:          /wwwroot/destiny/nginx_error.log

云顶娱乐平台 5

可以发现,我几乎把所有有关工程的配置文件和日志文件都放在工程目录下了,方便后期维护与查错。
启动uWSGI

sudo uwsgi --ini /wwwroot/destiny/destiny.ini

启动nginx
在这之前,我们要先去nginx配置文件的根目录拷贝mime.types(/etc/nginx/conf/mime.types)到工程目录(/wwwroot/destiny/mime.types),【云顶娱乐平台】uWSGI+Nginx+Django安装和配置。和destiny.conf放在一起
否则用配置文件启动nginx会报错:

nginx: [emerg] open() "/**/**/**/mime.types" failed (2: No such file or directory)

如果nginx已经开启,先关闭nginx(service nginx stop),再执行以下命令:

nginx -c /wwwroot/destiny/destiny.conf

这里的-c 表示加载配置文件启动

逻辑图

云顶娱乐平台 8

web服务器

传统的c/s架构,请求的过程是
客户端 > 服务器 
服务器 > 客户端
服务器就是:1.接收请求 2.处理请求 3.返回响应

web框架层

HTTP的动态数据交给web框架,例如django遵循MTV模式处理请求。
HTTp协议使用url定位资源,urls.py将路由请求交给views视图处理,然后返回一个结果,完成一次请求。
web框架使用者只需要处理业务的逻辑即可。

如果将一次通信转化为“对话”的过程

Nginx:hello wsgi,我刚收到一个请求,你准备下然后让django来处理吧

WSGI:好的nginx,我马上设置环境变量,然后把请求交给django

Django:谢谢WSGI,我处理完请求马上给你响应结果

WSGI:好的,我在等着

Django:搞定啦,麻烦wsgi吧响应结果传递给nginx

WSGI:太棒了,nginx,响应结果请收好,已经按照要求传递给你了

nginx:好滴。我把响应交给用户。合作愉快

更多参考

# Django-related settings

二、必要的前提

2.1 准备知识

django

一个基于python的开源web框架,请确保自己熟悉它的框架目录结构。

uWSGI

一个基于自有的uwsgi协议、wsgi协议和http服务协议的web网关

nginx

常用高性能代理服务器

wsgi.py

django项目携带的一个wsgi接口文件
如果项目名叫destiny的话,此文件就位于[destiny/destiny/wsgi.py]

2.2 相关资料

wsgi:一种实现python解析的通用接口标准/协议,是一种通用的接口标准或者接口协议,实现了python
web程序与服务器之间交互的通用性。
利用它,web.py或bottle或者django等等的python
web开发框架,就可以轻松地部署在不同的web server上了;

uwsgi:同WSGI一样是一种通信协议
uwsgi协议是一个uWSGI服务器自有的协议,它用于定义传输信息的类型,它与WSGI相比是两样东西。

uWSGI :一种python web server或称为Server/Gateway
uWSGI类似tornadoweb或者flup,是一种python web
server,uWSGI是实现了uwsgi和WSGI两种协议的Web服务器,负责响应python
的web请求。
因为apache、nginx等,它们自己都没有解析动态语言如php的功能,而是分派给其他模块来做,比如apache就可以说内置了php模块,让人感觉好像apache就支持php一样。
uWSGI实现了wsgi协议、uwsgi协议、http等协议。
Nginx中HttpUwsgiModule的作用是与uWSGI服务器进行交换。

2.3 项目流程
其实网上很多教程,都是关于uwsgi+nginx部署django的,StackOverflow也有一些解决常见错误的方法,但是部署还是容易出问题,新手难解决。
归根到底是自己不了解整个项目的流程。教程都只教方法,但为什么这样部署,这样部署有什么好处,每个组件都起什么作用却只字不提。致使只要部署稍微有那么一点不同,就无可是从了。
所以说,项目流程和每个组件的用途才是此次部署最重要的部分。

首先客户端请求服务资源,
nginx作为直接对外的服务接口,接收到客户端发送过来的http请求,会解包、分析,
如果是静态文件请求就根据nginx配置的静态文件目录,返回请求的资源,
如果是动态的请求,nginx就通过配置文件,将请求传递给uWSGI;uWSGI 将接收到的包进行处理,并转发给wsgi,
wsgi根据请求调用django工程的某个文件或函数,处理完后django将返回值交给wsgi,
wsgi将返回值进行打包,转发给uWSGI,
uWSGI接收后转发给nginx,nginx最终将返回值返回给客户端(如浏览器)。
*注:不同的组件之间传递信息涉及到数据格式和协议的转换

作用:
1.
第一级的nginx并不是必须的,uwsgi完全可以完成整个的和浏览器交互的流程;

  1. 在nginx上加上安全性或其他的限制,可以达到保护程序的作用;
    3.
    uWSGI本身是内网接口,开启多个work和processes可能也不够用,而nginx可以代理多台uWSGI完成uWSGI的负载均衡;
    4.
    django在debug=False下对静态文件的处理能力不是很好,而用nginx来处理更加高效。

  django的静态文件与nginx配置

mysite/settings.py

STATIC_ROOT='/opt/nginx1-12/static'
STATIC_URL = '/static/'
STATICFILES_DIRS=[
    os.path.join(BASE_DIR,"static"),
]

上述的参数STATIC_ROOT用在哪?

通过python3 manage.py collectstatic
收集所有你使用的静态文件保存到STATIC_ROOT!

STATIC_ROOT 文件夹 是用来将所有STATICFILES_DIRS中所有文件夹中的文件,以及各app中static中的文件都复制过来
# 把这些文件放到一起是为了用nginx等部署的时候更方便

 

 

参考文档:

 uwsgi热加载:

sudo ln -s ~/path/to/your/mysite/mysite_nginx.conf
/etc/nginx/sites-enabled/
部署静态文件
在部署服务器之前,需要先将Django的静态文件部署到静态文件夹中,首先,编辑django网站的settings.py文件

2.实战配置

四、后记

到这里,工作基本就做完了,可以打开浏览器,输入自己项目的IP地址,如

云顶娱乐平台 9

  1. 如果启动时就报错,查看终端信息,解决错误。
    如果终端没有报错,但是浏览时出现500、502等错误,就去项目目录查看nginx日志和uWSGI日志,解决错误。

  2. 自己在部署时,遇到很多坑,网上的教程大多附带virtualenv和supervisor的部署,但是连最基本的部署都说不明白,部署出来的东西性能再好也没指导意义。基于自己踩坑脱坑的过程,写下此文。

  3. 正如以上所说,我只是用单独的一个conf文件,在nginx上部署了一个工程,没有说明部署多个工程的问题;也没有使用virtualenv开发环境、使用supervisor来管理进程等。请根据个人爱好和需要去实践扩展。

更多参考

Nginx+uWSGI+Supervisor在Ubuntu上部署Flask应用 
http://www.linuxidc.com/Linux/2016-07/133064.htm

Ubuntu Server 12.04 安装Nginx+uWSGI+Django环境
http://www.linuxidc.com/Linux/2012-05/60639.htm 

快速部署Python应用:Nginx+uWSGI配置详解 
http://www.linuxidc.com/Linux/2016-12/137830.htm

Nginx+uWSGI+Django+Python 应用架构部署 
http://www.linuxidc.com/Linux/2015-10/124183.htm

Ubuntu Server 14.04.2 LTS 配置 Nginx + Uwsgi + Django 
http://www.linuxidc.com/Linux/2015-04/116397.htm

Flask+uWSGI+Nginx+Ubuntu部署教程
http://www.linuxidc.com/Linux/2016-06/132690.htm

Ubuntu 16.04下安装部署 Nginx+uWSGI+Django1.9.7 
http://www.linuxidc.com/Linux/2016-07/133484.htm

Nginx+uWSGI+Django在Ubuntu下的部署 
http://www.linuxidc.com/Linux/2016-07/133490.htm

Linux 上利用Nginx代理uWSGI处理Flask Web应用 
http://www.linuxidc.com/Linux/2016-08/134164.htm

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-03/141785.htm

云顶娱乐平台 10

提前安装好python3环境

https://www.cnblogs.com/pyyu/p/7402145.html

[uwsgi]
# 项目根目录路径(full path)
chdir          = /path/to/your/project
# Django的 wsgi 文件
module          = mysite.wsgi
# virtualenv目录 (full path)
home            = /path/to/virtualenv

uwsgi

一、前言

献给和我一样懵懂中不断汲取知识,进步的人们。

霓虹闪烁,但人们真正需要的,只是一个可以照亮前路的烛光

指定配置文件启动命令

uwsgi --ini  /etc/uwsgi_nginx.ini

[Install]
WantedBy=multi-user.target
这样我们就可以用systemd来管理uwsgi服务了。启动服务:

# ‘NAME’: os.path.join(BASE_DIR, ‘db.sqlite3’),

大家都学过了django,用django写了各种功能,写了bbs项目,写了路飞学城。

2 测试uwsgi是否安装成功
在终端中输入以下命令查看uwsgi的版本号,如果输出正常,说明uswgi已安装成功

1.若要放在云服务器上部署。

基础开发环境配置

yum groupinstall "Development tools"
yum install zlib-devel bzip2-devel pcre-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel

yum groupinstall “Development Tools”
yum install python 

module =Blog.wsgi

supervisor

supervisor 是基于 python
的任务管理工具,用来自动运行各种后台任务,当然你也能直接利用 nohup
命令使任务自动后台运行,但如果要重启任务,每次都自己手动 kill
掉任务进程,这样很繁琐,而且一旦程序错误导致进程退出的话,系统也无法自动重载任务。

这里超哥要配置基于virtualenv的supervisor

由于supervisor在python3下无法使用,因此只能用python2去下载!!!!!!

#注意此时已经退出虚拟环境了!!!!!
yum install python-setuptools
easy_install supervisor

通过命令生成supervisor的配支文件

echo_supervisord_conf > /etc/supervisord.conf

然后再/etc/supervisord.conf末尾添加上如下代码!!!!!!

[program:my]
#command=/opt/venv/bin/uwsgi --ini  /etc/uwsgi_nginx.ini  #这里是结合virtualenv的命令 和supervisor的精髓!!!!
command= /home/venv/bin/uwsgi --uwsgi 0.0.0.0:8000 --chdir /opt/mysite --home=/home/venv --module mysite.wsgi
#--home指的是虚拟环境目录  --module找到 mysite/wsgi.py

directory=/opt/mysite
startsecs=0
stopwaitsecs=0
autostart=true
autorestart=true

最后启动supervisor,完成uWSGI启动django,nginx反向代理

supervisord -c /etc/supervisord.conf #启动supervisor
supervisorctl -c /etxc/supervisord.conf restart my  #重启my项目
supervisorctl -c /etc/supervisord.conf [start|stop|restart] [program-name|all]

 重新加载supervisor

一、添加好配置文件后

二、更新新的配置到supervisord    

supervisorctl update
三、重新启动配置中的所有程序

supervisorctl reload
四、启动某个进程(program_name=你配置中写的程序名称)

supervisorctl start program_name
五、查看正在守候的进程

supervisorctl
六、停止某一进程 (program_name=你配置中写的程序名称)

pervisorctl stop program_name
七、重启某一进程 (program_name=你配置中写的程序名称)

supervisorctl restart program_name
八、停止全部进程

supervisorctl stop all
注意:显示用stop停止掉的进程,用reload或者update都不会自动重启。

    # 将动态请求转发到uwsgi跑的django程序
    location / {
        uwsgi_pass  django;
        include    /path/to/your/mysite/uwsgi_params; #
从github上下载的uwsgi_params 文件路径
    }
}
你也可以把这个配置文件放在项目路径中,然后建立一个链接到nginx配置文件夹:

}

安装django1.11

pip3 install django==1.11
#创建django项目mysite
django-admin startproject mysite
#创建app01
python3 manage.py startapp app01

mysite/settings.py

#settings.py设置
ALLOWED_HOSTS = ['*']
install app01

mysite/urls.py

from app01 import views
urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^hello_django/', views.hello),
]

app01/views.py

from django.shortcuts import render,HttpResponse

# Create your views here.
def hello(request):
    print('request is :',request)
    return HttpResponse('django is ok ')

uwsgi –socket :8001 –module mysite.wsgi –chmod-socket=664
接下来,启动nginx服务器,就可以访问django站点了。

listen 80;

配置nginx结合uWSGI

配置nginx.conf

worker_processes  1;
error_log  logs/error.log;
pid        logs/nginx.pid;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
    access_log  logs/access.log  main;
    sendfile        on;
    keepalive_timeout  65;
   #nginx反向代理uwsgi
    server {
        listen       80;
        server_name  192.168.11.64;
        location / {
         include  /opt/nginx1-12/conf/uwsgi_params;
         uwsgi_pass 0.0.0.0:8000;
            root   html;
            index  index.html index.htm;
        }
      #nginx处理静态页面资源
      location /static{
        alias /opt/nginx1-12/static;   
         }
     #nginx处理媒体资源
     location /media{
        alias /opt/nginx1-12/media;   

         }
        error_page   500 502 503 504  /50x.html;

        location = /50x.html {
            root   html;
        }
    }
}

配置完启动nginx

# nginx需要连接的上游
upstream django {
    server unix:///path/to/your/mysite/mysite.sock; # 使用unix套接字
    #server 127.0.0.1:8001; #
使用TCP端口请注释上一行,并取消本行注释,这里的端口指的是跑uwsgi的端口
}

.. 如果是动态的请求,nginx就通过配置文件,将请求传递给uWSGI;uWSGI
将接收到的包进行处理,并转发给 wsgi,

Django Nginx+uwsgi 安装配置

在前面的章节中我们使用 python manage.py
runserver
 来运行服务器。这只适用测试环境中使用。

正式发布的服务,需要一个可以稳定而持续的服务器。

master          = true
#
最大工作进程数(CPU密集型建议设为CPU核心数,IO密集型建议设为CPU核心数的两倍)
processes      = 16
# unix套接字文件路径
socket          = /path/to/your/project/mysite.sock
# socket文件权限
# chmod-socket    = 664
# 退出时清空环境
vacuum          = true
然后,直接根据配置文件运行uwsgi即可:

)

virtualenv

请确保你的虚拟环境正常工作
https://www.cnblogs.com/pyyu/p/9015317.html

7 常用参数和选项
关于参数的具体使用,可以阅读官方文档
,在这里列出一些常用的参数:

server {

wsgi    全称web server gateway interface,wsgi不是服务器,也不是python模块,只是一种协议,描述web server如何和web application通信的规则。
运行在wsgi上的web框架有bottle,flask,django

uwsgi    和wsgi一样是通信协议,是uWSGI服务器的单独协议,用于定义传输信息的类型

uWSGI    是一个web服务器,实现了WSGI协议,uwsgi协议。a

nginx    web服务器,更加安全,更好的处理处理静态资源,缓存功能,负载均衡,因此nginx的强劲性能,配合uWSGI服务器会更加安全,性能有保障。

django 高级的python web框架,用于快速开发,解决web开发的大部分麻烦,程序员可以更专注业务逻辑,无须重新造轮子

    浏览器 <-> nginx <-> uWSGI <-> Django(python)
uwsgi_params 配置文件
uWSGI使用的协议不完全是标准的WSGI协议,我们需要从Github下载uwsgi_paraments配置文件,并将该文件拷贝到项目路径中(例如:/user/home/pengquanxin/projects/mysite1/)。

mysql 5.7.21

安装uWSGI

进入虚拟环境venv,安装uwsgi
(venv) [root@slave 192.168.11.64 /opt]$pip3 install uwsgi
检查uwsgi版本
(venv) [root@slave 192.168.11.64 /opt]$uwsgi --version
2.0.17.1
#检查uwsgi python版本
uwsgi --python-version

运行简单的uWSGI

#启动一个python
uwsgi --http :8000 --wsgi-file test.py
  • http :8000: 使用http协议,端口8000
  • wsgi-file test.py: 加载指定的文件,test.py

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

uWsgi热加载python程序

在启动命令后面加上参数
uwsgi --http :8088 --module mysite.wsgi --py-autoreload=1 
#发布命令
command= /home/venv/bin/uwsgi --uwsgi 0.0.0.0:8000 --chdir /opt/mysite --home=/home/venv --module mysite.wsgi

#此时修改django代码,uWSGI会自动加载django程序,页面生效

运行django程序

#mysite/wsgi.py  确保找到这个文件
uwsgi --http :8000 --module mysite.wsgi
  • module mysite.wsgi: 加载指定的wsgi模块

uwsgi配置文件

云顶娱乐平台 11云顶娱乐平台 12

uwsgi支持ini、xml等多种配置方式,本文以 ini 为例, 在/etc/目录下新建uwsgi_nginx.ini,添加如下配置:

# mysite_uwsgi.ini file
[uwsgi]

# Django-related settings
# the base directory (full path)
chdir           = /opt/mysite
# Django's wsgi file
module          = mysite.wsgi
# the virtualenv (full path)
home            = /opt/venv
# process-related settings
# master
master          = true
# maximum number of worker processes
processes       = 1
# the socket (use the full path to be safe
socket          = 0.0.0.0:8000
# ... with appropriate permissions - may be needed
# chmod-socket    = 664
# clear environment on exit
vacuum          = true

uwsgi.ini

Ubuntu Server 14.04.2 LTS 配置 Nginx + Uwsgi + Django 
http://www.linuxidc.com/Linux/2015-04/116397.htm

STATIC_URL = ‘/static/’ #访问url后缀地址 如 127.0.0.1/static/js/jq.js

咱们都知道django是一个web框架,方便我们快速开发web程序,http请求的动态数据就是由web框架来提供处理的。

$ systemctl status emperor.uwsgi.service
停止服务

‘PORT’: ‘3306’,

Nginx+uWSGI+Supervisor在Ubuntu上部署Flask应用 
http://www.linuxidc.com/Linux/2016-07/133064.htm

2.文件权限处理

uwsgi –emperor /etc/uwsgi/vassals
这样,就会自动读取文件夹中的配置文件,并自动监控这些uwsgi服务: –
检测文件夹中有新的配置文件时,会启动新的uwsgi服务实例 –
检测到一个配置文件发生改变,会自动重启该服务 –
检测到一个配置文件被移除,则自动停止该服务 –
如果一个服务死了(诸侯),皇帝进程会重启该服务 –
如果监控进程(皇帝)死了,所有服务(诸侯)都会停止

}

uwsgi –ini mysite.uwsgi.ini
6 管理uwsgi
Emperor模式
uWSGI的Epreror模式可以用来管理机器上部署的uwsgi服务,在这种模式下,会有一个特殊的进程(皇帝)对其它部署的服务(诸侯)进行监视。我们将所有配置文件(ini或xml文件,如上一节中的mysite.uwsgi.ini)统一放到一个文件夹(如:/etc/uwsgi/vassals)中,然后启动Emperor模式:

‘{云服务器ip地址}’,

Ubuntu 16.04下安装部署 Nginx+uWSGI+Django1.9.7 
http://www.linuxidc.com/Linux/2016-07/133484.htm

location /media {

uWSGI是为Python语言定义的通用网关接口,它承担python
web框架(django、flask、web.py等)和web服务器(nginx、apache、lighttpd等)之间的中间层。

注:admin的静态文件位置与开发时的静态文件位置不一致,所以MEDIA_ROOT来合并所有的静态文件是很有必要的,这样admin才会有样式。

用systemd管理uwsgi服务
配合Eperor模式,在centos、fedora、archlinux中,我们可以用systemd来管理uwsgi,首先,创建一个systemd
service文件(/etc/systemd/system/emperor.uwsgi.service)

测试uWSGI: 新建文件test.py,写入以下内容:

3 nginx和django的配置
nginx和django的安装不是本文的重点,故在此略去,只讨论配置部分。在这里,我们要实现的效果如下:

安装:sudo pip install uwsgi

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-03/141822.htm

# chmod-socket = 664

    浏览器                      chrome、firefox、ie等
      |
    web服务器                  nginx、apache等
      |
    网关接口                    CGI、FastCGI、WSGI等
      |
    Python(程序、Web框架)    Django、Flask、Tornado等

# the domain name it will serve for

快速部署Python应用:Nginx+uWSGI配置详解 
http://www.linuxidc.com/Linux/2016-12/137830.htm

alias /var/www/blog/media; # your Django project’s media files – amend
as required

$ systemctl start emperor.uwsgi.service
查询服务运行状态:

#此地址是指在云服务器上 最后所有的static文件夹都会集中在此目录下
运行命令为

uWSGI+Django+Nginx的工作原理流程与部署过程
http://www.linuxidc.com/Linux/2017-03/141785.htm

因为apache、nginx等,它们自己都没有解析动态语言如php的功能,而是分派给其他模块来做,比如apache就可以说内置了php模块,让人感觉好像apache就支持php一样。

    浏览器 <-> uWSGI <-> Python
上述方式运行uWSGI服务的过程中,可以使用CTRL+C即可停止服务,在后续的章节中会讲到自动管理和部署。

1.作用:

# nginx服务器配置
server {
    # 监听端口
    listen      80;
    # 域名
    server_name .example.com;
    # 编码
    charset    utf-8;

# 设置静态文件目录

python中自带的wsgiref就是一种wsgi接口的标准实现,但是,由于100%使用python实现等原因,导致wsgiref实在过于缓慢,只能用于测试和学习。生产环境中我们需要使用性能更高的服务器,目前常用的wsgi服务器有:uWSGI、Gunicorn、twisted.web。

nginx 1.10.3

# mysite_nginx.conf

charset utf-8;

Linux 上利用Nginx代理uWSGI处理Flask Web应用 
http://www.linuxidc.com/Linux/2016-08/134164.htm

alias /var/www/blog/static; # your Django project’s static files –
amend as required

上面的例子中,我们用浏览器直接访问了uwsgi运行的python程序(只有一个入口函数的wsgi测试应用test.py),其访问结构如下所示。

创建static目录,注意顺序是先分配权限,再创建目录:mkdir static

chdir 项目目录
home virtualenv目录(如没有运行virtualenv虚拟环境,则无需设置)
socket 套接字文件或TCP套接字,例如:site1.uwsgi.sock 或 127.0.0.1:8000
uid 用户id
gid 用户组id
processes 工作进程数
harakiri 进程超过该时间未响应就重启该进程(默认单位为秒)
module 要启动的wsgi模块入口,如:mysite.wsgi:application
ini 指定ini配置文件
xml 指定xml配置文件(与ini类似)
file 指定要运行的wsgi程序文件,如:test.py
emperor Emperor模式
so-keepalive 开启TCP KEEPALIVE(unix套接字方式下无效)
vacuum 退出时清空环境

3.
uWSGI本身是内网接口,开启多个work和processes可能也不够用,而nginx可以代理多台uWSGI完成
uWSGI的负载均衡;

Nginx+uWSGI+Django+Python 应用架构部署 
http://www.linuxidc.com/Linux/2015-10/124183.htm

socket = :8000 # Django项目本地端口

#注:django1.6 前的版本需要手动添加wsgi.py
uwsgi –socket mysite.sock
如果nginx和uwsgi跑在同一台服务器上,使用unix套接字就可以了,unix套接字方式性能要高很多,但不能跨机器访问。当nginx和uWSGI不在一台服务器上时,就需要使用TCP端口方式(别忘了更改nginx配置文件,取消相应注释):

主要配置难点在于在django
setting.py文件的配置、uwsgi.ini文件配置,nginx配置上。

STATIC_ROOT = os.path.join(BASE_DIR, “static/”)
然后,运行以下命令

#设置静态文件目录。其中前端js、css、kindeditor富文本、UI第三方都放在其中

在Fedora、RedHat、CentOS下使用yum安装

os.path.join(BASE_DIR, “static”), #开发时存放静态文件目录

systemctl stop emperor.uwsgi.service
Linux系统中,还有一种通用的方法,就是在init.d 或 rc.d
中加入启动脚本,这种方式不够智能,而且网上资料很多,在这里暂不讨论。

MEDIA_ROOT =’/var/www/blog/media/’

$ uwsgi –version
2.0.11.1
我们可以编写一个简单的wsgi应用来测试uwsgi是否被安装成功,首先创建一个test.py文件:

# configuration of the server

uwsgi –http :8000 –wsgi-file test.py
参数中,http
:8000表示使用http协议,端口号为8000,wigi-file则表示要运行的wsgi应用程序文件。uwsgi运行后打开浏览器,访问
,或者是相应服务器地址的8000端口,就可以看到hello world 页面了。

nginx的配置文件在ubuntu中位置为 /etc/nginx/nginx.conf

python uwsgiconfig.py –build

processes = 4 # 启动4个uwsgi进程

编译安装,从github下载uwsgi代码,cd到目录下

pip install mysqlclient

Nginx+uWSGI+Django在Ubuntu下的部署 
http://www.linuxidc.com/Linux/2016-07/133490.htm

在project目录下兴建一个uwsgi.ini文件

    # Django 的media路径
    location /media  {
        alias /path/to/your/mysite/media; 
    }

location /static {

[Service]
ExecStart=/root/uwsgi/uwsgi –emperor /etc/uwsgi/vassals
Restart=always
KillSignal=SIGQUIT
Type=notify
StandardError=syslog
NotifyAccess=all

‘127.0.0.1’,

5 使用ini配置文件跑uWSGI
到这里,我们已经把nginx+uWSGI+Django跑起来了,但uWSGI的参数比较多的时候,每次都要输入非常麻烦,这时,我们可以在django项目目录下建立一个mysite.uwsgi.ini

2.项目运行流程

#安装最新稳定版
pip install uWSGI
#也可以安装长期支持版(LTS版本)
#pip install
在Ubuntu下可以使用apt-get来安装

..首先客户端请求服务资源,

python manage.py collectstatic
4 启动服务
在启动nginx之前,我们需要先启动uWSGI,进入项目目录然后输入以下命令,在这里我们使用unix套接字方式:

pidfile=uwsgi.pid

    # 静态文件路径
    location /static {
        alias /path/to/your/mysite/static;
    }

pip install Pollow ### model中ImageField需要的依赖

Flask+uWSGI+Nginx+Ubuntu部署教程
http://www.linuxidc.com/Linux/2016-06/132690.htm

# Finally, send all non-media requests to the Django server.

    # 最大上传大小
    client_max_body_size 75M; 

数据库在云服务器中使用的是mysql,在此建议在安装了mysql后,将云服务器上安装的mysql配置为可远程访问操控,方便在远程使用第三方工具对数据库进行操控。

# 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:

3.实战操作

[Unit]
Description=uWSGI Emperor
After=syslog.target

upstream django {

1 uWSGI的安装
uWSGI是用C语言写的高性能WSGI服务器,安装uWSGI前我们需要安装Python和C编译器(GCC)。推荐使用python包管理器pip安装uWSGI。

云顶娱乐平台 13nginx配置文件写入

apt-get install uwsgi 

uWSGI实现了wsgi协议、uwsgi协议、http等协议。
Nginx中HttpUwsgiModule的作用是与uWSGI服务器进行交换。

Nginx服务器配置
接下来,要配置nginx服务器和uWSGI互通,可以使用unix套接字方式和TCP端口方式。在nginx配置文件夹(/etc/naginx/site-enabled

/usr/local/etc/nginx/sites-enabled)中新建网站的配置文件mystie_nginx.conf,输入以下内容:

client_max_body_size 75M; # adjust to taste

‘default’: {

强制停止:killall -9 uwsgi

chdir = /www/Blog/Blog/ # 项目根目录位置

ubuntu 16.04 64位

nginx -s reload; nginx重启 但自己常使用 service nginx start/restart/stop

是ubuntu下要先创建关于django web
project的静态文件目录和上传文件目录,要保证

# server_name .liqian.ink; # substitute your machine’s IP address or
FQDN

云顶娱乐平台 14uwsgi.ini文件配置

此文纯粹记录个人在搭建此博客时候遇到的情况。

利用它,web.py或bottle或者django等等的python
web开发框架,就可以轻松地部署在不同的web server上了;

start_response(‘200 OK’, [(‘Content-Type’,’text/html’)])

uwsgi协议是一个uWSGI服务器自有的协议,它用于定义传输信息的类型,它与WSGI相比是两样东西。

MEDIA_ROOT=’/var/www/blog/static/’

1.基本知识

pip install PyMSQL

‘ENGINE’: ‘django.db.backends.mysql’,

STATICFILES_DIRS = (

# 设置本地服务的端口

uWSGI :一种python web server或称为Server/Gateway

.. wsgi将返回值进行打包,转发给uWSGI,

# maximum number of worker processes

location / {

‘HOST’: ‘{数据库所在的ip地址}’,

virtualenv 15.2.0

..如果是静态文件请求就根据nginx配置的静态文件目录,返回请求的资源,

# ‘ENGINE’: ‘django.db.backends.sqlite3’,

]

# … with appropriate permissions – may be needed

def application(env, start_response):

}

3.对静态文件和上传文件的更改。

首先要对服务器访问ip与web程序进行绑定才可以由云服务器的ip访问web资源。

启动:uwsgi –ini uwsgi.ini

# 监听主机的端口

# master

master = true # 进程设置,无需变动

若浏览器显示

1.
第一级的nginx并不是必须的,uwsgi完全可以完成整个的和浏览器交互的流程;

uwsgi:同WSGI一样是一种通信协议

daemonize=uwsgi.log

}

return “Hello World”

使用时,对数据库依赖安装了有以下:

# clear environment on exit

server 127.0.0.1:8000; # for a web port socket (we’ll use this first)

云顶娱乐平台 15nginx、uwsgi、django之间的相互联系图

# Django media

.. uWSGI接收后转发给nginx,nginx最终将返回值返回给客户端。

}

python 3.5

运行 sudo uwsgi –http 0.0.0.0:8000 –wsgi-file test.py

django框架下,对静态文件和上传文件是需要进行配置才会有效,要指定访问后缀和文件目录地址,这一切都可以在setting配置中实现。

include uwsgi_params; # the uwsgi_params file you installed

云顶娱乐平台 16test.py成功相应uwsgi

ALLOWED_HOSTS = [

kindeditor

而我们要写入的服务配置在 /etc/nginx/sites-enabled/default

重启:uwsgi –reload uwsgi.pid

# 设置媒体文件目录

uWSGI类似tornadoweb或者flup,是一种python web
server,uWSGI是实现了uwsgi和WSGI两种协议的Web服务器,负责响应python
的web请求。

修改Nginx配置文件,都需要重启Nginx服务。

# max upload size

1.注意事项

# 设置媒体文件目录 与上静态文件目录配置说明同理

..nginx作为直接对外的服务接口,接收到客户端发送过来的http请求,会解包、分析,

每次修改了Django项目中的模板/视图/URL/配置文件,都需要重启uwsgi服务。

vacuum = true

‘PASSWORD’: ‘{数据库访问密码}’,

DATABASES = {

}

sudo apt-get build-dep python-lxml

wsgi:一种实现python解析的通用接口标准/协议,是一种通用的接口标准或者接口协议,实现了python
web程序与服务器之间交互的通用性。

停止:uwsgi –stop uwsgi.pid

wsgi-file = /Blog/wsgi.py # wsgi.py文件在项目的中的相对位置

  1. 在nginx上加上安全性或其他的限制,可以达到保护程序的作用;

}

django 2.0

..
wsgi根据请求调用django工程的某个文件或函数,处理完后django将返回值交给wsgi,

[uwsgi]

MEDIA_URL = ‘/media/’

uwsgi_pass django;

python manage.py collectstatic

‘USER’: ‘{数据库访问用户}’,

修改目录权限:sudo chmod 777 /var/www/xxxx

2.更改数据库配置。

‘NAME’: ‘{数库名}’,