目录[-]

CentOS+nginx+uwsgi部署Django项目

写一个部署文章,为以后做部署项目做个参照。

系统我这边安装的是CentOS 7.9,环境为uwsgi+nginx+python3+django2.2

下面开始写部署的详细步骤

一. 升级你的软件并安装软件管理包和所用的依赖

依次在shell运行下面的命令行即可,升级安装比较花时间,请耐心等待一下

[root@echo /]# yum update -y
[root@echo /]# yum -y groupinstall "Development"
[root@echo /]# yum install openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel psmisc libffi-devel

二. 下载python3并安装

有些Linux系统中,都是自带python和python3的,如果你的系统中只有python2.17而没有python3,那就安装一个,这里选用最新版python3.9.1,这里有个汇总所有python版本的地址:https://www.python.org/ftp/python/

# 我一般喜欢在/usr/local路径下放所有下载的软件包,这样直接统一进行管理
[root@echo /]# cd /usr/local/
[root@echo local]# wget https://www.python.org/ftp/python/3.9.1/Python-3.9.1.tgz

下载完安装包后进行解压

[root@echo local]# tar -zxvf Python-3.9.1.tgz

进入Python-3.9.1文件夹

[root@echo local]# cd Python-3.9.1 

编译安装到/usr/local/python3

[root@echo Python-3.9.1]# ./configure --prefix=/usr/local/python3

安装

[root@echo Python-3.9.1]# make
[root@echo Python-3.9.1]# make install

为了在我们终端中直接使用python3这个命令,建立软连接,后面建的几个软连接也都是为了方便使用命令

[root@echo Python-3.9.1]# ln -s /usr/local/python3/bin/python3.9 /usr/bin/python3

pip3也一样建立软连接

[root@echo Python-3.9.1]# ln -s /usr/local/python3/bin/pip3.9 /usr/bin/pip3

回到根目录下,可以用下面的命令来查看python3和pip3是否安装成功

[root@echo /]# python3
Python 3.9.1 (default, Jan 14 2021, 09:08:21) 
[GCC 4.8.5 20150623 (Red Hat 4.8.5-44)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> 
[root@echo /]# pip3 -V
pip 20.2.3 from /usr/local/python3/lib/python3.9/site-packages/pip (python 3.9)

只要和上面提示的差不多,就说明安装成功了。

恭喜你,到这你成功了一小步

三. 安装虚拟环境

现在python3也是自带虚拟环境的,但习惯了virtualenv,还是安装一个管理我们所有的虚拟环境

[root@echo /]# pip3 install virtualenv

为方便使用virtualenv这个命令,我们也建立一下软连接

[root@echo /]# ln -s /usr/local/python3/bin/virtualenv /usr/bin/virtualenv

四. 创建我们存放网站的文件夹

在根目录下,创建一个data文件夹,再在data文件夹里面创建env文件夹和wwwroot文件夹,这个地方属于我自己的个人习惯,env来管理我们所有的虚拟环境,wwwroot来存放我们部署的网站文件

[root@echo /]# mkdir -p /data/env
[root@echo /]# mkdir -p /data/wwwroot

五. 在env文件里创建我们的虚拟环境

[root@echo /]# cd /data/env
[root@echo env]# virtualenv --python=/usr/bin/python3 myweb
created virtual environment CPython3.9.1.final.0-64 in 520ms
  creator CPython3Posix(dest=/data/env/myweb, clear=False, no_vcs_ignore=False, global=False)
  seeder FromAppData(download=False, pip=bundle, setuptools=bundle, wheel=bundle, via=copy, app_data_dir=/root/.local/share/virtualenv)
    added seed packages: pip==20.3.3, setuptools==51.0.0, wheel==0.36.2
  activators BashActivator,CShellActivator,FishActivator,PowerShellActivator,PythonActivator,XonshActivator

看到下面提示即创建成功

启动和退出虚拟环境的命令

[root@echo env]# source myweb/bin/activate
(myweb) [root@echo env]# deactivate 

前面能出现虚拟环境的名称,就代表启用成功,想退出就使用 deactivate 命令

六. 安装uwsgi

在系统里安装一次,在虚拟环境中再安装一次

[root@echo /]# pip3 install uwsgi
(myweb) [root@echo /]# pip3 install uwsgi

为方便使用uwsgi这个命令,继续做软链接

[root@echo /]# ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi

七. 安装nginx

进入软件的安装目录,下载nginx

[root@echo /]# cd /usr/local/
[root@echo local]# wget http://nginx.org/download/nginx-1.18.0.tar.gz

下载完成后进行解压

[root@echo local]# tar -zxvf nginx-1.18.0.tar.gz

进入nginx-1.18.0并进行安装

[root@echo local]# cd nginx-1.18.0
[root@echo nginx-1.18.0]# ./configure
[root@echo nginx-1.18.0]# make
[root@echo nginx-1.18.0]# make install

到这里,环境基本上是搞完了,下面开始上传你的网站代码

八. 本地项目搬运到服务器上

  1. 上传sql文件

对本地数据库进行备份,使用MySQL数据库的话,直接用navicat可视化工具导出sql文件,然后上传到服务器的MySQL数据库中。如果使用的是sqlite,那么直接随着项目文件一块上传到服务器,这里使用ftp也行,宝塔运维面版都可以,新手的话,建议使用宝塔运维面板,面板直接给你集成了ftp服务和MySQL数据库,你以后上传php项目也可以用,这个东西很强大,具体怎么使用自己百度

  1. 在本地项目中导出环境依赖包
pip freeze > requirements.txt
  1. 将项目的源码进行压缩打包,上传到服务器的wwwroot文件夹中,传完后进行解压缩

  2. 使用之前创建的虚拟环境,怎么使用进入参考步骤五

  3. 在你的虚拟环境中安装requirements.txt的依赖

(myweb) [root@echo myweb]# pip3 install requirements.txt 
  1. 修改一下项目文件中的设置,在settings.py里面修改
# 关闭生产环境中的DEBUG
DEBUG = False 
# 设置所有ip都可以访问该网站
ALLOWED_HOSTS = ['*']
# 在最下面添加样式收集目录,防止后端样式不生效
STATIC_ROOT  = os.path.join(BASE_DIR, 'static')
  1. 收集后端的css样式,不运行的话,进入admin后台会出现样式丢失的情况
(myweb) [root@echo myweb]# python3 manage.py collectstatic
  1. python3 manage runserver 运行系统,看能否运行

九. 配置uwsgi

进入你网站的根目录下,创建一个uwsgi.ini文件,内容可以参考下面的配置

(myweb) [root@echo myweb]# vim uwsgi.ini
[uwsgi]
#配置和nginx连接的socket连接
socket=127.0.0.1:8999
#配置项目路径,项目的所在目录
chdir=/data/wwwroot/myweb/
#配置wsgi接口模块文件路径,也就是wsgi.py这个文件所在的目录名
wsgi-file=myweb/wsgi.py
#配置启动的进程数
processes=4
#配置每个进程的线程数
threads=2
#配置启动管理主进程
master=True
#配置存放主进程的进程号文件
pidfile=uwsgi.pid
#配置dump日志记录
daemonize=uwsgi.log

创建完成后保存退出,用下面的命令来启用uwsgi,如果显示下面的内容,那么运行成功

(myweb) [root@echo myweb]# uwsgi --ini uwsgi.ini 
[uWSGI] getting INI configuration from uwsgi.ini

运行成功后,输入ls命令,可以看见根目录下多了uwsgi.pid和uwsgi.log这两个文件

uwsgi.pid里面记录了uwsgi的进行pid;uwsgi.log记录uwsgi的日志记录,有什么错误可以在里面查看

再补充两个uwsgi的相关操作:

停止uwsgi

uwsgi --stop uwsgi.pid

重启uwsgi

uwsgi --reload uwsgi.pid

注意:如果程序有改动,务必重启uwsgi

十. 配置nginx

进入nginx的conf文件夹,编辑nginx.conf

[root@echo /]# cd /usr/local/nginx/conf/
[root@echo conf]# vim nginx.conf

里面的内容改成下面这样

worker_processes  1;

events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    include /usr/local/nginx/conf/vhost/*.conf;     #主要是这个地方,把新建的配置文件>全部包含进来
    server {
        listen 80 default_server;
        server_name _;
        return 404;
    }
}

还是这个目录,新建一个vhost文件夹,这里存放你网站的配置,在里面新建个myweb.conf

[root@echo conf]# mkdir vhost
[root@echo conf]# cd vhost
[root@echo vhost]# vim myweb.conf

myweb.conf内容参考下面的配置:

server {
    listen       80;    #网站运行的端口
    server_name  www.myweb.com;    #这里没有域名的话,就写你的服务器ip地址,使用ip来访问

    charset utf-8;

    #access_log  logs/host.access.log  main;

    location / {
        include uwsgi_params;
        uwsgi_pass 127.0.0.1:8999;  #端口要和uwsgi里配置的一样
        uwsgi_param UWSGI_SCRIPT myweb.wsgi;  #wsgi.py所在的目录名+.wsgi
        uwsgi_param UWSGI_CHDIR /data/wwwroot/myweb/; #项目路径
    }

    location /static/ {
        alias /data/wwwroot/myweb/static/;
    }
}

配置好了就启动nginx服务,进入sbin文件夹执行下面的命令

[root@echo vhost]# cd /usr/local/nginx/sbin/
[root@echo sbin]# ./nginx 

这样用你的域名或者ip地址来访问,就能看到你的网站了

注意:如果程序有所改动,除了uwsgi要重启外,nginx也得进行重启

conf文件有改动,更应该重启nginx,重启命令如下:

[root@echo sbin]# ./nginx -s reload

到这里,项目就部署好了


补充

项目有修改,uwsgi、nginx都要进行重启,不然修改的地方不生效

如果出现500错误,而且你还找不到错误原因,一般都是程序片段有问题会报500错误,但也有一些情况,本身代码没问题,但浏览器报服务超时500错误,这时候你就得重新启动uwsgi服务,如果重启有报错,那就杀死uwsgi进程,重新进虚拟环境,重新启动uwsgi服务

查看uwsgi进行的命令:

(myweb) [root@echo myweb]# ps -ef|grep uwsgi 

杀死进程的命令,杀死后重新进行初始化

(myweb) [root@echo myweb]# killall -9 uwsgi
(myweb) [root@echo myweb]# uwsgi --ini uwsgi.ini 

这里重启完uwsgi后也要重启下nginx

[root@echo sbin]# ./nginx -s reload

善于从日志文件中定位错误位置,多尝试几次,多入几个坑,就有经验了

到这里,此文章也就结束,码了近两千字,希望能帮助各位小白们搭建自己的django项目,一般照着这个教程来,不大会出错,如有错误。


本文转载自 一条爱吃屎的狗:http://www.qnmlgb.top ,以上部署内容教程本人已亲测实际有效!配合宝塔面板部署,那效果更是爽得飞起......