小白学Django系列:
- 小白学Django第一天| MVC、MVT以及Django的那些事
- 小白学Django第二天| Django原来是这么玩的!
- 小白学Django第三天| 一文带你快速理解模型Model
- 小白学Django第四天| Django后台管理及配置MySQL数据库
- 小白学Django第五天| 视图View的初步使用
- 小白学Django第六天| 一文快速搞懂模板的使用
- Django实战小型图书人物信息网页(MVT的综合运用)
- 小白学Django第七天| 模型类Model进阶学习
- 小白学Django第八天| 登录案例实战
- Django| 给你博客装个Markdown编辑器
- 小白学Django第九天| Cookie和session的那些骚操作
- 持续更新中...
前言
关于Django的部署,本人也踩了很多坑,这篇文章一步一步教你怎么进行部署,只需要你按照我的步骤来就OK了!这里我们使用的服务器是一个全新的服务器,没有安装任何东西。
基础环境搭建步骤
★ 注意:下面的步骤都需要在root权限下进行 ”
一、更新系统软件包
代码语言:javascript复制yum update -y
二、安装软件管理包和可能使用的依赖
代码语言:javascript复制yum -y groupinstall "Development tools"
代码语言:javascript复制yum install openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel psmisc libffi-devel
三、下载Pyhton3到/usr/local 目录
代码语言:javascript复制cd /usr/local
代码语言:javascript复制wget https://www.python.org/ftp/python/3.6.6/Python-3.6.6.tgz
★ 这里我们安装的Python是3.6.6版本,版本可以自己选择,如果版本不同,后面相应的代码也会不同!!! ”
解压python包
代码语言:javascript复制tar -zxvf Python-3.6.6.tgz
进入 Python包的路径
代码语言:javascript复制cd Python-3.6.6
编译安装到自己指定路径-/usr/local/python3
代码语言:javascript复制./configure --prefix=/usr/local/python3
安装python3
代码语言:javascript复制make
make install
安装完成之后,建立软链接,添加变量,这样的好处是方便我们在终端中能够直接使用python3
代码语言:javascript复制ln -s /usr/local/python3/bin/python3.6 /usr/bin/python3
Python3安装完成之后pip3也一块安装完成,不用再单独安装 这里给pip3也建立软链接
代码语言:javascript复制ln -s /usr/local/python3/bin/pip3.6 /usr/bin/pip3
四、查看是否成功安装Python3和pip3
代码语言:javascript复制python3 -V
pip3 -V
如图则成功
五、安装virtualenv
代码语言:javascript复制★ 建议大家都安装一个virtualenv,方便不同版本项目管理。虚拟环境这块大家可以自行百度进行了解,当然也可以直接按照我下面的步骤进行 ”
pip3 install virtualenv
我们也给它建立软链接
代码语言:javascript复制ln -s /usr/local/python3/bin/virtualenv /usr/bin/virtualenv
安装成功在根目录下建立文件夹,主要用于存放env,当然项目你也可以创建一个文件夹存放。我的项目是存放在/~/blog中的,影响不大,后面自己可以进行相关修改(我会注明)
代码语言:javascript复制mkdir -p /data/env
六、切换到/data/env/下,创建虚拟环境。
代码语言:javascript复制virtualenv --python=/usr/bin/python3 djangoenv
这里的djangoenv名称可以自己定义但是后面步骤一定要跟你所定义的名称相同,然后进入/data/env/djangoenv/bin
启动虚拟环境:
代码语言:javascript复制source activate
进入之后,你就会发现下面红框中的内容就是自己定义的名称
七、虚拟环境里用pip3安django和uwsgi
代码语言:javascript复制pip3 install django (需要指定安装和你项目相同的版本)
pip3 install uwsgi
★ uwsgi要安装两次,一次在虚拟环境中,另一次退出虚拟环境进行安装 ”
给uwsgi建立软链接
代码语言:javascript复制ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi
本地Django项目部署到服务器
上面的步骤已经将整个大致的环境安装好了,接下来我们就需要把自己本地的项目搬运上来。
一、备份本地数据库。使用Mysql数据库,要先在本地Mysql里备份导出数据,然后在服务器上安装Mysql数据库
关于在centos中安装Mysql,我会在下篇文章中写,敬请关注(里面的坑比较多,我都会总结好的)
二、在项目目录下把当前的环境依赖包导出到requirements.txt文件
代码语言:javascript复制pip freeze > requirements.txt
★ 注意:这里是在自己本地上进行的,导出你整个项目需要的依赖包 ”
三、把项目源码压缩打包。
四、把项目上传到服务器对应的目录里,解压。
这里我使用的是Fileziila软件进行上传的,大家可以自己去下载相关的ftp软件,把自己项目上传到服务器。
在服务器中解压,可以先安装支持ZIP的工具
代码语言:javascript复制yum install -y unzip zip
解压zip文件
代码语言:javascript复制unzip 文件名.zip
五、创建新的虚拟环境(参照上面基础环境步骤中的第六步)
六、进入虚拟环境,然后进入项目安装目录requirements.txt里的依赖包。
代码语言:javascript复制pip3 install -r requirements.txt
七、导入数据库到服务器。(Mysql)
关于数据库的导入步骤:
代码语言:javascript复制# 进入数据库
mysql -u root -p
# 创建与项目中相应的名称的数据库
create database kulsblog;
use kulsblog
source /你导入sql文件的目录地址
八、通过python3 manage.py runserver 运行一下项目,如果能正常启动则进行下一步,不能正常运行往上检查。
这里需要注意使用python3来执行manage.py,否则会出现报错情况!
九.配置uwsgi文件(重点!!!)
我的网站项目路径是/root/blog/kuls_blog,在项目根目录下创建 项目名称.xml (例如我的就是 kuls_blog.xml) 编辑该文件:
代码语言:javascript复制<uwsgi>
<socket>127.0.0.1:8000</socket> <!-- 内部端口,自定义 -->
<chdir>/root/blog/kuls_blog</chdir> <!-- 项目路径 -->
<module>kuls_blog.wsgi</module> <!-- mysite为wsgi.py所在目录名-->
<processes>4</processes> <!-- 进程数 -->
<daemonize>uwsgi.log</daemonize> <!-- 日志文件 -->
</uwsgi>
★ 注意里的kuls_blog,这个是wsgi.py所在的目录名。大家记得仔细看我的注释进行填写!!! ”
十、安装nginx和配置nginx.conf文件
进入home目录,执行下面命令,我这里安装的是1.13.7版本。
代码语言:javascript复制cd /home/
代码语言:javascript复制wget http://nginx.org/download/nginx-1.13.7.tar.gz
下载完成后,执行解压命令:
代码语言:javascript复制tar -zxvf nginx-1.13.7.tar.gz
进入解压后的nginx-1.13.7文件夹,依次执行以下命令:
代码语言:javascript复制./configure
make
make install
nginx一般默认安装好的路径为/usr/local/nginx
在/usr/local/nginx/conf/中先备份一下nginx.conf文件,防止我们出错。
代码语言:javascript复制cp nginx.conf nginx.conf.bak
然后打开nginx.conf,把原来的内容删除,直接加入以下内容:
代码语言:javascript复制 events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
server {
listen 80;
server_name 127.0.0.1:80; #改为自己的域名,没域名修改为127.0.0.1:80
charset utf-8;
location / {
include uwsgi_params;
uwsgi_pass 127.0.0.1:8000; #端口要和uwsgi里配置的一样
uwsgi_param UWSGI_SCRIPT kuls_blog.wsgi; #wsgi.py所在的目录名 .wsgi
uwsgi_param UWSGI_CHDIR /root/blog/kuls_blog; #项目路径
}
location /static/ {
alias /root/blog/kuls_blog/static/; #静态资源路径
}
}
}
★ 大家一定仔细看每个参数后面的注释,这里容易出错!!!这里的参数一定要和之前配置的xml文件相对应 ”
进入/usr/local/nginx/sbin/目录 执行 ./nginx -t 命令先检查配置文件是否有错,没有错就执行以下命令:
代码语言:javascript复制./nginx
终端没有任何提示就证明nginx启动成功。
★ uwsgi和Nginx两个配置,在整个部署里面是非常非常重要的,如果出现报错,一定往上面翻一翻,看看有没有哪个步骤出现问题。 ”
重点
如果修改了Django文件或者一些其他的配置,一定要重启uwsgi和Nginx,否则不会生效!
代码语言:javascript复制#查看Uwsgi进程
ps -ef|grep uwsgi
#用kill方法把uwsgi进程杀死,然后启动uwsgi
killall -9 uwsgi
#启动方法
uwsgi -x mysite.xml
#Nginx平滑重启方法
/usr/local/nginx/sbin/nginx -s reload
上面是重启uswgi和Nginx的步骤,大家每次修改之后,调用上面的方法即可。
一些注意事项
如果你的项目中的应用含有静态文件,你需要在setting.py中进行STATIC_ROOT的设置
代码语言:javascript复制STATIC_ROOT = os.path.join(BASE_DIR, 'static')#指定样式收集目录
#或
STATIC_ROOT = '/www/mysite/kuls_blog/static' #指定样式收集目录
并且执行下面的指令:
代码语言:javascript复制python manage.py collectstatic
运行这个命令之后,就会自动把静态文件收集到/static/目录下。