经历了两天的时候终于把本地使用python3 django开发的接口API部署到服务器上了,还是记录一下,以免之后忘记,哈哈

注意一点,就是,centos7是基于python2的,我这边默认的是python2.7.5,记住不要删除了python2,否则后果很严重,yum会报错,这是因为python3和python2版本的冲突导致的

第一步,安装 python3 到 Centos7, 先安装软件管理包和可能使用的依赖

yum -y groupinstall "Development tools"

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

第二步,下载Pyhton3到/usr/local 目录

wget https://www.python.org/ftp/python/3.8.0/Python-3.8.0.tgz

第三步,解压

tar -zxvf Python-3.8.0.tgz

第四步,进入cd Python-3.8.0

第五步,解压到指定路径

./configure --prefix=/usr/local/python3

第六步,安装python3

make

make install

第七步,安装完成之后 建立软链接 添加变量 方便在终端中直接使用python3

ln -s /usr/local/python3/bin/python3.8 /usr/bin/python3

第八步,Python3安装完成之后pip3也一块安装完成,不需要再单独安装一样建立软链接

同样给pip3建立软链接

ln -s /usr/local/python3/bin/pip3.8 /usr/bin/pip3

注: 如果软链建立完成,但是却无法使用的时候执行下面命令:

mv pip pip2 # (将文件 pip 更名为 pip2 )

ln -s /usr/local/python3/bin/pip3 /usr/bin/pip

如果安装了python3以后发现没有pip可以通过以下方式下载pip,进入一个目录就是你想把它下载到哪个目录就进入哪个目录

执行命令:wget https://bootstrap.pypa.io/get-pip.py --no-check-certificate

会下载get-pip.py文件

然后执行: python3 get-pip.py

第九步,安装virtualenv, 方便不同版本项目管理。

pip3 install virtualenv

第十步,建立软链接

ln -s /usr/local/python3/bin/virtualenv /usr/bin/virtualenv3

第十一步,安装成功在根目录下建立两个文件夹,主要用于存放env和网站文件的 (文件创建随意,根据实际需求)。

mkdir -p /data/env # 存放虚拟环境

mkdir -p /data/www # 存放web项目

第十二步,切换到/data/env/下,创建指定版本的虚拟环境。

virtualenv3 --python=/usr/bin/python web (项目名) # 创建虚拟环境

# 然后进入

cd /data/env/web/bin

# 进入bin目录后开启虚拟环境,执行命令

source activate

# 注:(启动后出现 (web),说明是成功进入虚拟环境。)

第十三步,虚拟环境里用pip3安django和uwsgi (留意:uwsgi要安装两次,先在系统里安装一次,然后进入对应的虚拟环境安装一次。)

pip3 install django #(如果用于生产的话,则需要指定安装和你项目相同的版本)

pip3 install uwsgi

# 给uwsgi建立软链接,方便使用

ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi

第十四步,在本地项目目录下用下面的命令把当前的环境依赖包导出到requirements.txt文件

pip freeze > requirements.txt

第十五步,把项目源码压缩打包。把项目上传到服务器对应的目录里(/data/www/),解压。

这里可以导入本地数据库,其实django建model,只要在线上mysql数据库中建立项目中的数据库的名称,eg:python

然后,可以像本地开发一样 migrate 数据库,前提是已经安装好了数据库啊

第十六步,进入解压好的项目根路径中安装requirements.txt里的依赖包。

pip3 install -r requirements.txt

第十七步,安装mysql

wget -P /home/liudong http://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpm

cd /home/liudong

安装mysql的YUM源:rpm -ivh mysql57-community-release-el7-11.noarch.rpm

检查mysql的YUM源是否安装成功:yum repolist enabled | grep "mysql.*-community.*"

查看mysql版本,执行:yum repolist all | grep mysql

查看当前的启用的 MySQL 版本:yum repolist enabled | grep mysql

yum install mysql-community-server

安装过程中一直输入"y"就可以了,当出现下面的结果时,就代表mysql数据库安装成功了

启动mysql服务:systemctl start mysqld

登录进Mysql(我的刚安装完时没有密码):mysql -uroot -p

查看默认密码

grep 'temporary password' /var/log/mysqld.log


进去之后重新设置密码

set password for 'root'@'localhost' = password('123456');

第十八步,通过 python3 manage.py runserver 运行一下项目,如果能正常启动则进行下一步,不能正常运行往上检查

如果报错:django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.3 or newer is required; you have 0.7.11 解决方案:

解决:编辑Python安装路径下的 Python36-32\Lib\site-packages\django\db\backends\mysql\base.py

将文件中的如下代码注释

#if version < (1, 3, 3):

# raise ImproperlyConfigured("mysqlclient 1.3.3 or newer is required; you have %s" % Database.__version__)

第十九步,在项目根目录里添加uwsgi配置文件 (uwsgi.ini)

[uwsgi]

socket = 127.0.0.1:8070

#是否使用主线程

master = true

# 项目在服务器中的目录(绝对路径)

chdir = /data/www/web

# Django's wsgi 文件目录

wsgi-file = web/wsgi.py

# 最大进程数

processes = 4

#每个进程的线程数

threads = 2

#状态监听端口

stats = 127.0.0.1:9191

# 退出时自动清理环境配置

vacuum = true

#目录下文件改动时自动重启

touch-reload = /data/www/web

#Python文件改动时自动重启

#py-auto-reload = 1

#后台运行并把日志存到.log文件

daemonize = /data/www/web/uWSGI.log

第二十步,进入部署到服务器的项目根目录下,执行

uwsgi --ini uwsgi.ini

第二十一步,查看端口,看下uwsgi是否存在

netstat -nltp


第二十二步,配置Nginx配置文件(把原先的配置文件可以备份以下,然后将下面的替换进去)。

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:8070; #端口要和uwsgi里配置的一样

uwsgi_param UWSGI_SCRIPT web.wsgi; #wsgi.py所在的目录名+.wsgi

uwsgi_param UWSGI_CHDIR /data/www/web/; #项目路径

}

location /static {

alias /data/www/web/myapp/static; #静态资源路径

}

location /templates {

alias /data/www/web/templates;

}

}

}

第二十三步,一定要注意Uwsgi和Nginx配置文件里的项目路径和静态资源路径,填写正确了才能成功访问。不然会出现502错误。还有就是,修改Django文件和其它配置文件之后,一定要重启Uwsgi和Nginx,不然不生效。

uwsgi 启动方法

uwsgi --ini uwsgi.ini

Nginx 重启方法

nginx -s reload

以下总结下注意事项:

1 项目上线后记得 DEBUG = False 这样设置,这样的话你的项目访问失败就不会有 Django 的错误信息了

2 设置所有 IP 都可访问 (settings.py)

ALLOWED_HOSTS = ['*']

3 数据库设置(settings.py)

DATABASES = {

'default': {

'ENGINE': 'django.db.backends.mysql',

'NAME': 'python', # 库名 (根据实际数据库名进行修改)

'PORT': 3306, # 端口(不用改)

'HOST': '127.0.0.1', # 本地host(不用改)

"USER": 'root', # 用户名

'PASSWORD': '123456' # 密码

}

}