主頁 > 知識庫 > nginx反向代理服務(wù)因配置文件錯(cuò)誤導(dǎo)致訪問資源時(shí)出現(xiàn)404

nginx反向代理服務(wù)因配置文件錯(cuò)誤導(dǎo)致訪問資源時(shí)出現(xiàn)404

熱門標(biāo)簽:硅谷的囚徒呼叫中心 美圖手機(jī) 智能手機(jī) 使用U盤裝系統(tǒng) 檢查注冊表項(xiàng) 百度競價(jià)點(diǎn)擊價(jià)格的計(jì)算公式 網(wǎng)站建設(shè) 阿里云

最近測試手上的項(xiàng)目,出現(xiàn)訪問服務(wù)器的資源出現(xiàn)404的錯(cuò)誤,這個(gè)是不應(yīng)該會(huì)出現(xiàn)的問題,因?yàn)樵诖酥敖?jīng)過測試是沒問題,下面是詳細(xì)情況:

1)公司的服務(wù)器都是做過nginx反向代理

2)訪問路徑是在tomcat中配置過虛擬路徑

3)前幾天服務(wù)器有做過磁盤恢復(fù)

當(dāng)然如果你也遇到過這關(guān)問題,沒解決的可以參考一下,如果解決了就看一下我的解決方案是否有問題,本人剛接觸Nginx不深;

出現(xiàn)這個(gè)問題,我首先考慮應(yīng)該是路徑出現(xiàn)了問題,然后去修改tomcat中的配置文件server.xml中的虛擬路徑;然后再測試,還是出現(xiàn)404;

imgss是server.xml配置的虛擬路徑,1444...png這個(gè)是要訪問的圖片;路徑是沒有問題(但是到nginx那里的時(shí)候就有問題,后面會(huì)貼出nginx的配置文件)這個(gè)是nginx返回的一個(gè)404頁面(當(dāng)時(shí)沒注意到這個(gè)是nginx的);

這就奇怪了,明明服務(wù)器里面的文件都在,怎么會(huì)訪問不到,然后將之前修改的路徑改回去(因?yàn)檫@個(gè)路徑在此之前是做過測試,訪問沒有問題)然后去訪問該路徑下的其他的文件,

發(fā)現(xiàn)訪問居然沒有問題,是可以正常在線預(yù)覽的;然后再凈多多次測試發(fā)現(xiàn)除了jpg,png等格式的文件不能訪問,其他的都可以正常訪問;又將服務(wù)器要訪問的資源在服務(wù)器中刪除,除了jpg,png的文件,然后再重新發(fā)起訪問,出現(xiàn)了正常的404;

imgss是server.xml配置的虛擬路徑,b.PDF本來就不存在;所以出現(xiàn)404很正常;

百度了一下資料,沒有找到解決方案;

再次查看本地jdk和服務(wù)器上的jdk,都沒有問題;有的人說是打包的問題,我重新打包后,發(fā)布到服務(wù)器測試還是同樣的問題;最后想是不是nginx的配置文件的問題,然后去查看nginx的配置文件localhost;這個(gè)是配置文件的路徑/etc/nginx/sites-available/localhost

#號注釋的部分是后面加上去的,之前是沒有,這個(gè)就是nginx的反向代理的配置文件;

注意這一段: location ~ .*\.(jpg|js|html|mp3|gif|jpeg|png|bmp|swf|ico|css)$ #設(shè)定訪問靜態(tài)文件直接讀取不經(jīng)過tomcat

看到這里,相信大家也知道問題出在哪里了,當(dāng)以.jpg/.png等格式文件時(shí),它會(huì)將路徑映射到 /var/lib/tomcat7/webapps/ROOT ;本來在這個(gè)路徑下就沒有你訪問的資源當(dāng)然會(huì)返回nginx的404錯(cuò)誤頁面;然后嘗試將其中的jpg/png刪除掉,然后重啟服務(wù),再次訪問,就正常了;出現(xiàn)這個(gè)問題應(yīng)該是前幾天做磁盤恢復(fù)以后沒有將nginx的配置文件修改的原因;

當(dāng)然最好的做法是,不用刪除.jpg/png;直接在上面添加這段代碼:

location ^~ /imgss/
    {
      #  root /data/customfiles/Files/;
      #  expires 30d;
      proxy_set_header  Host $host;
      proxy_pass http://127.0.0.1:8080;
    }
  location ^~ /attachments/
    {
      #  root /data/
      #  expires 30d;
      proxy_set_header  Host $host;
      proxy_pass http://127.0.0.1:8080
    }

/imgss/和/attachments/都是在tomcat配置文件中配置的虛擬路徑;nginx會(huì)一層層的向下匹配,匹配到合適的就將配置的路徑映射;

server.xml的虛擬路徑:

 <Context path="/imgss" docBase="/data/customfiles/Files/" debug="0" reloadable="true"/>
  <Context path="/attachments" docBase="/data/" debug="0" reloadable="true"/>

比如我們要訪問的路徑是:http://192.168.1.104/imgss/(A)/1444639216522781.png;

經(jīng)由nginx反向代理到:http://192.168.1.104/data/customfiles/Files/(A)/1444639216522781.png也就是該資源在服務(wù)器中實(shí)際的位置;

當(dāng)修改好以后,再次訪問,圖片便能成功加載了;當(dāng)然本人也是剛接觸nginx不久,如果有說錯(cuò)的話請各位指教

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:湘潭 懷化 賀州 煙臺 通遼 湖北 山南 黃山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《nginx反向代理服務(wù)因配置文件錯(cuò)誤導(dǎo)致訪問資源時(shí)出現(xiàn)404》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266