這篇文章主要介紹Vue+Django項(xiàng)目部署的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

本地項(xiàng)目配置
1 復(fù)制 luffy/settings/dev.py為prop.py
修改luffy/settings/prop.py中以下幾項(xiàng)
(1) allow_hosts
ALLOWED_HOSTS = [ 'api.youdomain.com', ]
(2) 跨域白名單
CORS_ORIGIN_WHITELIST = ( # 前端域名 "www.youdomain.com", # 后端api接口域名 "api.youdomain.com" )
(3) 支付寶電腦網(wǎng)站支付配置信息
ALIPAY_APPID = "xxxxxxx" APP_NOTIFY_URL = None ALIPAY_DEBUG = True # APIPAY_GATEWAY="https://openapi.alipay.com/gateway.do" APIPAY_GATEWAY = "https://openapi.alipaydev.com/gateway.do" ALIPAY_RETURN_URL = "http://www.youdomain.com/success" ALIPAY_NOTIFY_URL = "http://api.youdomain.com:8000/payments/success"
2 修改luffy/wsgi.py文件
第14行
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "luffy.settings.prop")3 修改manage.py文件
不改也可以,為了在服務(wù)器測試方便一點(diǎn)
第6行
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "luffy.settings.prop")4 導(dǎo)出pip安裝的包列表
freeze > docs/requirements.txt
5 收集靜態(tài)文件
python manage.py collectstatic
6 提交并推送
git add . git commit -m "項(xiàng)目完成" git push -u origin master
7 前端配置修改 src/settings.js
設(shè)置后端服務(wù)器域名和端口
Host:http://api.youdomain.com:80,
8 構(gòu)建
npm run build
9 提交并推送
git add . git commit -m "項(xiàng)目完成" git push -u origin master
服務(wù)器上配置
1 安裝所需軟件
yum install python36-pip.noarch python36.x86_64 python36-devel.x86_64 nginx git gcc -y pip3 install virtualenv -i https://pypi.douban.com/simple
注意:uwsig 最好使用pip方式安裝
pip3 install uwsgi -i https://pypi.douban.com/simple
2 mysql數(shù)據(jù)庫相關(guān)配置
(1)安裝mysql
yum install mysql-server -y
或者使用容器
設(shè)置密碼以及初始化配置請(qǐng)自行解決
(2) 啟動(dòng)數(shù)據(jù)庫
systemctl start mysqld
(3)新建數(shù)據(jù)庫luffy
create database luffy;
(4) 導(dǎo)入數(shù)據(jù)
mysql -uroot -pmysql luffy < luffy.sql
3 redis 安裝與配置
可以使用 yum 安裝并啟動(dòng) ,簡單粗暴!
為了使用最新版,我采用解壓安裝
那種方式你喜歡就好!
(1) 下載
cd /opt/ wget http://download.redis.io/releases/redis-5.0.5.tar.gz
(2) 解壓并安裝
tar -xf redis-5.0.5.tar.gz cd /opt/redis-5.0.5 make && make install
(3)修改配置文件
vim redis.conf
69行 bind 127.0.0.1
改為 bind 0.0.0.0
(4)啟動(dòng)Redis,并放置在后臺(tái)
nohup redis-server redis.conf &
4 拉取前端項(xiàng)目
cd /opt/ git clone https://gitee.com/SunHarvey/luffyweb.git
前端項(xiàng)目路徑為 /opt/luffyweb/
只有 /opt/luffyweb/dist/ 文件有用 ,
dist用作前端根目錄,其他的不要亦可!
5 創(chuàng)建虛擬環(huán)境
(1)創(chuàng)建虛擬環(huán)境
cd /opt/ virtualenv luffy
即就是虛擬環(huán)境路徑為 /opt/luffy/
cd /opt/luffy/
(2)激活虛擬環(huán)境
source /opt/luffy/bin/activate
(3)拉取后端項(xiàng)目
git clone https://gitee.com/SunHarvey/luffy.git
注:項(xiàng)目根路徑為 /opt/luffy/luffy/
cd luffy
可以看到以下文件
docs luffy manage.py scripts static
(4)pip安裝所需包
我的 django 使用的是2.0版本,不需要因?yàn)?pymysql 報(bào)錯(cuò)該源碼
刪除 luffy/docs/requirements.txt中 xadmin中的那行
pip3 install https://codeload.github.com/sshwsfc/xadmin/zip/django2 pip3 instal -r /opt/luffy/luffy/docs/requirements.txt
(5)用 runserver 啟動(dòng)django項(xiàng)目看看是否正常
記得啟動(dòng)MySQL數(shù)據(jù)庫和redis
python manage.py runserver
沒有報(bào)錯(cuò)的話繼續(xù),報(bào)錯(cuò)了就根據(jù)提示排除吧
6 uwsgi配置
(1) uwsgi.ini 配置內(nèi)容如下
vim /opt/luffy/luffy/uwsgi.ini [uwsgi] # 設(shè)置uwsgi 啟動(dòng)用戶,不設(shè)置也可,會(huì)有警告,也可以設(shè)置為當(dāng)前登錄的用戶 uid = nginx gid = nginx #使用nginx連接時(shí)使用,Django程序所在服務(wù)器地址 socket=127.0.0.1:8000 #直接做web服務(wù)器使用,Django程序所在服務(wù)器地址 #http=0.0.0.0:8080 #項(xiàng)目目錄 chdir=/opt/luffy/luffy #項(xiàng)目中wsgi.py文件的目錄,相對(duì)于項(xiàng)目目錄 wsgi-file=luffy/wsgi.py # 進(jìn)程數(shù) processes=1 # 線程數(shù) threads=2 # uwsgi服務(wù)器的角色 master=True # 存放進(jìn)程編號(hào)的文件 pidfile=uwsgi.pid # 日志文件,因?yàn)閡wsgi可以脫離終端在后臺(tái)運(yùn)行,日志看不見。我們以前的runserver是依賴終端的 daemonize=uwsgi.log # 指定依賴的虛擬環(huán)境 virtualenv=/opt/luffy/ # clear environment on exit #退出時(shí)清除環(huán)境 vacuum = true
(2) 修改文件所有者, 如果用root啟動(dòng)可忽略此步驟
chown -R nginx.nginx /opt/luffy/luffy/
也可以把nginx換成當(dāng)前登錄用戶的用戶名,其它用戶也可以。
(3) 啟動(dòng)uwsgi , 記得啟動(dòng)MySQL數(shù)據(jù)庫和redis
uwsgi --ini /opt/luffy/luffy/uwsgi.ini
7 nginx配置
(1) 創(chuàng)建配置文件
vim /etc/nginx/conf.d/your.conf
# 設(shè)置后端uwsgi服務(wù)器,可寫多個(gè)用作負(fù)載均衡
upstream luffy {
server 127.0.0.1:8000;
}
# 后端 api服務(wù)器配置
server {
listen 80;
server_name api.youdomain.com;
location / {
include uwsgi_params;
uwsgi_pass luffy;
}
# 加載css、js文件
location ~ .*\.(css|js)$ {
root /opt/luffy/luffy/;
}
}
# 前端頁面服務(wù)器配置
server {
listen 80;
# 不要懷疑,你沒有看錯(cuò)!nginx的80端口可以啟動(dòng) n 個(gè)域名!
server_name youdomain.com www.youdomain.com;
location / {
# /opt/luffyweb/dist/ 為npm run build生成的文件夾
root /opt/luffyweb/dist/;
index index.html;
try_files $uri $uri /index.html;
}
}這是最基本配置,其它優(yōu)化配置就不再贅述!
(2)檢查nginx配置文件語法
nginx -t
(3) 啟動(dòng)nginx
systemctl start nginx
以上是“Vue+Django項(xiàng)目部署的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
本文標(biāo)題:Vue+Django項(xiàng)目部署的示例分析-創(chuàng)新互聯(lián)
本文網(wǎng)址:http://www.chinadenli.net/article48/dhsphp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、網(wǎng)站策劃、網(wǎng)站改版、網(wǎng)站維護(hù)、建站公司、網(wǎng)站營銷
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容