Nginx + uWSGI 部署Django站点

作者 : 开心源码 本文共4121个字,预计阅读时间需要11分钟 发布时间: 2022-05-11 共28人阅读

Django有Apache和Nginx两种常见部署方式

主要工具:

  • 一台远程服务器

  • Nginx

  • uWSGI

  • Django

知识点:

  • 站点结构

  • Nginx结构

  • debug方式

主机用的是DigitalOcean家的基础版ubuntu,版本16.01。

从裸机开始的环境准备

1. 基础环境

zsh,oh-my-zsh,vimrc从github上pull过来,一切都是熟习的感觉。

apt-get 要升级。

2. Python3/pip 和 虚拟环境

主要是为了环境简洁和适应版本

3. Nginx

远程服务器这个是第一步的,没有服务器,开发调试都是头疼的事情。Nginx是一款反向代理商服务器,能让网站的内容呈现给用户。

启动后访问服务器ip,会看到**Welcome to nginx!**信息。

4. uWSGI

uWSGI是实现了WSGI的服务器。WSGI一个Web接口。提供规范化协议,提高服务器的工作效率。uWSGI本身已经能胜任服务器的工作,为什么要再前面挡一个Nginx,这是出于更好的安全性,更有效率的工作和Nginx作为专业的服务器的优势。

使用wWSGI挂起一个最简单的程序,创立一个文件命名test.py

# test.py

def application(env, start_response):

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

#return [“Hello World”] # python2

return [b”Hello World”] # python3

使用wWSGI挂起:

Nginx + uWSGI 部署Django站点

这条命令是说,用http协议,8000端口,加载指定文件。文件很简单,收到GET请求后,返回`Hello World`,在浏览器输入`ip:8000`即可以看到结果了。

5. 安装Django

6. 同步数据库

python manage.py makemigrations

python manage.py migrate

7. 开发服务器

python manage.py runserver #localhost

python manage.py runserver 0.0.0.0:8000 #ip:8000端口

了解Nginx服务器的结构

Nginx + uWSGI 部署Django站点

Nginx 服务器结构

1. 最重要的文件:一开始就要加载

默认下,Nginx会安装在`/usr/local/nginx`,所有的配置文件在`/etc/nginx`下,最主要的配置文件是 `/etc/nginx/nginx.conf`,这个文件建议放在git上,或者者进行周期性备份

cp /etc/nginx/nginx.conf /etc/nginx/nginx.conf.$(date “+%b_%d_%Y_%H.%M.%S”)

`nginx.conf` 配置了主要的工作功可以,`include`允许从后面的地址中找到配置文件,这样能让主配置文件看起来更加精简,但是多层套使用`include`也不推荐,让代码不易读。从默认的配置文件能看出,`/etc/nginx/conf.d/`里所有的配置文件和`/etc/nginx/sites-enalbed/`里的配置文件都会在一开始被加载。log文件在`/var/log/nginx/`下。

2. HTTP板块:全局配置

HTTP 板块会解决所有来自于网络的HTTP请求,这是Nginx的大门。

重点说下`/etc/nginx/sites-enalbed/`这个目录,它能让不同的虚拟域名分开来。一般都是通过软连接将配置文件连接进这个目录,很容易修改,ngnix提供了一个配置模版:

cp /etc/nginx/sites-available/default /etc/nginx/sites-available/example.com

3. Server板块:虚拟域名的配置

在`/etc/nginx/sites-enalbed/`下配置的格式:

server {

listen 80

}

server 板块是使用户修改量最大的地方。对于每一个虚拟域名都能有不同的配置文件。`/usr/share/nginx/html`这个路径现在已经是Nginx默认存放静态文件的路径了,不需要再配置。

listen: 使用来监听端口

server_name: 自己网站的域名

能否能用不有效的域名呢?完全能,在局域网中,是一个很好的办法。

log: log文件,HTTP板块已经设置过,在server板块里能更细致。

access_log logs/example.access.log;

access_log /srv/www/example.com/logs/access.log;

建议用完全路径,相对路径是与现在的路径下部分匹配的,不好控制。

location:文件系统配置

`location`设置能让服务器去应答少量要服务器资源的请求。例如:

# http://example.com/blog/

location /blog/ { }

注意字符串的匹配是最佳匹配,Nginx会选择匹配的最好的location。更复杂的匹配情况请参照官方文件。

4. 部署一个Nginx的最小Web结构

实践是检验真理的唯一标准,这里部署一个Nginx的最小结构,看看Nginx可以不可以正常工作。

linux 新建使用户名使用于部署Nginx并赋予权限.

visudo

# 增加权限:

username ALL=(ALL) ALL

将`nginx.conf`使用户名修改为当前使用户。

在当前使用户的根目录下创立如下结构:

mysite:

– mysite.conf

– www

– media

-test.png

– log

最简单的目标就是通过ip访问网站里的静态内容。简单的配置下,注意用绝对路径:

server {

listen 8000;

server_name mysite.com

charset utf_8;

access_log /home/username/mysite/log/access.log;

error_log /home/username/mysite/log/error_log;

location /media/ {

alias /home/username/mysite/media/;

}

}

sudo ln -s /home/username/mysite/mysite.conf /etc/nginx/sites-enabled/

重启Nginx后,在 `http://mysite.com/media/test.png`可以够看到正常显示内容就说名Nginx正常工作了。log文件显示正常。

Nginx + uWSGI 部署Django站点

Nginx 最小网站结构

5 常见的错误

5.1 403 forbidden

这里就要注意下使用户名了,很多时候登录一台主机使用户是root,而Nginx使用户不是root,所以忽略了使用户名的部署多会遇到这个问题。

  • 能将Nginx的使用户名改为root,这样风险会很大。

  • 网站静态内容部署在当前使用户目录下,如列子所示。

  • 在`/usr/share/nginx/html`下部署静态文件或者软连接到网站目录。

5.2 404 notfound

一般出现这个问题是目录的配置出现问题,用绝对路径可处理

6 调试方法

最好的办法就是log文件了,每次的请求,错误记录都会非常详细。

了解Django部署结构

Nginx + uWSGI 部署Django站点

djangoe结构

1. 每个环节都要了解

到现在为止,已经能分别使用Nginx和uWSGI挂起服务器了。说明这两个部分都是通的:

Nginx + uWSGI 部署Django站点

Nginx工作结构

Nginx + uWSGI 部署Django站点

uWSGI挂起Python

2. 使用uWSGI挂起Django:

uwsgi –http :8000 –module mysite.wsgi

这里sWSGI会找到 mysite下的wsgi的配置文件,即`mysite/wsgi.py`假如看到Django的“it worked!”信息,则说明Django被成功挂起。

Nginx + uWSGI 部署Django站点

3. 通过socket连接Nginx和uWSGI

socket中文翻译为套接字,它的作使用就像一个连接器,比如说把两段水管连接起来,每段管子都有自己不同的编号,下面就来实验下套接字的作使用。

带socket的Nginx配置多了这个部分:

upstream django {

# server unit:///path/to/yourmysite/mysite.sock;

server 127.0.0.1:8022; #for a webport socket

}

这是要说明监听来自8022端口的请求,8022口做什么了呢?

uwsgi –socket :8022 –wsgi-file test.py

8022挂起了最先的python测试文件,假如有GET请求,则返回hello world。Nginx则设置为监听8023端口。通过socket,有检测到8023口的外部请求,则交给8022端口去解决,这就是socket的作使用,非常灵活。也说明了这一套结构都通了:

Nginx + uWSGI 部署Django站点

4. Django sockect

upstream django {

server unit:///path/to/yourmysite/mysite.sock;

# server 127.0.0.1:8022; #for a webport socket

}

重启Nginx,挂起uWSGI:

uwsgi –socket mysite.sock –wsgi-file test.py

在当前项目下能看到生成了空的文件mysite.sock,2023口测试通过。

最后拉起整个Django项目:

uwsgi –socket mysite.sock –module mysite.wsgi

看到Django工作界面,完成,Done!

5 常见错误

5.1 connect() to unix:mysite.sock failed (2: No such file or directory)

基本是路径设置问题,upstrem和socket都要用绝对路径。

5.2 connect() to uunix:mysite.sock failed (13: Permission denied)

增加socket权限:

uwsgi –socket mysite.sock –wsgi-file test.py –chmod-socket=664 # (more sensible)

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » Nginx + uWSGI 部署Django站点

发表回复