Django应用的部署不同于node或者javaweb应用,对初学者来说部署具有一定的难度,本文就ubuntu16.04来讲讲具体部署细节,若有问题欢迎大家提issue讨论。
官方文档上建议初学者使用apache部署django应用,本人并不建议,apache部署太麻烦,还要配置虚拟主机什么的,但nginx就相对来说简单多了。也便于理解。
一.安装Django
sudo apt install python3-pip #安装pip
pip -v # 查看pip的版本
pip install django #默认安装最新的django版本
当然安装前需要更新一下系统的文件
sudo apt update
二.安装uWSGI
sudo apt install build-essential python3-dev #安装依赖项
pip install uwsgi
然后呢你也可以直接查看官方文档对uwsgi这个东西深入了解,也可以直接略过,只学习怎么使用就可以。
三.安装nginx
这里推荐官方的通过命令安装而不是编译安装 官方安装指南
1.下载nginx_signing.key文件
wget https://nginx.org/keys/nginx_signing.key
2. apt-key的添加:
sudo apt-key add key nginx_signing.key
3.将nginx添加至ubuntu的配置源列表里面
sudo vim /etc/apt/sources.list
添加以下两行进入sources.list文件中
deb http://nginx.org/packages/ubuntu/ xenial nginx #xenial是系统的Codename '使用命令 sudo lsb_release -a 查看'
deb-src http://nginx.org/packages/ubuntu/ xenial nginx
4.更新系统并安装最新的nginx版本
sudo apt update
sudo apt install nginx
5. 查看是否安装成功
nginx -v #写文章时版本号为1.12.0
四.部署django应用
1.配置nginx配置文件配置转发请求(配置文件默认路径 /etc/nginx/nginx.conf)
配置前建议先了解一下nginx默认的全局配置文件nginx.conf内容,当然最主要的是看看include命令。nginx整合其他部分的配置文件都是通过include命令来导入的。在本人的nginx.conf文件里有这么一句
include /etc/nginx/conf.d/*.conf
意思是nginx启动的时候还要导入/etc/nginx/conf.d目录下的所有以.conf结尾的配置文件,所以我们的配置
文件就建立在这个目录下了
vim /etc/nginx/conf.d/nginx_uwsgi.conf
文件内容:
upstream django {
server unix://django_project_absolute_url/project_name.sock; #这个.sock文件不存在也没关系,启动的时候会自动创建
#例如我的项目的绝对路径为/home/floder/crawler 这行就是 server unix:///home/floder/crawler/crawler.sock
}
# 配置转发服务器
server {
# 应用监听端口
listen 80;
# 允许访问的域名 没有域名的话就写服务器的公网ip地址
server_name .crawler.site; #这是我的一个django项目,项目访问地址为 http://crawler.site ,欢迎访问使用
charset utf-8;
#访问日志
access_log /var/log/nginx/project_name_access.log;
#错误日志
error_log /var/log/nginx/project_name_error.log;
# 最大上传文件大小
client_max_body_size 75M;
# 配置静态文件的请求
location /static {
alias /static_files_absolute_url; #项目静态文件地址,使用python3 manage.py collectstatic 将静态文件收集到settings.py文件配置的STATIC_ROOT目录下
}
# 配置django应用的转发请求
location / {
uwsgi_pass django;
include /etc/nginx/uwsgi_params; # 这个uwsgi_params文件的地方,默认在/etc/nginx目录下随nginx一起被安装
}
location /favicon.ico{
alias /favicon.ico_absolute_url; #网站图标地址
}
#这里还可以配置许多独立的请求地址,只要找到对应的静态资源地址即可
#location /xxx.html{
# alias /xxx.html_absolute_url;
#}
}
接下来重启nginx服务
sudo /etc/init.d/nginx restart #nginx服务默认安装完就自动启动了
如果重启遇到错误的话可以按照提示查看错误原因,大部分原因都是由于配置文件写错了(比如语句末尾没有分号...)
2.配置uwsgi启动文件(.ini格式的文件 以我的项目为例)
这个文件我一般是将它放在django项目的根目录下面,这里假设文件名为crawler_uwsgi.ini 内容如下:
# 项目的uwsgi配置文件
[uwsgi]
# Django-related settings
# 项目的绝对路径(以我的为例)
chdir = /home/floder/crawler
# django的wsgi文件,默认是在项目的根目录的主文件夹下面
module = crawler.wsgi
# python包的绝对目录,这是python3.5版本的包管理路径
pythonpath = /usr/local/lib/python3.5/dist-packages
# 后台运行时打印日志的地方
daemonize = /home/floder/log/crawler_uwsgi.log
# 是否开启主线程
master = true
# 最大工作进程
processes = 10
# .sock文件的地址(因为django的应用请求配置的是sock请求)
socket = /home/floder/crawler/crawler.sock #项目的根目录下(和)
# 给予.sock文件的执行权限
chmod-socket = 666
# 退出时是否清除工作环境
vacuum = true
3.后台启动项目
uwsgi --ini crawler_uwsgi.ini
若项目启动之后访问出错,查看uwsgi的log文件查看出错的原因
五.服务器的选择
学生的话项目不需要翻墙可以去使用腾讯的云服务器,特别便宜。非学生党或者项目需要翻强的话推荐digitalocean服务器,这里给的链接点击进入可以自动获得$10供你熟悉使用。digitalocean 服务器的优点如下(具体费用和你选择的配置有关 $5起步):
(1)可以同时新建多个云主机(droplets),按流量收费。
(2)和github一样,只要在创建主机的时候将本机的ssh公钥添加进新创建的主机里面,就可以直接通过ssh连接而不用输入密码了(创建ssh密钥的石斛要求输入密码验证的除外)。
(3) digtialocean有各种已经配置好的各种编程语言环境的web项目主机比如django,lamp,nodeJS等等,就不需要你继续一个个的像上面介绍的一样安装运行环境了(缺点就是比较老,不推荐)。
(4)可选节点多达8个,总有一个满足你的要求.
通过ssh登录主机的第一件事是更新软件源
sudo apt update
默认是root用户登录的,为了安全起见,我们首先新建一个用户
adduser floder #floder是用户名
设定密码、回答完相关问题之后,名为 jerry 的帐号就建好了。把它加到 sudo 权限组:
usermod -a -G sudo floder
这时候可以通过 su floder
切换到新帐号下工作
补充: ubuntu通过scp命令上传文件或者文件夹到服务器 scp命令的使用