這篇文章主要介紹“Nginx FastDFS不能訪問了怎么辦”,在日常操作中,相信很多人在Nginx FastDFS不能訪問了怎么辦問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”Nginx FastDFS不能訪問了怎么辦”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!
10年積累的成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、成都外貿(mào)網(wǎng)站建設(shè)公司經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先做網(wǎng)站后付款的網(wǎng)站建設(shè)流程,更有藍(lán)山免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
問題重現(xiàn)
在服務(wù)器上搭建集群時(shí),統(tǒng)一對(duì)外訪問的接口為http://192.168.175.110,前端童鞋訪問時(shí),是通過http://192.168.175.101訪問的,并且前端加了一個(gè)前綴file,也就是通過http://192.168.175.101/file來訪問的。第一時(shí)間我想到的是直接將前端的請(qǐng)求通過Nginx轉(zhuǎn)發(fā)到192.168.175.110服務(wù)器。在192.168.175.101服務(wù)器上簡(jiǎn)化后的Nginx配置如下所示。
upstream file { server 192.168.175.110:80 max_fails=3; } server { listen 80; server_name 192.168.175.101; location / { root html; index index.html index.htm; #允許cros跨域訪問 add_header 'Access-Control-Allow-Origin' '*'; #proxy_redirect default; #跟代理服務(wù)器連接的超時(shí)時(shí)間,必須留意這個(gè)time out時(shí)間不能超過75秒,當(dāng)一臺(tái)服務(wù)器當(dāng)?shù)魰r(shí),過10秒轉(zhuǎn)發(fā)到另外一臺(tái)服務(wù)器。 proxy_connect_timeout 10; } location ~/file { add_header 'Access-Control-Allow-Origin' '*'; add_header 'Access-Control-Allow-Credentials' 'true'; proxy_pass http://file; proxy_set_header Host $host:$server_port; } }
我在192.168.175.110服務(wù)器上配置的Ngin如下所示。
server { listen 80; server_name 192.168.175.110; #charset koi8-r; #access_log logs/host.access.log main; location / { root html; index index.html index.htm; #允許cros跨域訪問 add_header 'Access-Control-Allow-Origin' '*'; #proxy_redirect default; #跟代理服務(wù)器連接的超時(shí)時(shí)間,必須留意這個(gè)time out時(shí)間不能超過75秒,當(dāng)一臺(tái)服務(wù)器當(dāng)?shù)魰r(shí),過10秒轉(zhuǎn)發(fā)到另外一臺(tái)服務(wù)器。 proxy_connect_timeout 10; } location ~/group([0-9]){ root /data/fastdfs/storage/data; ngx_fastdfs_module; } }
此時(shí),就存在一個(gè)問題:通過file前綴將請(qǐng)求轉(zhuǎn)發(fā)到192.168.175.110服務(wù)器時(shí),會(huì)返回400狀態(tài)碼。
其實(shí),問題的定位也比較簡(jiǎn)單,就是前端訪問時(shí)多加了一個(gè)file前綴。那么,我們?cè)撊绾谓鉀Q這個(gè)問題呢?
問題解決
一般情況下,Nginx的反向代理,只會(huì)替換域名或者IP部分,其他部分會(huì)按照原樣進(jìn)行轉(zhuǎn)發(fā)。也就是說,前端訪問http://192.168.175.101/file時(shí),會(huì)被轉(zhuǎn)發(fā)到http://192.168.175.110/file上,從而無法正常訪問文件服務(wù)接口。
既然定位到問題了,那我們下一步就是要解決這個(gè)問題。思路也比較簡(jiǎn)單,就是在192.168.175.101服務(wù)器上接收到請(qǐng)求時(shí)將file前綴去掉。那如何去掉呢?
其實(shí)也很簡(jiǎn)單,只需要在192.168.175.101服務(wù)器上的Nginx上添加如下配置。
location ^~/file/ { proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-NginX-Proxy true; proxy_pass http://file/; }
此時(shí),192.168.175.101服務(wù)器上的Nginx配置如下所示。
upstream file { server 192.168.175.110:80 max_fails=3; } server { listen 80; server_name 192.168.175.101; location / { root html; index index.html index.htm; #允許cros跨域訪問 add_header 'Access-Control-Allow-Origin' '*'; #proxy_redirect default; #跟代理服務(wù)器連接的超時(shí)時(shí)間,必須留意這個(gè)time out時(shí)間不能超過75秒,當(dāng)一臺(tái)服務(wù)器當(dāng)?shù)魰r(shí),過10秒轉(zhuǎn)發(fā)到另外一臺(tái)服務(wù)器。 proxy_connect_timeout 10; } location ^~/file/ { proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-NginX-Proxy true; proxy_pass http://file/; } }
此時(shí),再次訪問http://192.168.175.101/file時(shí),就被轉(zhuǎn)發(fā)到http://192.168.175.110上,能夠正確訪問文件服務(wù)接口。
知識(shí)擴(kuò)展
nginx反向代理配置如何去除前綴?
使用Nginx做反向代理的時(shí)候,可以簡(jiǎn)單的直接把請(qǐng)求原封不動(dòng)的轉(zhuǎn)發(fā)給下一個(gè)服務(wù)。設(shè)置proxy_pass請(qǐng)求只會(huì)替換域名,如果要根據(jù)不同的url后綴來訪問不同的服務(wù),則需要通過如下方法:
方法一:加"/"
upstream pay { server localhost:8089 weight=5; } upstream order { server localhost:8090 weight=5; } server { listen 80; server_name binghe.com; location ^~/pay/ { proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-NginX-Proxy true; proxy_pass http://pay/; } location ^~/order/ { proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-NginX-Proxy true; proxy_pass http://order/; } }
^~/pay/表示匹配前綴是pay的請(qǐng)求,proxy_pass的結(jié)尾有/, 則會(huì)把/pay/*后面的路徑直接拼接到后面,即移除pay。
方法二:rewrite
upstream pay { server localhost:8089 weight=5; } upstream order { server localhost:8090 weight=5; } server { listen 80; server_name binghe.com; location ^~/pay/ { proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-NginX-Proxy true; rewrite ^/user/(.*)$ /$1 break; proxy_pass http://pay; } location ^~/order/ { proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-NginX-Proxy true; rewrite ^/order/(.*)$ /$1 break; proxy_pass http://order; } }
到此,關(guān)于“Nginx FastDFS不能訪問了怎么辦”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!