主頁(yè) > 知識(shí)庫(kù) > 使用Nginx反向代理到go-fastdfs的方法示例

使用Nginx反向代理到go-fastdfs的方法示例

熱門標(biāo)簽:金融行業(yè)外呼線路 賀州市地圖標(biāo)注app 高德地圖標(biāo)注無(wú)營(yíng)業(yè)執(zhí)照 百度地圖標(biāo)注要不要錢 智能電話機(jī)器人線路 長(zhǎng)沙開福怎么申請(qǐng)400電話 東莞人工智能電銷機(jī)器人供應(yīng)商 廣州電銷機(jī)器人系統(tǒng)圖 江蘇電銷外呼防封系統(tǒng)是什么

背景

go-fastdfs是支持http協(xié)議的一款分布式文件系統(tǒng),在一般的項(xiàng)目中,很少是直接將文件系統(tǒng)的地址暴露出來(lái)的,大多數(shù)都會(huì)通過(guò)nginx等軟件進(jìn)行反代過(guò)去,由于我司的業(yè)務(wù)和網(wǎng)絡(luò)環(huán)境場(chǎng)景相對(duì)特殊,由公網(wǎng)部分(公有云)和內(nèi)網(wǎng)部分(私有云)組成的混合云網(wǎng)絡(luò)體系,公有云主要就是作為一個(gè)出口和入口以及運(yùn)行一些審計(jì)認(rèn)證等應(yīng)用,對(duì)上游請(qǐng)求進(jìn)行處理,從而減少私有云的處理次數(shù),提升性能。那么也正是因?yàn)檫@樣,在公網(wǎng)的環(huán)境下,要訪問(wèn)到私有云提供的服務(wù)則必須使用反向代理。同樣道理,對(duì)于文件系統(tǒng)的訪問(wèn)也如此,如何在nginx中進(jìn)行配置才能使得外部的網(wǎng)絡(luò)請(qǐng)求可以反向代理到go-fastdfs呢?本文將逐步闡述。

一般配置

在一般的情況下,熟悉nginx的朋友都知道,如果需要配置反向代理,直接寫一個(gè)location上下文和proxy模塊即可,如果需要自定義前綴,使用一個(gè)rewrite模塊即可。簡(jiǎn)單例子如下:

location ~ /dfs/group([0-9]) {
 proxy_pass http://localhost:8080;
 rewrite ^/dfs/(.*)$ /$1 break;
 proxy_set_header Host $host:$server_port;
 proxy_set_header X-Real-IP $remote_addr;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}

到這里,一般的反代配置就算是可以了,那么對(duì)于go-fastdfs而言是否可以了呢?對(duì)于go-fastdfs一般上傳是可以了,但是呢,對(duì)于使用了tus做斷點(diǎn)續(xù)傳還是不夠,為什么呢?因?yàn)閠us服務(wù)端會(huì)返回301重定向,并且需要攜帶一定的請(qǐng)求頭過(guò)去,所以還需要特別的設(shè)置一下。

支持Tus的反代配置

如果需要做tus的反代,要支持301重定向Location的重寫還要支持一定的請(qǐng)求頭轉(zhuǎn)發(fā),那該如何配置呢?請(qǐng)參考下面的配置

location ~ /dfs1/group([0-9]) {
 access_log logs/dfs/access.log main;
 error_log logs/dfs/error.log error;
 rewrite ^/dfs1/(.*)$ /$1 break;
 proxy_pass http://localhost:8051;

 # Disable request and response buffering
 proxy_request_buffering off;
 proxy_buffering off;
 proxy_http_version 1.1;

 proxy_set_header Host $host:$server_port;
 proxy_set_header X-Real-IP $remote_addr;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 # 如果server_name不是公網(wǎng)域名,這個(gè)地方可以設(shè)置成ip
 proxy_set_header X-Forwarded-Host $hostname;
 proxy_set_header X-Forwarded-Proto $scheme;
 proxy_set_header Upgrade $http_upgrade;
 proxy_set_header Connection "upgrade";
 # 因?yàn)槭褂昧饲熬Y加rewrite,所以要修改返回的Location加上反向代理的前綴
 proxy_redirect ~^(.*)/group([0-9])/big/upload/(.*) /dfs/group$2/big/upload/$3;
 client_max_body_size 0;
}

上面要注意一下就是proxy_redirect和client_max_body_size這兩個(gè)配置,第一個(gè)配置是因?yàn)閠us服務(wù)端返回的重定向Location是不會(huì)攜帶自定義前綴的,因此需要自己加入自定義的前綴,我這里是/dfs,如果是別的,更換下就好。第二個(gè)就是client_max_body_size了,這個(gè)是設(shè)置為0表示不管上傳多大的文件都不會(huì)報(bào)request too large的問(wèn)題,直接轉(zhuǎn)發(fā)過(guò)去,如果需要設(shè)置,那么請(qǐng)?jiān)O(shè)置大于等于chunkSize的數(shù)字。什么是chunkSize?就是tus客戶端分塊上傳的時(shí)候,每一塊的大小,具體請(qǐng)參考官方文檔。

負(fù)載均衡配置

在配置了集群服務(wù)器的情況下,上傳或者下載如何進(jìn)行負(fù)載均衡呢?使用nginx做了反代,配合upstream模塊就可以實(shí)現(xiàn)了,具體參考如下配置

upstream dfs_stream {
 server host1:port;
 server host2:port;
 ip_hash;
}

上面的配置和一般的負(fù)載均衡沒(méi)有什么不一樣,唯一要注意的是要配置ip_hash,為什么呢?因?yàn)槭褂脭帱c(diǎn)續(xù)傳的時(shí)候,文件是分塊上傳的,如果不是ip_hash的話,有可能會(huì)前面幾片被上傳到A服務(wù)器,后面幾片被上傳到B服務(wù)器,那么這樣子文件就不是完整的了,因此需要注意這個(gè)問(wèn)題。

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

標(biāo)簽:廊坊 玉樹 北京 松原 張家界 滄州 永州 洛陽(yáng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用Nginx反向代理到go-fastdfs的方法示例》,本文關(guān)鍵詞  使用,Nginx,反向,代理,到,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用Nginx反向代理到go-fastdfs的方法示例》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于使用Nginx反向代理到go-fastdfs的方法示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章