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,無報錯,運行在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上面,見下圖
運行時端口依然被占:
后proxy_pass改為轉(zhuǎn)發(fā)5000端口,正常運作,但網(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重啟,并順利運行。
相關(guān)文章:
1. javascript - 如何將一個div始終固定在某個位置;無論屏幕和分辨率怎么變化;div位置始終不變2. html - vue項目中用到了elementUI問題3. javascript - 原生canvas中如何獲取到觸摸事件的canvas內(nèi)坐標(biāo)?4. javascript - vscode alt+shift+f 格式化js代碼,通不過eslint的代碼風(fēng)格檢查怎么辦。。。5. javascript - 求解答:實例對象調(diào)用constructor,此時constructor內(nèi)的this的指向?6. javascript - 有什么比較好的網(wǎng)頁版shell前端組件?7. java - 如何寫一個intellij-idea插件,實現(xiàn)編譯時修改源代碼的目的8. javascript - [js]為什么畫布里不出現(xiàn)圖片呢?在線等9. java 中Long 類型如何轉(zhuǎn)換成Double?10. html5 - 有可以一次性把所有 css外部樣式轉(zhuǎn)為html標(biāo)簽內(nèi)style=" "的方法嗎?
