欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

基于Django框架的网站部署详解

程序员文章站 2022-03-21 20:51:42
...
对于刚入门的同学,当完成了项目代码,在本地localhost的调试没问题后,会遇到如何让项目上线的问题。
网上的资料过于繁杂,因此希望这篇能简单地为刚入门的同学解惑。

1.域名

    首先,当我们输入一个网址http://www.example.com/时,首先经过DNS解析到对应的IP地址,从而对该IP实现访问。所以,要让别人访问我们项目的第一步,就是需要拥有两样东西,域名和公网ip。
    域名的获得很简单,随便注册购买一个就好了。然后需要的是将域名解析到你的公网ip。而公网ip,一般在购买云服务器的时候能获得。
    经过这一步,我们实现了:请求-->DNS-->服务器ip,而我们的最终目的就是:请求-->DNS-->服务器ip-->黑盒子-->项目wsgi应用

2.使用gunicorn运行项目

    在此,我们使用django搭建项目,当你的项目完成后。我们需要运行监听请求,接收请求并调用相应的wsgi应用的服务程序。例如执行python manage.py runserver 0.0.0.0:8000,runserver 就是django 自带的用于调试的基于wsgi的服务程序。

在云服务器上我们创建一个项目

django-admin.py startproject blog

其中wsgi.py

import os
import sys
# 当使用virtualenv等隔离项目环境时,需要将项目的路径添加添加到查找路径中
path = os.getcwd()
if path not in sys.path:
    sys.path.append(path)

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "blog.settings")
from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()

我们在项目下执行以下命令

gunicorn wsgi:application

默认绑定127.0.0.1:8000,具体gunicorn 的使用可以自行google一下
此时,我们能就能通过本地8000端口来访问我们的项目内容了。实现了:请求-->DNS-->服务器ip-->黑盒子-->127.0.0.1:8000-->项目wsgi应用

3.nginx接收外部请求,内部转发

在/etc/nginx/sites-available/文件夹下,新建一个文件blog,并添加如下简单设置

server {
    listen 80;
    server_name  你的域名 你的公网ip(可选);
    access_log  /var/log/nginx/blog.log;
    location /static {
        #静态文件如js,css的存放目录
        root /project/blog;
    }
    location / {
        include proxy_params;
        # 从外部接收请求后转发到本地的8000端口
        proxy_pass http://127.0.0.1:8000;
    }
}

从上面我们就可以明白,nginx 接收到请求后,转发给gunicorn正在监听的本地8000端口,gunicorn根据请求调用项目中相应的应用函数后返回结果。
自此我们就基本实现了请求-->DNS-->服务器ip-->nginx(80端口)-->127.0.0.1:8000-->项目wsgi应用
而关于nginx和gunicorn的具体配置还有许多,不妨多google一下延伸学习

4.总结

gunicorn让项目跑起来
nginx负责接收请求和转发请求到运行中项目监听请求的端口
部署到线上,主要需要域名,公网ip,二者均可以通过云服务器来解决,所以最好还是直接买个云服务器实践一下,just do it

以上就是基于Django框架的网站部署详解的详细内容,更多请关注其它相关文章!

相关标签: Django框架