步骤一:在Centos上安装Python3.6
可见文章:Linux-Centos7安装python3并与python2共存
步骤二:用Python3.6自带的venv,创建虚拟环境
创建一个虚拟环境的目录,然后进入到该目录(py3)
localhost:py3 zhaofan$ pwd
/Users/zhaofan/py3
创建虚拟环境
python3 -m vent .
激活虚拟环境
source bin/activate
如下图:这样虚拟环境就创建完成
退出虚拟环境
(py3)$deactivate
-
问题:如何复制虚拟环境A下的依赖到虚拟环境B?
解决:先在A环境中把所有依赖都保存到XX.txt中,使用pip freeze:
pip3 freeze > re.txt
这时会在当前目录下生成re.txt文件,打开后可以看到该环境下pip3所有第三方依赖包,可以按情况删除不需要的包。
然后把re.txt文件复制到环境B下,运行pip3 install -r re.txt,就会自动安装好第三方依赖了。
注意:有的扩展库通过pip install的方式安装可能会出现问题(比如 lxml),那么通过上面那条命令安装也会失败,这种扩展库我们只有去这里下载编译好的.whl文件进行单独安装。先在虚拟环境中安装wheel(pip install wheel),然后就可以直接用pip命令安装.whl文件了。
步骤三:部署项目代码
Django 项目中会有一些 CSS、JavaScript 等静态文件,为了能够方便地让 Nginx 处理这些静态文件的请求,我们把项目中的全部静态文件收集到一个统一的目录下,这个目录通常位于 Django 项目的根目录,并且命名为 static。为了完成这些任务,需要在项目的配置文件里做一些必要的配置:
blogproject/settings.py
# 其他配置...
STATIC_URL = '/static/'
# 加入下面的配置
STATIC_ROOT = os.path.join(BASE_DIR, 'static')
STATIC_ROOT 指明了静态文件的收集目录,即项目根目录(BASE_DIR)下的 static 文件夹。
为了安全起见,在生产环境下需要关闭 DEBUG 选项。打开 settings.py 文件,找到 DEBUG选项,将它们设置成如下的值:
blogproject/settings.py
DEBUG = False
如果将本地编写的代码放到GitHub上,那在虚拟环境下直接下载GitHub的代码即可
git clone XXXgit仓库目录
当然也可以是SVN等,具体就不赘述了。
然后安装项目依赖,直接pip3 install -r re.txt就可以了(具体见步骤二)
收集静态文件
虚拟环境下继续运行 python manage.py collectstatic 命令收集静态文件到 static 目录
python3 manage.py collectstatic
生成数据库
python3 manage.py migrate
步骤四:配置Nginx
安装Nginx请看Linux(CentOS 6.5) 下Nginx 安装,重启和停止
Nginx的配置文件配置(建议的方法):
在自己项目目录下加个新建个nginx的配置文件nginx_blog.conf,将其建立软连接,连接到自己系统的nginx安装目录下的conf/conf.d目录下(conf.d目录为我自己添加)
ln -s /opt/mysites/boke/blogproject/nginx_blog.conf
/usr/local/nginx/conf/conf.d
/opt/mysites/boke/blogproject/nginx_blog.conf
server {
listen 9000;
server_name localhost;
access_log /opt/mysites/boke/blogproject/access.log;#访问日志
error_log /opt/mysites/boke/blogproject/error.log;#错误日志
location / {
proxy_pass [http://127.0.0.1:9090](http://127.0.0.1:9090); #动态请求交给gunicorn,9090端口就是gunicorn用的端口
#proxy_set_header Host $host;
#proxy_set_header X-Real-IP $remote_addr;
#proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
#proxy_set_header X-Forwarded-Proto $scheme;
}
# location 顾名思义,定位,就是当访问 / 的时候,nginx会将请求转给本地的8080端口,而后面的设置都是一些基本的配置,可以直接用
location /static {
alias /opt/mysites/boke/blogproject/static;
}
# 这个就是配置静态文件的地方,要用绝对地址,对应最开始的目录形式,假设project就在/home下面,那么这样配置就可以的了,还有个前提是,你在开发的时候,采取了django的建议,每个app的静态文件都用多了一层app_name的文件夹来包住。
}
问题1:
proxy_set_header Host $host; #这里我一开始没有注释的,网页访问的时候都是报bad request 400错误,后来注释掉以后可以访问,具体原因还不知道
nginx主配置文件/usr/local/nginx/conf/nginx.conf里include 配置文件
user root;
worker_processes 1;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
worker_connections 1024;
}
http {
include mime.types;
include conf.d/nginx_blog.conf; #blog站点
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
}
django项目的站点名(域名或IP或者表示全部)加入到 settings.py的ALLOWED_HOSTS里:
ALLOWED_HOSTS = [‘*’]
如果要外部访问,则打开8000端口:
/sbin/iptables -I INPUT -p tcp --dport 8000 -j ACCEPT
service iptatbles save
问题2:Django DEBUG=False时静态文件404的问题
设置urls.py(在urls.py文件里增加下面代码)
from django.views.static import serve
from django.conf import settings
if not settings.DEBUG:
urlpatterns += [url(r'^static/(?P<path>.*)$', serve,{'document_root': settings.STATIC_ROOT})]
配置完后,检查下
/usr/local/nginx/sbin/nginx -t 检查配置语法是否正确
/usr/local/nginx/sbin/nginx 启动nginx
/usr/local/nginx/sbin/nginx -s reload 重启nginx
步骤五:安装配置Gunicorn
安装:
直接 pip install gunicorn 就可以了
配置:
用gunicorn代替runserver
在django的settings INSTALLED_APPS里面加上gunicorn
方法1:
在项目的manage.py文件夹中运行
gunicorn ×××.wsgi:application -b 127.0.0.1:9090 —reload
方法2:
在项目根目录下创建一个配置文件:gunicorn.conf.py ,配置如下:
import multiprocessing
bind = "127.0.0.1:9090"
workers = 2
errorlog = "/opt/mysites/boke/blogproject/gunicorn.error.log"
#loglevel = "debug"
proc_name = "gunicorn_blog_project"
在上述配置的情况下,Gunicorn 会在 /tmp/ 目录下创建一个名为 gunicorn1.sock 的 Unix 套接字。 还会启动一些工作进程,进程数量相当于 CPU 内核数量的 2 倍。 它还会自动重新加载并作为守护进程运行。
在该目录下运行命令:
gunicorn -c gunicorn.conf.py blogproject.wsgi:appliction
稍微复杂点的命令:
gunicorn -c gunicorn.conf.py -D --error-logfile gunicorn.error.log blogproject.wsgi:appliction
上面的命令应该从项目的根目录运行。 -c 选项告诉 Gunicorn 使用你创建的配置文件。 -D 再次指定 gunicorn 为守护进程。 最后一部分指定 Gunicorn 的错误日志文件在你创建 Gunicorn 文件夹中的位置。 命令结束部分就是为 Gunicorn 指定 .wsgi 文件的位置。
最后打开网页,看下是否能成功访问。以上我搞了两天,中间各种不服。
附录:
gunicorn 不要用 命令中传参来做配置,用文件。
配置说明见官方文档 http://docs.gunicorn.org/en/latest/settings.html#logging
优化后的配置文件:
# coding=utf-8
import sys
import os
import multiprocessing
path_of_current_file = os.path.abspath(__file__)
path_of_current_dir = os.path.split(path_of_current_file)[0]
_file_name = os.path.basename(__file__)
sys.path.insert(0, path_of_current_dir)
worker_class = 'sync'
workers = multiprocessing.cpu_count() * 2 + 1
chdir = path_of_current_dir
worker_connections = 1000
timeout = 30
max_requests = 2000
graceful_timeout = 30
loglevel = 'info'
reload = True
debug = False
bind = "%s:%s" % ("0.0.0.0", 8811)
pidfile = '%s/run/%s.pid' % (path_of_current_dir, _file_name)
errorlog = '%s/logs/%s_error.log' % (path_of_current_dir, _file_name)
accesslog = '%s/logs/%s_access.log' % (path_of_current_dir, _file_name)