server - Nginx配置webapp問題
問題描述
新手自學(xué),nginx在AWS部署。在服務(wù)器正常安裝nginx無問題順利打開歡迎頁Welcome to Nginx!
然后創(chuàng)建nginx配置文件,軟連接到/etc/nginx/sites-enabled/,檢查軟鏈正確,通過nginx自帶檢查配置文件命令顯示語法等也顯示正確
server { listen 80; server_name xxxxx;location / {proxy_pass http://localhost:8000; }}
刪除掉/etc/nginx/sites-enabled/里面的default,重啟nginx服務(wù)啟動python django的webapp,無報錯,運(yùn)行在127.0.0.1:8000上
然而最后結(jié)果是:“無法連接”。后看過nginx的doc里面的example,看不出問題所在。目前認(rèn)為問題應(yīng)該出在配置nginx方面,因為我一旦刪掉我自己的配置文件,恢復(fù)default,重啟nginx就能夠恢復(fù)到歡迎頁。而webapp多次測試路徑也經(jīng)過校正不存在問題。請求解決辦法,謝謝!
新的代碼為:
server { listen 80; server_name xxxxx;location / {root ~/sites/source #網(wǎng)站根目錄index index.htmlproxy_pass http://localhost:8000; }}
或把root和index放到location上面,見下圖
運(yùn)行時端口依然被占:
后proxy_pass改為轉(zhuǎn)發(fā)5000端口,正常運(yùn)作,但網(wǎng)頁依然無法打開
問題解答
回答1:應(yīng)該是你沒有指定document_root和index。
回答2:問題解決
因為問題肯定出現(xiàn)在配置上,而apt-get的方法安裝nginx造成無法自定義編譯很難查清楚所在,nginx不支持添加模塊,只能在編譯時進(jìn)行。故apt-get也沒有日志可看。所以重新下載nginx-1.10.1編譯安裝,編譯包模塊選擇最基本的http模塊方便調(diào)試起見再加debug模塊,證實,最后最簡方案為編譯到--prefix=/usr/local下完成安裝,直接修改總的配置文件為(無需uwsgi和root等):
http{ server {listen 80;server_name xxxxx; location / { proxy_pass http://localhost:8000;} }}
另加上默認(rèn)的events就可以通過最基本的配置文件驗證,其他全部注釋掉,也無需再去刪除默認(rèn)的配置文件,reload重啟,并順利運(yùn)行。
相關(guān)文章:
1. css - 如何把一個視圖放在左浮動定位的視圖的上面?2. python的正則怎么同時匹配兩個不同結(jié)果?3. php多任務(wù)倒計時求助4. javascript - axios請求回來的數(shù)據(jù)組件無法進(jìn)行綁定渲染5. javascript - vue中怎么使用原生js插件6. MySQL的聯(lián)合查詢[union]有什么實際的用處7. javascript - jquery怎么讓a標(biāo)簽跳轉(zhuǎn)后保持tab的樣式8. css - 子元素跑到父元素外面9. javascript - 小demo:請教怎么做出類似于水滴不斷擴(kuò)張的效果?10. javascript - 請問下面代碼中的...是擴(kuò)展運(yùn)算符還是操作運(yùn)算符?這樣寫是什么意思?
