前言
《Django部署到線上》一文中箱吕,很多步驟不是必須的,有些部分甚至是錯誤的柿冲,本文就精簡修改一下茬高。
目標:把djsite項目部署到/home/web目錄中,并且給它分配一個域名為djsite.voidking.com假抄。
環(huán)境準備
supervisor
1怎栽、安裝
yum install python-pip
yum install supervisor
pip install supervisor
2、創(chuàng)建sock
touch /tmp/supervisor.sock
chmod 777 /tmp/supervisor.sock
python虛擬機
1宿饱、安裝pyenv套裝
curl -L https://raw.githubusercontent.com/pyenv/pyenv-installer/master/bin/pyenv-installer | bash
內(nèi)容除了包含 pyenv 以外熏瞄,還包含如下插件:
- pyenv-doctor
- pyenv-installer
- pyenv-update
- pyenv-virtualenv
- pyenv-which-ext
2、路徑添加
vim ~/.bash_profile
谬以,添加:
export PATH="/root/.pyenv/bin:$PATH"
eval "$(pyenv init -)"
eval "$(pyenv virtualenv-init -)"
3强饮、使配置立即生效
source ~/.bash_profile
4、查看安裝情況
pyenv -v
5蛉签、常用命令
- 查看可安裝的python版本列表:
pyenv install -l
- 安裝指定版本的python:
pyenv install 3.6.1
- 查看已安裝的python:
pyenv versions
- 查看當前設為默認的python版本:
pyenv version
安裝python3.6
1胡陪、配置pyenv下載源為本地目錄(可選操作沥寥,不做的話下載速度會很慢)
mkdir /root/python/ && cd /root/python/
# 設置變量
export PYTHON_BUILD_CACHE_PATH=/root/python
# 設置變量
export PYTHON_BUILD_MIRROR_URL=/root/python
# 查看變量設置
env | grep PYTHON_BUILD_MIRROR_URL
wget https://www.python.org/ftp/python/3.6.1/Python-3.6.1.tar.xz
2、安裝python3.6.1柠座,pyenv install 3.6.1
報錯邑雅,ERROR: The Python ssl extension was not compiled. Missing the OpenSSL lib? 需要安裝依賴包:
yum install readline readline-devel readline-static -y
yum install openssl openssl-devel openssl-static -y
yum install sqlite-devel -y
yum install bzip2-devel bzip2-libs -y
3、改變?nèi)职姹?br>
pyenv global 3.6.1
妈经,python -V
附:改變回原版本
pyenv global system
淮野,python -V
4、刷新數(shù)據(jù)庫
python rehash
項目部署
代碼準備
1吹泡、在/home/web目錄中骤星,執(zhí)行命令克隆項目
git clone https://github.com/voidking/djsite.git
2、安裝django
pip install django==1.11.7
3爆哑、安裝pymysql
pip install pymysql
數(shù)據(jù)庫準備
1洞难、創(chuàng)建數(shù)據(jù)庫
# mysql -uroot -p
mysql> create database `djsite` default character set utf8 collate utf8_general_ci;
2、修改mysql的binlog格式為混合模式:
mysql> set global binlog_format=mixed;
mysql> exit;
3揭朝、修改djsite/djsite/settings.py中的數(shù)據(jù)庫配置
vim djsite/djsite/settings.py
4队贱、創(chuàng)建表結(jié)構(gòu)
python manage.py makemigrations
python manage.py migrate
啟動項目
1、啟動命令
python manage.py runserver
2潭袱、服務器測試訪問
curl localhost:8000/blog/index
3柱嫌、本地測試訪問
使用瀏覽器查看 http://ip:8000/blog/index ,無法訪問屯换。
啟動命令改為:python manage.py runserver 0.0.0.0:8000
编丘,此時即可在瀏覽器看到部署好的項目。
如果還是不能訪問彤悔,嘗試先關(guān)閉防火墻:systemctl stop firewalld
nginx配置
1嘉抓、首先,在萬網(wǎng)上配置域名解析蜗巧,添加A記錄掌眠,解析到阿里云服務器IP。假設解析好的域名為django.voidking.com幕屹。
2蓝丙、在nginx的vhost中,添加django.voidking.com.conf望拖,內(nèi)容為:
server {
listen 80;
server_name django.voidking.com;
charset utf-8;
location /{
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 1024m;
client_body_buffer_size 128k;
client_body_temp_path data/client_body_temp;
proxy_connect_timeout 90;
proxy_send_timeout 90;
proxy_read_timeout 90;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;
proxy_temp_path data/proxy_temp;
proxy_pass http://127.0.0.1:8000;
}
}
3渺尘、重啟nginx,./nginx -s reload
4说敏、測試訪問
服務器:curl django.voidking.com/blog/index
本地瀏覽器:http://django.voidking.com/blog/index
至此鸥跟,django項目已經(jīng)部署成功,沒有用到uwsgi。如果給django添加守護進程医咨,那么我們的部署就接近完美了枫匾。那么,uwsgi又能干什么呢拟淮,我們繼續(xù)研究干茉。
uwsgi
安裝uwsgi
pip install uwsgi
編寫測試:
# test.py
def application(env, start_response):
start_response('200 OK', [('Content-Type','text/html')])
return [b"Hello World"]
啟動測試:
uwsgi --http :8001 --wsgi-file test.py
訪問 http://ip:8001 ,即可看到Hello World 很泊。
一般啟動
1角虫、編寫wsgi.py文件
編寫django_wsgi.py文件,將其放在與文件manage.py同一個目錄下委造。
#!/usr/bin/env python
# coding: utf-8
import os,django
from django.core.handlers.wsgi import WSGIHandler
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "djsite.settings")
django.setup()
application = WSGIHandler()
2戳鹅、啟動項目
uwsgi --http :8000 --chdir /home/web/djsite/ --module django_wsgi
3、查看啟動結(jié)果
lsof -i :8000
昏兆,ps aux | grep uwsgi
4枫虏、測試訪問
http://ip:8000/blog/index
此時,頁面是沒有樣式的亮垫,也就是說靜態(tài)資源加載失敗模软。
5伟骨、配置靜態(tài)資源
uwsgi --http :8000 --chdir /home/web/djsite/ --module django_wsgi --static-map=/static=static
此時饮潦,頁面樣式就正常了。
高級啟動
1携狭、新建uwsgi.ini继蜡,與manage.py在同一級目錄。
[uwsgi]
http = :8000
chdir = /home/web/djsite/
wsgi-file = django_wsgi.py
static-map = /static=static
2逛腿、啟動uwsgi
uwsgi uwsgi.ini
3稀并、測試訪問
http://ip:8000/blog/index
supervisor
配置supervisor
1、開機啟動
systemctl enable supervisord
2单默、生成配置文件
mkdir -p /etc/supervisor/
echo_supervisord_conf > /etc/supervisord.conf
3碘举、修改配置文件
vim /etc/supervisord.conf
,添加:
[include]
files = /etc/supervisor/*.conf
4搁廓、運行
supervisord -c /etc/supervisord.conf
守護uwsgi
1引颈、在/etc/supervisor中新建djsite.conf文件:
[program:djsite]
command=/root/.pyenv/versions/3.6.1/bin/uwsgi --http :8000 --chdir /home/web/djsite/ --module django_wsgi --static-map=/static=static
directory=/home/web/djsite/
startsecs=0
stopwaitsecs=0
autostart=true
autorestart=true
2、重啟supervisor
ps aux | grep supervisord
systemctl stop supervisord
systemctl start supervisord
附:重啟djsite命令
supervisorctl -c /etc/supervisord.conf restart djsite
3境蜕、測試訪問
http://ip:8000/blog/index
頁面顯示正常蝙场,至此守護進程配置成功。
4粱年、djsite.conf可以精簡修改為:
[program:djsite]
command=/root/.pyenv/versions/3.6.1/bin/uwsgi --ini uwsgi.ini
directory=/home/web/djsite/
startsecs=0
stopwaitsecs=0
autostart=true
autorestart=true
靜態(tài)資源問題(可忽略)
假設售滤,uwsgi.ini為:
[uwsgi]
http = :8000
chdir = /home/web/djsite/
wsgi-file = django_wsgi.py
靜態(tài)資源就無法訪問了。在不添加static-map的情況下,需要修改兩個文件:
(1)修改djsite/djsite/settings.py文件完箩,添加:
STATIC_ROOT = '/home/web/djsite/static/'
(2)修改djsite/djsite/settings.py文件為:
from django.conf.urls import url,include
from django.contrib import admin
from django.conf.urls.static import static
from django.conf import settings
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^blog/', include('blog.urls', namespace='blog')),
] + static(settings.STATIC_URL, document_root=settings.STATIC_ROOT)
admin靜態(tài)資源問題
如果以python manage.py runserver
啟動django赐俗,那么靜態(tài)資源沒有問題。
如果以uwsgi啟動django弊知,靜態(tài)資源看起來沒有問題秃励,但是,如果訪問 http://ip:8000/admin 吉捶,就會發(fā)現(xiàn)這個頁面的靜態(tài)資源無法獲取夺鲜。
一個Django應用,一般有兩類靜態(tài)文件呐舔。一是應用內(nèi)的靜態(tài)文件币励,二是Django自帶的靜態(tài)文件。應用內(nèi)的靜態(tài)文件在djsite/static目錄下珊拼。此外食呻,在INSTALLED_APPS中配置了django.contrib.admin, 則還會有另外一組靜態(tài)文件澎现,在Django安裝位置里仅胞。
例如,一個root在Python 3.6版本安裝的Django剑辫,admin的靜態(tài)文件在: /usr/local/lib/python3.6/site-packages/django/contrib/admin/static/admin/干旧。
最終,在STATIC_URL里妹蔽,會有兩類靜態(tài)文件椎眯, /static/*
與 /static/admin/*
。
了解原理胳岂,原因就很顯然了编整。python manage.py runserver
知道靜態(tài)文件的位置,而uWSGI不知道靜態(tài)文件在什么位置乳丰。
解決辦法如下:
(1)修改djsite/djsite/settings.py文件:
SITE_ROOT = os.path.dirname(os.path.abspath(__file__))
SITE_ROOT = os.path.abspath(os.path.join(SITE_ROOT, '../'))
STATIC_ROOT = os.path.join(SITE_ROOT, 'collectedstatic')
(2)收集所有靜態(tài)文件到collectedstatic目錄
python manage.py collectstatic
(3)修改uwsgi.ini配置
[uwsgi]
http = :8000
chdir = /home/web/djsite/
wsgi-file = django_wsgi.py
static-map = /static=collectedstatic
nginx+uwsgi
以上掌测,我們的djsite項目已經(jīng)通過uwsgi方式啟動起來,并且可以保持后臺運行产园。nginx配置不改變的情況下汞斧,我們可以正常訪問 http://django.voidking.com/blog/index 。此時淆两,nginx作為反向代理断箫,和uwsgi間通過http交互。
接下來秋冰,就配置下nginx和uwsgi通過socket結(jié)合的方式仲义。原理:用戶發(fā)送http請求到nginx,nginx通過socket把請求交給uwsgi,uwsgi拿到django的處理結(jié)果埃撵,通過socket返還給nginx赵颅,nginx通過http返回結(jié)果給用戶。
1暂刘、因為nginx和uwsgi通過socket方式交互饺谬,我們需要修改uwsgi.ini的配置為:
[uwsgi]
socket = :8000
chdir = /home/web/djsite/
wsgi-file = django_wsgi.py
static-map = /static=collectedstatic
master = true
processes = 2
enable-threads = true
daemonize = /home/web/djsite/uwsgi.log
2、重啟supervisor
systemctl stop supervisord
systemctl start supervisord
3谣拣、修改nginx配置djsite.voidking.com.conf:
server {
listen 80;
server_name djsite.voidking.com;
charset utf-8;
location / {
uwsgi_pass 127.0.0.1:8000;
include uwsgi_params;
}
}
5募寨、重啟nginx
./nginx -s reload
6、測試訪問
此時森缠,訪問 http://ip:8000/blog/index 失敗拔鹰,訪問 http://django.voidking.com/blog/index 正常。因為8000端口不再提供http服務贵涵,而是一個和nginx連接的socket列肢。
加速靜態(tài)資源
1、修改nginx配置djsite.voidking.com.conf:
server {
listen 80;
server_name djsite.voidking.com;
charset utf-8;
location / {
uwsgi_pass 127.0.0.1:8000;
include uwsgi_params;
}
location /static {
alias /root/djsite/collectedstatic;
}
}
2宾茂、修改nginx.conf
user root;
3瓷马、重啟nginx
./nginx -s reload
小結(jié)
至此,django部署完畢跨晴,我們實現(xiàn)了三種部署方法:
- nginx + django(http方式)
- nginx + uwsgi(http方式)
- nginx + uwsgi(socket方式)