一学就会的django项目服务器部署nginx-uwsgi-django/build

一、前言

需要在阿里云服务器部署Django-restframework框架,一开始不清楚情况,网上找了很多的文章和办法,东拼西凑也没有能够完全实现nginx和uwsgi的互通。

想学会?

你需要找一个干干净净的、没有安装其他东西的Linux服务器(Centos系统)来跟着这篇文章做。

参考过的文章有

-视频:Nginx + uWsgi 部署 Django + Mezzanine 生产服务器

-文章:uWSGI+django+nginx的工作原理流程与部署历程

-文章:uwsgi官方文档

-文章:Django Nginx+uwsgi 安装配置

-文章:centos7 下通过nginx+uwsgi部署django应用

二、网上文章的遗漏

因为是东拼西凑,所以无论是网上的文章还是自己拼凑的配置,都是没有办法打通的。后来红包求助,才了解到有这几个地方:

1、nginx执行权限

2、uwsgi配置

3、uwsgi设置虚拟环境

4、uwsgi安装问题及插件安装问题

5、django静态文件收集处理

三、部署安装记录

1、创建非管理员账户

由于安全需求,还是配置一个非管理员(自己操作,增加sudo授权)账户操作,通过命令创建用户名密码

adduser quinns  # 新增用户

passwd quinns  # 为quinns设置密码

设置好之后,还需要开启sudo权限,通过命令:

vi /etc/sudoers

然后找到有 root ALL=(ALL)那一行,然后在下面增加一行:

quinns ALL=(ALL)  ALL

保存即可。

下面的操作,用新用户quinns登录来操作。

2、安装依赖

uwsgi和nginx以及anaconda的安装会存在一些报错问题,这里为了避免出现这情况,所以先安装好依赖。

sudo yum install gcc-c++

sudo yum install wget openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel

sudo yum install uwsgi-plugin-python

sudo yum install libxml*

sudo yum install -y bzip2

sudo yum -y install pcre-devel

sudo yum install python-devel

sudo yum install build-essential python-dev

3、安装软件

通过quinns账户登录,然后到quinns用户目录(/home/quinns)下新建一个utils目录,把一些软件下载在utils目录下。

3.1安装anaconda

通过wget方式下载anaconda(官网)

wget https://repo.continuum.io/archive/Anaconda3-5.0.1-Linux-x86_64.sh

如果想更快,就安装国内源(清华镜像):

wget https://mirrors.tuna.tsinghua.edu.cn/anaconda/archive/Anaconda3-5.1.0-Linux-x86_64.sh

下载好之后sh安装

sh Anaconda3-5.0.1-Linux-x86_64.sh

一路默认,到之后面安装完的时候会提示是否添加环境变量,输入yes即可。

如果想要后面使用更快,可以更改仓库镜像:

conda config --add channels https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/free/
conda config --add channels https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/main/
conda config --set show_channel_urls yes

这样的话安装软件都是国内源,速度比较快

3.2验证是anaconda否成功安装

通过命令:

conda list

来验证是否成功安装并加入环境变量,如果出现list列表则代表成功,如果出现报错提示信息则需要用命令:

source ~/.bashrc

来添加,然后重复conda list命令。如果还是不行,则编辑/etc/profile文件,在底部添加环境变量及指向:

export PATH=/home/quinns/anaconda3/bin:$PATH

通过文件添加的环境变量需重启服务器才能生效

3.3安装uwsgi

在确认安装好anaconda之后,先不着急新建虚拟环境,直接在linux下输入python,检查默认python是否已自动替换为python3.6。接着通过pip安装uwsgi:

pip install uwsgi

待有安装成功的提示出来,再通过命令:

uwsgi --version

来确认是否成功安装。

3.4创建虚拟环境

通过anaconda来创建python虚拟环境:

conda create --name envname python=3.6.3

(亲身经历 3.6.5无法启动uwsgi,最好还是3.6.3)

观察过程,无报错即完成安装。

3.5安装nginx

直接通过yum来安装nginx即可,如果想安装新版,可以在网上寻找新方法。

sudo yum install nginx

安装完成后应该是自动启动服务,在浏览器输入ip即可访问nginx的欢迎页面。如果没有,通过命令:

sudo service nginx start/restart

来启动或者重启nginx服务。

3.6安装mysql

先下载mysql的repo源

wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm

接着安装mysql-community-release-el7-5.noarch.rpm包

sudo rpm -ivh mysql-community-release-el7-5.noarch.rpm

安装这个包后,会获得两个mysql的yum repo源:/etc/yum.repos.d/mysql-community.repo,/etc/yum.repos.d/mysql-community-source.repo。

最后执行安装

sudo yum install mysql-server

3.7重置mysql密码

先授权

sudo chown -R root:root /var/lib/mysql

service mysqld restart  # 然后重启

接着重置密码

mysql -u root  //直接回车进入mysql控制台
mysql > use mysql;
mysql > update user set password=password('quinns') where user='root';
mysql > exit;

service mysqld restart  # 然后再重启一次服务

3.8开启远程访问

mysql默认是不开启远程访问的,想要在本地连接服务器的mysql,必须开启:

mysql -u root -p

mysql> use mysql;
mysql> update user set host = '%' where user = 'root';

service mysqld restart  # 这里也要重启一次服务

(过30秒或者1分钟再测试远程连接)如果不行的话,接着重启服务一次。

四、uwsgi服务测试

安装好这些软件后,需要确保独立服务都是正常运行的。

在/home/quinns目录下新建wwwroot目录,然后在里面新建一个测试文件uwsgitest.py

def application(env, start_response):
    start_response('200 OK', [('Content-Type','text/html')])
    return [b"Hello World, This uwsgi server is running"]

保存后通过命令来启动

uwsgi --http :8000 --wsgi-file uwsgitest.py

看到服务启动后,就可以在浏览器访问8080端口,如果能够正常显示文字内容,则代表uwsgi单独服务是可以正常运行的。如果没有,根据报错找原因。

五、上传django-rest项目

可以在本地,通过ssh对服务器进行连接,其中也包括上传下载服务。

本地打开终端后输入:

scp -r djangoName quinns@47.98.xxx.xxx:/home/quinns/wwwroot

将当前目录的djangoName文件夹通过quinns账户上传到/home/quinns/wwwroot目录内。回车执行后输入quinns的密码即可看到上传到指定的wwwroot目录内。

六、配置django

本地开发环境下的django和服务器的设置有些许不一样。

首先要开放ALLOWED_HOSTS,使得程序可以远程访问,然后再设置静态文件,最后再通过命令来测试是否可以顺利启动。

开启drf远程访问及静态设置

找到django项目的settings.py文件,里面有个ALLOWED_HOSTS,是接收一个空列表,现在要将服务器地址或者域名添加进去(也可以放*号,代表所有都可以指向这里,但是不推荐这么做):

ALLOWED_HOSTS = ['47.98.xxx.xxx']

上面就算是开启了远程访问,接着设置静态(drf有一些样式,如果不设置,通过uwsgi启动是无法加载的)。同样是在settings.py文件中,下部分代码中有个STATIC_URL = '/static/',在它下面新增一行:

STATIC_ROOT = os.path.join(BASE_DIR, "static/")

保存文件,然后在虚拟环境下执行命令:

python manage.py collectstatic

这样django就会收集静态文件,放到指定目录内,也就是(static目录内)

七、编写uwsgi配置

uwsgi可以通过命令来启动django项目,也可以通过配置文件ini或者xml来启动。这里已ini为例。

在项目根目录(manage.py同目录,其实哪个目录都可以,这里是方便寻找)新建文件夹conf,然后再在conf下新建uwsgi文件夹(这俩文件夹什么名字无所谓)。接着新建uwsgi的配置文件,这里暂且叫做lagou_uwsgi.ini 里面写上uwsgi与项目的配置信息:

ite_uwsgi.ini file`
    [uwsgi]

    # Django-related settings
    # the base directory (full path)
    chdir           = /home/quinns/wwwroot/GamesAPI
    # Django's wsgi file
    module          = GamesAPI.wsgi
    # the virtualenv (full path)

    # process-related settings
    # master
    master          = true
    # maximum number of worker processes
    processes       = 4
    threads         = 2
    # the socket (use the full path to be safe
    socket          = 127.0.0.1:8001
    # ... with appropriate permissions - may be needed
    # chmod-socket    = 664
    # clear environment on exit
    vacuum          = true
  virtualenv = /home/quinns/anaconda3/envs/envgames
    python-autoreload=1

    logto = /home/quinns/wwwroot/GamesAPI/uwsgilog.log

    stats = %(chdir)/conf/uwsgi/uwsgi.status
    pidfile = %(chdir)/conf/uwsgi/uwsgi.pid

具体的含义在uwsgi文档都有,这里记录一下:

chdir # 项目绝对路径

module  # 项目内的uwsgi.py文件,其实与项目同名即可

master

processes

threads

socket # 服务启动地址及端口

vacuum

virtualenv # 这个就很重要了,python虚拟环境地址

python-autoreload=1 # python自启动

logto # 自动生成日志文件及存放路径

stats

pidfile

这就算是编写好uwsgi的配置文件了,接着编写nginx的配置。

八、单项目nginx配置

最好不要改动原有的ningx,来新建一个新的.conf配置文件吧。同样在项目目录的conf目录内新建nginx文件夹,然后再在nginx文件夹里新建lagou.conf配置文件,里面写上nginx的配置:

upstream games {
# server unix:///path/to/your/mysite/mysite.sock; # for a file socket
server 127.0.0.1:8001; # uwsgi的端口
}
# configuration of the server

error_log  /home/quinns/wwwroot/nginxerror.log;#错误日志
server {
# the port your site will be served on
listen      8080;
# 端口
server_name 47.98.xxx.xxx ; # 服务器ip或者域名
charset     utf-8;

# max upload size
client_max_body_size 75M;   # adjust to taste


# Django media
location /media  {
    alias  /home/quinns/wwwroot/GamesAPI/media;  # 指向django的media目录
}

# Django static
location /static  {
    alias  /home/quinns/wwwroot/GamesAPI/static;  # 指向django的static目录
}

# Finally, send all non-media requests to the Django server.
location / {
    uwsgi_pass  games;
    include     uwsgi_params; # uwsgi服务
}
}

里面都有说明了,我就不写了。其的upstream games中的games是自定义名称,但是要与下面的uwsgi_pass games中games名称相同。

注意: .conf文件建立好后,要与让nginx知道并承认,所以需要通过软连接来链接到/etc/nginx/conf.d/目录下,如果不知道软连接怎么做,可以把这个文件copy到这个目录下。

然后重启服务器

sudo service nginx restart

如果没有报错,应该就是可以了。

如果有报错,没有重启ng服务器,那肯定是配置文件写错了,得去看一下。

九、启动项目

既然uwsgi也配置好了,django项目的虚拟环境也pip install -r requirements.txt过了,ng的配置文件也写好了。那就可以启动服务了。

nginx的服务启停

通过linux命令来进行启停

sudo service nginx restart/start/stop

如果之前启动过,就不用重启了。

uwsgi启动项目

找到刚才编写的lagou_uwsgi.ini配置文件目录,通过命令来启动:

uwsgi -i lagou_uwsgi.init &

如果没有报错,就代表启动了。就可以在浏览器访问之前.conf配置文件配置的8080端口了。

十、nginx配置静态

后端api没有问题后,前端也要部署。

前端通过npm run build打包之后,将build文件通过ssh上传到wwwroot目录下:

scp -r build quinns@xx.xx.xx.xx:/home/quinns/wwwroot

等到上传完成后,就到nginx那里进行静态的部属配置

cd /etc/nginx

然后打开nginx.conf文件进行编辑。

首先要给nginx文件进行访问授权,否则有些目录是会报错403的。其配置文件中有:

user nginx;

这里得给他改成用户的权限,如quinns或者root

user quinns;

看到server部分的代码:

server {
    listen       80 default_server;
        listen       [::]:80 default_server;
        server_name  _;
        root         /usr/share/nginx/html;
        
        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        location / {

        }
……
    ……
}

是这样的,访问网址80端口默认指向/usr/share/nginx/html目录下的index.html

因为静态打包后build也是由index.html来作为主入口的。所以这里只需要把root的指向改过来即可:

server {
    listen       80 default_server;
        listen       [::]:80 default_server;
        server_name  _;
        #root         /usr/share/nginx/html;
        root          /home/quinns/wwwroot/build;
        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        location / {

        }
……
    ……
}

将原来的root指向注释掉,增加build文件夹的指向

然后重启nginx服务,打开浏览器访问,就可以看正常的页面了。

心中一阵窃喜,这个坑终于是填上了。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 210,835评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 89,900评论 2 383
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,481评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,303评论 1 282
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,375评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,729评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,877评论 3 404
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,633评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,088评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,443评论 2 326
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,563评论 1 339
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,251评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,827评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,712评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,943评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,240评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,435评论 2 348

推荐阅读更多精彩内容