跨过Nginx上基于uWSGI部署Django项目的坑

先说说他们的关系,Nginx和uWSGI都是Web服务器,Nginx负责静态内容,uWSGI负责Python这样的动态内容,二者配合共同提供Web服务以实现提高效率和负载均衡等目的。uWSGI实现了多个协议,如WSGI,HTTP协议,还有它自己的uwsgi协议,想了解更多关于uWSGI和uwsgi协议内容可以查阅这里。这样和fastcgi类似,请求和响应的流程如下:

Request > Nginx > uWSGI > Django > uWSGI > Nginx > Response

请求先交由Nginx,如果是静态内容就自己处理了,如果是动态内容就交给uWSGI服务器,uWSGI服务器处理整个Django项目的Python代码,响应请求,原路返回,但是与fastcgi不同,Nginx、uWSGI和Django可以独立部署,然后整合。那么我们从Django开始,这里的服务器环境是Ubuntu 16.10。

1. 部署Django的项目

安装Python和Django,Ubuntu自带2.7和3.5版本的Python,安装相应的Django版本,注意在Ubuntu中不同版本Python都有相应的命令

www@cloud-vm-ub01:~$ python --version
Python 2.7.12+
www@cloud-vm-ub01:~$ python3 --version
Python 3.5.2+
www@cloud-vm-ub01:~$ pip -V
pip 9.0.1 from /home/www/.local/lib/python2.7/site-packages (python 2.7)
www@cloud-vm-ub01:~$ pip3 -V
pip 9.0.1 from /home/www/.local/lib/python3.5/site-packages (python 3.5)

pip3 install django

将已经完成开发的Django项目pro(pro是Django项目名)拷贝到服务器,这里拷贝到了www用户(www是服务器可登录用户名)路径下,最后相对路径是~/work/project/pro,绝对路径是/home/www/work/project/pro

进入以上目录,使用Django的内置服务器测试看看pro项目是否运行正常。

python3 ./manage.py runserver 127.0.0.1:8080

2. 部署uWSGI服务器

通过pip安装uWSGI。

pip3 install uwsgi

测试uWSGI是否正常,在~/work/project/pro目录中创建一个测试用的Python文件uwsgi_test.py

def application(env, start_response):
        start_response('200 OK',[('Content-Type', 'text/html')])
        #return ['Hello world'] # Python2
        return [b'Hello world'] # Python3

在pro项目路径下,基于HTTP协议运行uWSGI,如果uWSGI安装正常的话,可以在浏览器中访问9090端口,看到Hello world字样

uwsgi --http 127.0.0.1:9090 --wsgi-file uwsgi_test.py

接下来启动uWSGI加载Django项目,这里依然使用HTTP协议,将指向具体Python文件--wsgi-file参数替换为指向Django项目的--module参数,参数的值pro.wsgi指向~/work/project/pro/pro/wsgi.py模块,如果正常可以在浏览器http://127.0.0.1:9090端口打开了项目,但是静态文件路径有问题,不过没关系后面再处理。

www@cloud-vm-ub01:~/work/project/pro$ uwsgi --http 127.0.0.1:9090 --module pro.wsgi

对于uWSGI服务器的配置,如上命令加上很多参数非常麻烦,可以写成配置文件的方式,在~/work/project/pro中创建一个配置文件uwsgi.ini,注释掉参数暂时忽略,Django 1.4以前的版本需要配置如env,pythonpath等参数,这里不再深究了。

其中http参数用于以上测试,而与Nginx交互需要使用socket参数,即使用TCP协议,WSGI和uwsgi协议都在TCP协议之上。socket参数也可以配置为网络地址,如socket=127.0.0.1:7070,但如果Nginx和uWSGI同在一个服务器上,可以使用socket文件的形式。chmod-socket是为了动态配置socket文件的权限,因为socket文件会在每次uWSGI启动时被重新创建。

[uwsgi]
http=127.0.0.1:8000
#socket=/home/www/work/project/pro/nginx_uwsgi.socket
chdir=/home/www/work/project/pro/
#chmod-socket=664
master=true
processes=4
threads=2
module=pro.wsgi
#wsgi-file=uwsgi_test.py
#stats=127.0.0.1:9000

通过下面命令同样可以启动uWSGI加载Djiango项目

uwsgi --ini uwsgi.ini

设置uwsgi为自启动,在Ubuntu 16. 10

3. 部署Nginx服务器

通过apt安装Nginx

sudo apt install nginx

Nginx可以通过以下命令控制。正常安装和启动Nginx后,通过http://127.0.0.1:80可以看到Nginx的欢迎页

sudo service nginx start
sudo service nginx stop
sudo service nginx restart

接下来修改配置Nginx配置与uWSGI服务器交互。Nginx的主要配置文件在/etc/nginx/nginx.conf和sites-enabled文件夹里,nginx.conf是全局设置,sites-enabled文件夹里的可以针对不同站点进行配置,其中有个默认的default配置文件,该文件其实是sites-available文件夹里的default文件的软链接,sites-avaliable像个仓库,但只有sites-enabled里的才有效。我们可以将sites-enabled的default删除,再cp一份sites-available的default到sites-enabled里重名为nginx-pro,同时cp /etc/nginx/uwsgi_params ~/work/project/pro里以备nginx-pro配置文件调用。

#nginx-pro
 
upstream django{
        server unix:///home/www/work/project/pro/nginx_uwsgi.sock; # file socket
        #server 127.0.0.1:7070; # TCP socket
}


server {
        listen 80 default_server;
        listen [::]:80 default_server;
        root /var/www/html;
        index index.html index.htm index.nginx-debian.html;
        server_name 127.0.0.1; # IP or FQDN

        location /static {
                alias /home/www/work/project/pro/static;
        }

        location / {
                uwsgi_pass django;
                include /home/www/work/project/pro/uwsgi_params;
                #try_files $uri $uri/ =404;
        }
}

uwsgi_params文件是Nginx向uWSGI传递的参数,uwsgi_pass的意思动态内容请求都通过名为django的upstream传递给uWSGI,这使用文件socket的方式,那么与之前uwsgi.ini里的socket参数配置一致。

4. Nginx权限问题

以上全部配置完成了,但是还有一个重要的权限问题,如果启动uWSGI和Nginx(以下需要两个终端窗口,因为uwsgi命令会占据一个),会报错

uwsgi --ini uwsgi.ini
sudo service nginx restart

在/var/log/nginx/error.log中会看到Permission denied字样,是对home/www/work/project/pro/nginx_uwsgi.socket文件没有读写权限,即运行Nginx工作进程的用户需要socket文件的读写权限。

运行Nginx的工作进程的用户在/etc/nginx/nginx.conf中有配置,是user的值www-data,但查看/etc/group发现www-data是个用户组

user www-data;
worker_processes auto;
pid /run/nginx.pid;

events {
        worker_connections 768;
        # multi_accept on;
}

我们可以将www用户加入该用户组

usermod -G www-data www

也可以将socket文件及其上级目录pro的用户组改为www-data,并为该用户组授予读写权限

chown :www-data ~/home/work/project/pro
chown :www-data ~/home/work/project/pro/nginx_uwsgi.socket
chmod  ~/home/work/project/pro/nginx_uwsgi.socket

5.Nginx和Django静态文件处理

Django项目可以正常打开,但是静态文件引用路径还有问题,在Django开发时Django自己可以正确处理静态文件的路径,但是部署后Nginx去无法找到静态文件路径。

检查Nginx配置文件夹sites-enabled里的nginx-pro文件,确保里面默认的try_files要删掉或者注释掉,否则Nginx会因此检查静态文件是否存在。

将Django的静态文件集中起来,Django为此有专门的工具

现在Django的Settings文件中加上StATIC_ROOT,把静态文件都集中到这个路径下

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

执行命令

python3 ./manage.py collectstatic

这样所有Django前后台的静态文件都会集中到项目文件夹pro下static中,另外nginx-pro其中一个配置location /static即可让Nginx来处理静态内容。

转载于:https://www.cnblogs.com/qingspace/p/6838747.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: NginxuWSGI部署Django应用程序的两个重要组件。Nginx是一个高性能的Web服务器,可以作为反向代理服务器,将请求转发到uWSGI服务器。uWSGI是一个Web服务器网关接口,可以将Django应用程序与Web服务器连接起来。 要部署Django应用程序,首先需要安装NginxuWSGI。然后,将Django应用程序配置为uWSGI服务器可以识别的格式。最后,将Nginx配置为反向代理服务器,将请求转发到uWSGI服务器。 具体步骤如下: 1. 安装NginxuWSGI 在Linux系统中,可以使用包管理器安装NginxuWSGI。例如,在Ubuntu系统中,可以使用以下命令安装: sudo apt-get install nginx uwsgi uwsgi-plugin-python3 2. 配置Django应用程序 将Django应用程序配置为uWSGI服务器可以识别的格式。可以创建一个uwsgi.ini文件,指定Django应用程序的路径和其他配置参数。例如: [uwsgi] module = myproject.wsgi:application env = DJANGO_SETTINGS_MODULE=myproject.settings master = true processes = 5 socket = /tmp/myproject.sock chmod-socket = 664 vacuum = true 3. 启动uWSGI服务器 使用以下命令启动uWSGI服务器: uwsgi --ini uwsgi.ini 4. 配置NginxNginx配置为反向代理服务器,将请求转发到uWSGI服务器。可以创建一个nginx.conf文件,指定Nginx的配置参数。例如: server { listen 80; server_name example.com; location / { include uwsgi_params; uwsgi_pass unix:/tmp/myproject.sock; } } 5. 启动Nginx服务器 使用以下命令启动Nginx服务器: sudo service nginx start 完成以上步骤后,就可以通过访问Nginx服务器的IP地址或域名来访问Django应用程序了。 ### 回答2: Django是一个优秀的Python Web框架,可以快速、高效地开发Web应用程序。为了将Django应用程序部署到生产环境中,必须选择一个适合的Web服务器和应用服务器。nginxuwsgi是目前最流行的Web服务器和应用服务器之一。 部署Django应用程序通常需要使用一个Web服务器来处理用户请求,例如静态文件请求,以及一个应用服务器来处理动态请求和逻辑处理。nginx作为一个高性能的反向代理和Web服务器,能够提供快速的静态文件服务,并能够处理大量的并发请求。uwsgi则是一个WSGI应用服务器,用于处理Django应用程序的动态请求。 下面是nginxuwsgi部署Django的一般流程: 步骤一:安装和配置uwsgi 1. 使用pip安装uwsgi `pip install uwsgi` 2. 创建uwsgi配置文件 创建一个名为uwsgi.ini的配置文件。文件内容可以参考以下示例: ``` [uwsgi] chdir=/path/to/your/project module=project.wsgi:application home=/path/to/virtualenv/ master=True processes=4 socket=127.0.0.1:8001 vacuum=True ``` 配置文件中,chdir指定Django项目的根目录,module指定Django的WSGI接口,home指定虚拟环境的路径,master指定uwsgi是否以主进程方式运行(建议设置为True),processes指定子进程的数量,socket指定uwsgi监听的IP地址和端口号,vacuum指定uwsgi退出时是否清理UNIX套接字的文件。 3. 在命令行中启动uwsgi `uwsgi --ini /path/to/your/uwsgi.ini` 4. 测试uwsgi是否正常工作 可以使用浏览器或curl等工具访问uwsgi绑定的IP和端口。如果看到Django应用程序的欢迎页面,则说明uwsgi正常工作。 步骤二:安装和配置nginx 1. 使用apt-get或yum等包管理工具安装nginx `apt-get install nginx` 2. 创建nginx配置文件 创建一个名为myproject的配置文件。文件内容可以参考以下示例: ``` server { listen 80; server_name yourdomain.com; access_log /var/log/nginx/access.log; error_log /var/log/nginx/error.log; location / { include uwsgi_params; uwsgi_pass 127.0.0.1:8001; } location /static { alias /path/to/your/project/static; } } ``` 配置文件中,server_name指定nginx要监听的域名或IP地址,access_log和error_log分别指定nginx的访问日志和错误日志的路径,location /指定nginx如何处理动态请求,包括使用uwsgi_params配置文件和uwsgi_pass指令将请求转发到uwsgi服务器。location /static则指定nginx如何处理静态文件请求。 3. 启动nginx `service nginx start` 4. 测试nginx是否正常工作 可以使用浏览器或curl等工具访问nginx绑定的IP和端口。如果看到Django应用程序的欢迎页面,则说明nginxuwsgi已经正常工作,Django应用程序已经成功部署。 总结 以上就是使用nginxuwsgi部署Django应用程序的一般流程。我们需要先安装和配置uwsgi,然后配置nginx,最后启动nginxuwsgi,并测试应用程序是否正常工作。如果需要将Django应用程序部署到生产环境中,还需要学习更多的部署技巧和经验,例如负载均衡、安全加固等。 ### 回答3: Django是一款非常流行的Web框架,而NginxuWSGI则是常见的Web服务器和Python应用程序服务器。这三个工具可以结合起来,用于部署和运行Django应用程序。 首先,我们需要将Django应用程序部署到一台服务器上,例如Ubuntu或CentOS。我们可以使用Git等工具来完成此操作。同时,我们需要在服务器上安装Python虚拟环境。Python虚拟环境可以为每个应用程序提供独立的Python环境,从而避免干扰其他应用程序。安装虚拟环境后,我们可以使用pip来安装Django和其他依赖项。 接下来,我们可以使用uWSGI来作为Django应用程序的Python应用程序服务器。uWSGI支持多种协议,例如HTTP和WebSocket。我们可以使用以下命令来启动uWSGI: ``` uwsgi --http :8000 --module mysite.wsgi --venv /path/to/venv ``` 这里,我们使用“http”协议并指定端口号8000。我们还指定了Django应用程序的入口点,即wsgi.py文件。最后,我们指定了Python虚拟环境的路径。当我们运行此命令时,uWSGI将启动一个Web服务器,该服务器将使用8000端口来监听HTTP请求,并将请求转发给Django应用程序。 最后,我们可以使用Nginx来作为反向代理服务器,以将uWSGIDjango应用程序连接到外部Internet。Nginx支持负载平衡和HTTPS等特性。我们可以使用以下Nginx配置文件来配置反向代理服务器: ``` server { listen 80; server_name example.com; location / { include uwsgi_params; uwsgi_pass unix:/tmp/uwsgi.sock; } location /static/ { alias /path/to/static/; } } ``` 这里,我们定义了一个名为example.com的虚拟主机来监听HTTP请求。我们将所有请求转发到uWSGI服务器的Unix套接字上,该套接字默认为/tmp/uwsgi.sock。另外,我们还配置了一个用于提供静态文件的路径。 使用此配置文件后,我们可以启动Nginx服务器,从而将所有来自外部Internet的请求都转发到Django应用程序上。此时,我们就成功地使用NginxuWSGI部署Django应用程序,从而使其能够运行在Web服务器上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值