Django + Uwsgi + Nginx 的生产环境部署

Posted 篓子

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django + Uwsgi + Nginx 的生产环境部署相关的知识,希望对你有一定的参考价值。

安装项目依赖

pip freeze > requirements.txt

django部署生产环境静态文件设置

setting.py设置
STATIC_URL = \'/static/\'


STATICFILES_DIRS = (os.path.join(BASE_DIR, "static"), )

# specify media root for user uploaded files,
MEDIA_ROOT = os.path.join(BASE_DIR, \'media\')

MEDIA_URL = \'/media/\'

AUTH_USER_MODEL = \'user.DongYaoUser\'


STATIC_ROOT = os.path.join(BASE_DIR, \'www\') #执行python manage.py collectstatic后django会自动找到根目录的www文件夹把所有静态文件保存到www目录中

url设置
from django.conf.urls.static import serve
re_path(r\'^media/(?P<path>.*)$\', serve, {\'document_root\': settings.MEDIA_ROOT}),
re_path(r\'^static/(?P<path>.*)$\', serve, { \'document_root\': settings.STATIC_ROOT})
 

安装python3.6

Ubuntu默认安装了Python2.7和3.5

输入命令python

按Ctrl+D退出python命令行

输入命令sudo add-apt-repository ppa:jonathonf/python-3.6

按Enter确认

输入命令sudo apt-get update

输入命令sudo apt-get install python3.6

按Y确认

 

调整Python3的优先级,使得3.6优先级较高

sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.5 1

sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.6 2

更改默认值,python默认为Python2,现在修改为Python3

sudo update-alternatives --install /usr/bin/python python /usr/bin/python2 100

sudo update-alternatives --install /usr/bin/python python /usr/bin/python3 150

 

此时再输入命令python

可以看到此时已经是Python3.6了

 

更新pip3

安装

sudo apt-get install python3-pip

升级

sudo pip3 install --upgrade pip

安装mysql

1.安装命令:

sudo apt-get install mysql-server

提示:安装过程中会提示让你设置MySQL密码 ,输入两次密码,回车即可,然后等待安装完成

 
设置MySQL密码

2.查看MySQL版本:

mysql --version

提示:输出结果为:5.7.17,事实上Mysql 5.7.6或更高版本,数据目录将自动初始化,这一点大部分教程都没有提及。所以这里我们不用初始化。


 
查看Mysql版本

3.运行数据库Mysql安全配置向导:

  sudo mysql_secure_installation

提示:输入Mysql密码


 
输入root密码:

提示:是否设置验证密码,输入 n


 
是否设置验证密码,输入 n

提示:是否修改Mysql密码,输入 n


 
是否修改MySQL密码,输入 n

提示:是否移除匿名用户,输入y


 
是否移除匿名用户,选y

提示:是否允许远程登陆,如果选n的话,只能在本机访问数据库,根据情况来,本人数据库和项目都在一个服务器上,为了安全考虑,这里我设置关闭,输入n


 
设置关闭,输入 n

提示:是否移除test数据库,输入y


 
是否移除test数据库,选y

提示:是否重新加载权限表,输入y


 
是否重新加载权限表,选y

注意:如果出现这种错误:

[error: \'Can\'t connect to local MySQL server through socket \'/var/run/mysqld/mysqld.sock\' (2)\']

它表明你的Mysql服务,并没有开启!输入下列命令开启即可:

sudo service mysql start 

sudo表明以管理员权限执行,教程:如何启动/停止/重启MySQL

4.配置Mysql默认字符集

提示:此时当前目录为根目录,进入 /etc/mysql/,打开 my.cnf。

不太熟悉vi命令的同学看这里:linux下vi命令大全

cd /etc/mysql/
vi my.cnf

按一下 i 代表输入操作,填入以下代码:

[client]
port = 3306
socket = /var/lib/mysql/mysql.sock
default-character-set=utf8

[mysqld]
port = 3306
socket = /var/lib/mysql/mysql.sock
character-set-server=utf8

[mysql]
no-auto-rehash
default-character-set=utf8

提示:编辑完成后按一下键盘 ESC 输入:wq,代表保存退出,然后重启mysql服务使其生效:

sudo service mysql restart

5.创建网站的数据库:

提示:进入mysql shell:

mysql -uroot -p

提示:输入Mysql密码,登陆即可,如图所示登录无问题:

 
登陆成功界面

提示:接下来创建数据库并指定编码方式为UTF-8(其中dataname 为数据库名称,保证与Django连接数据库名称一致,否则连接会出错):

 CREATE DATABASE `dataname` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

提示:数据库操作基本命令:

SHOW DATABASES; #显示所有数据库
USE <NAME>;   #进入某数据库 
SHOW TABLES; #显示所有数据表
SELECT * FROM <NAME>; #查询表内容

多余的不说了,忘记的看看:mysql基本操作命令汇总

退出命令:quit 退回根目录 :cd

 

使用runserver可以使我们的django项目很便捷的在本地运行起来,但这只能在局域网内访问,如果在生产环境部署django,就要多考虑一些问题了。比如静态文件处理,安全,效率等等,本篇文章总结归纳了一下基于uwsgi+nginx下django项目生产环境的部署

准备条件:

1
2
1.确保有一个能够用runserver正常启动的django项目
2.项目已上传到linux <br>3.linux上已部署好python环境,且已安装好项目所需的模块

安装uwsgi

  uwsgi是python的一个模块,安装uwsgi只需简单的pip命令就可以了

安装python-dev包

sudo apt-get install python3.6-dev
1
pip3 install uwsgi

基于uwsgi+django的实现

 1.使用命令启动uwsgi

  第一步:进入django项目

  第二步:命令测试启动

1
uwsgi --http 192.168.31.123:8080 --file teacher/wsgi.py --static-map=/static=static

  

  参数说明:

--http 这个就和runserver一样指定IP 端口
--file 这个文件就里有一个反射,如果你在调用他的时候没有指定Web Server就使用默认的
-- static 做一个映射,指定静态文件

  此时,访问http://192.168.2.108:8080/,如图所示,表示项目启动成功

以上是关于Django + Uwsgi + Nginx 的生产环境部署的主要内容,如果未能解决你的问题,请参考以下文章

通过 Nginx 的 uwsgi + django - uwsgi 设置/生成?

转载nginx+uwsgi+django

Django+Nginx+uWSGI = 504 网关超时

uWSGI + Nginx + Django 部署

Django + Uwsgi + Nginx 实现生产环境部署

Django + Uwsgi + Nginx 实现生产环境部署