基于Django框架的网站部署详解
对于刚入门的同学,当完成了项目代码,在本地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框架的网站部署详解的详细内容,更多请关注其它相关文章!
上一篇: 查看Oracle CPU情况
下一篇: MySQL批量删除指定前缀表_MySQL