写在最前:
非常抱歉的是,因为突如其来的疫情,我的hadoop系列断更了,很难受,因为我的分布式环境在学校,我的笔记本配置带不起来,代码跑不起来我是不敢写博客的,然后寒假在家写代码也没啥意思,看了非常多的书,把计网和操作系统重新学了一遍。因为实习的需要,未来我更多的技术可能在Python这块,但是java相关的内容我也会努力保持更新,同时也会出更多的入门教程给大家谢谢大家。
背景:
最近在学习django的过程中,用django做了一个小demo,所以试试看能不能部署到服务器上,自己顺便也熟悉一下Django整个部署的流程,因为之前学习flask的时候,就使用的uwsgi来作为python web服务器来部署的,所以这次也就选择了nginx+uwsgi这样的一个组合。
当时买完云服务器之后,就顺手把宝塔装上了,之前用宝塔部署php项目是真的很容易,所以就偷懒试试宝塔能不能部署django,苦试一个小时,无果,遂放弃,还是老老实实用原生的uwsgi配合Nginx来部署吧。然后下面的流程我会争取把有可能是坑的地方重点标注出来,将来如果发博客或者自己需要再次部署的时候,也可以少写很多配置文件。
环境:
系统版本
:centos7.5
python
版本:3.6.5
nginx
版本:1.16.1
uwsgi
版本:2.0.18
如环境不同,还请查阅其他资料另行配置。
环境准备:
在部署之前,请确保你的linux服务器正确安装了对应的python版本,如果需要python3版本,请自行查阅资料进行升级安装。
首先为了更好的独立部署,避免对其他的项目产生干扰,我们需要安装python 虚拟环境:
sudo pip install virtualenv sudo pip install virtualenvwrapper
virtualenvwrapper 是virtualenv的扩展管理包,可以将所有的虚拟环境整合在一个目录下。
配置虚拟环境:
mkdir ~/.virtualenvs
打开.bashrc:
sudo vim ~/.bashrc
在.bashrc的末尾增加下面内容:
export WORKON_HOME=$HOME/.virtualenvs # 所有虚拟环境存储的目录 source /usr/local/python3/bin/virtualenvwrapper.sh
注意!:这里的/usr/local/bin/virtualenvwrapper.sh只是针对于我当前系统环境的一个位置,并不是所有的服务器都是在这个位置,如果自己不知道virtualenvwrapper.sh在哪里,可以搜索文件来找到它在系统中的位置,并且修改.bashrc。
启用配置文件:
source ~/.bashrc
这个时候如果不报错,就代表我们的虚拟环境配置成功了,一般常见的报错就是virtualenvwrapper.sh文件找不对。
创建虚拟环境:
找一个你自己觉得能记住的地方,新建一个env 文件夹:
cd /www mkdir env cd env #进入env目录
新建一个虚拟环境:
mkvirtualenv -p /usr/bin/python3 orange_env # my_env是虚拟环境的名称
注意:如果你的软连接/usr/bin/python3没有的话,会报错误,找不到/usr/bin/python3,这个时候就需要你自己新建一个软连接:
如果报错:
ln -s /usr/local/python3/bin/python3 /usr/bin/python3 # 路径要改成自己的python安装路径
之后便可以进入我们的虚拟环境了:
source /www/env/orange_env/bin/activate
进去虚拟环境之后,前面会出现一个括号,里面是你虚拟环境的名字:
(orange_env) [root@iz2ze1cvux96riiwfh05qqz ~]#
在虚拟环境中安装uwsgi:
pip install uwsgi
退出虚拟环境:
deactivate
再次在主环境中安装uwsgi:
pip install uwsgi
注意:如果你有其他的依赖,比如django,msqlclient这些,记得一定要在虚拟环境里pip安装一下。
部署过程:
找一个你认为比较合适的地方,新建一个文件夹,将你的Django项目上传进去:
以我为例:
cd /www mkdir orange
上传解压操作略,记得是上传项目根目录,就是直接带manage.py的那个目录。
新建一个uswgi配置文件,uswgi支持多种配置文件类型,比如yaml,xml,json,ini,这里我选的是xml。
vim mysite.xml #记得mysite.xml 要和你项目的manage.py 在一个目录下。
mysite.xml内容如下:
<uwsgi> <socket>127.0.0.1:8080</socket><!-- 内部端口,自定义 --> <chdir>/www/orange/</chdir><!-- 项目路径 --> <module>orangeproject.wsgi</module> <!-- 一般模块名 项目名+wsgi --> <processes>4</processes> <!-- 进程数 --> <daemonize>uwsgi.log</daemonize><!-- 日志文件 --> </uwsgi>
安装Nginx:
Nginx 我之前有写过一系列的基础入门教程,如果对安装启动重启这些不是很熟练的可以看下面这篇文章:
链接: 写给后端的Nginx初级入门教程:实战篇
查看nginx 配置文件路径:
nginx -t
记得备份nginx之前的配置文件,然后把之前的配置全部删了,直接加入下面内容:
worker_processes 1; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; server { listen 8000; server_name 你的域名; charset utf-8; location / { include uwsgi_params; uwsgi_pass 127.0.0.1:8080; uwsgi_param UWSGI_SCRIPT orangeproject.wsgi; uwsgi_param UWSGI_CHDIR /www/orange/; } location /static/ { alias /www/orange/transfer/static/; } } }
注意模块名要保持一致,而且你nginx监听的端口不能和你django启动的端口一样,要不uswgi会因为nginx占用端口启动失败。alias /www/orange/transfer/static/; 这个是你的静态文件地址,css,img这些。
检查nginx是否配置成功:
nginx -t
重启nginx:
nginx -s reload
之后,再次进入我们的虚拟环境orange_env中,启动我们的uwsgi服务器:
cd /www/orange uwsgi -x mysite.xml
然后打开我们的本地浏览器,输入:域名:8000,备案过的可以改nginx配置文件成80。
大功告成:
到此这篇关于Django项目uwsgi+Nginx保姆级部署教程实现的文章就介绍到这了,更多相关Django uwsgi+Nginx 部署内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!
Django项目uwsgi+Nginx保姆级部署教程实现
- Author -
韩数声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@