部署背景:之前开发了一个本地的个人blog项目,还未部署云服务器,有些功能还未完善,先尝试在本地部署。本篇内容则是基于centos+uwsgi+nginx来部署项目,实现高性能web服务,其中还给出uwsgi和nginx分别部署在不同服务器上步骤,这一点,很多文章并未给出相关探讨。
1、相关服务安装配置
安装nginx。配置官方镜像源,这里baseurl里面有$basearch变量,用来检索yum命令安装所需要的包。
$ vi /etc/yum.repos.d/nginx.repo
[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1
$ yum -y install nginx
$ systemctl enable nginx
安装python3.6,采用python虚拟环境部署项目,跟系统不冲突
$ yum -y install python36 python36-devel
# 配置并载入 Python3 虚拟环境
$ cd /opt
# 在这里不需要将centos默认python2.7版本配置为默认python3.6
# 直接使用python3.6作为启动命令即可,可避免冲突
$ python3.6 -m venv py36 # py3 为虚拟环境名称, 可自定义
# 退出虚拟环境可以使用 deactivate 命令
$ source /opt/py36/bin/activate
(py36) [root@nn py36]# ls
bin include lib lib64 pyvenv.cfg
# 载入环境后默认以下所有命令均在该虚拟环境中运行
(py3) [root@localhost py3]
# 安装 Python 库依赖
$ pip install --upgrade pip setuptools
$ pip install -r requirements.txt
安装uwsgi
# uwsgi需要使用gcc环境编译否则无法安装成功
yum install gcc -y
# 激活py36环境
(py36) [root@nn mywebapp]# pip install uwsgi
Successfully installed uwsgi-2.0.18
数据库安装和配置可以参考本人这篇文章
以上后台技术栈的相关版本总揽如下:
Centos 7.5
MariaDB 10.3.17
Python 3.6
Django1.11
uWSGI 2.0.18
Nginx 1.12.2
Redis 5.0.4
这些服务都是部署同一台服务器上,适合单台的个人云服务器,毕竟一年几百元,服务器配置有限,而对于本地部署,可以通过多台linux虚拟机分别部署不同服务,并做HA,这一过程相信也会积累不少知识和经验,学有余力的同学一定要试试。
2、配置uwsgi启动django项目
2.1 uwsgi 命令行启动项目
查看项目,对项目路径必须清楚那些文件在哪里路径下,否则使用uwsgi启动设置参数,容易出错,以本项目为例,项目根目录路径为:/opt/mywebapp
,项目根目录内容:
(py36) [root@nn mywebapp]# pwd
/opt/mywebapp
(py36) [root@nn mywebapp]# ls
account blog db.sqlite3 __init__.py media script templates
article course image manage.py mysite static
其中非常关键的wsgi入口,在mysite目录下,也就是django项目总settings.py所在的目录,mysite目录下的wsgi.py,将在之后的uwsgi启动中使用
(py36) [root@nn mysite]# ls
__init__.py __pycache__ settings.py urls.py wsgi.py
wsgi.py代码逻辑:
"""
WSGI config for mysite project.
It exposes the WSGI callable as a module-level variable named ``application``.
For more information on this file, see
https://docs.djangoproject.com/en/1.10/howto/deployment/wsgi/
"""
import os
from django.core.wsgi import get_wsgi_application
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "mysite.settings")
application = get_wsgi_application()
确认项目使用manage.py启动能正常运行
python manage.py runserver 0.0.0.0:9000
使用uwsgi启动项目并测试是否成功运行django项目,通过连接mysite/wsgi.py实现web server和application通信
这里有两种启动方式:
A、不带静态文件启动,静态文件将无法加载,页面不正常显示
–chdir /opt/mywebapp/ django项目根路径
wsgi-file mysite/wsgi.py django项目settings.py所在目录下的 wsgi.py文件
uwsgi --http 0.0.0.0:9000 --chdir /opt/mywebapp/ --wsgi-file mysite/wsgi.py --master --processes 4 --threads 2
B、带静态文件启动,也就是网页打开后,页面能正常显示
–chdir /opt/mywebapp/ django项目根路径
wsgi-file mysite/wsgi.py django项目settings.py所在目录下的 wsgi.py文件
–static-map=/static=static django项目web页面静态文件,所在根目录的’static’目录
–static-map=/static=media django项目内容静态文件,所在根目录的’media’目录
注意:这里仅是指static、media目录,根目录下还有其他blog,account,templates目录等,可能也有人会问,是不是都需要把这些目录都要一一加入–static-map里面,答案是不需要,因为这些都不是django application对应的“static”目录(已在settins设定,并可以让其他views索引到static目录),如果使用-static-map=/static=templates,uwsgi将无法找到相关静态文件
uwsgi --http 0.0.0.0:9000