中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用Nginx配置反向代理

發布時間:2022-05-21 10:48:20 來源:億速云 閱讀:164 作者:iii 欄目:大數據

本篇內容主要講解“如何使用Nginx配置反向代理”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何使用Nginx配置反向代理”吧!

一般配置

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

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;
}

到這里,一般的反代配置就算是可以了,那么對于go-fastdfs而言是否可以了呢?對于go-fastdfs一般上傳是可以了,但是呢,對于使用了tus做斷點續傳還是不夠,為什么呢?因為tus服務端會返回301重定向,并且需要攜帶一定的請求頭過去,所以還需要特別的設置一下。

支持tus的反代配置

如果需要做tus的反代,要支持301重定向location的重寫還要支持一定的請求頭轉發,那該如何配置呢?請參考下面的配置

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不是公網域名,這個地方可以設置成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";
 # 因為使用了前綴加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這兩個配置,第一個配置是因為tus服務端返回的重定向location是不會攜帶自定義前綴的,因此需要自己加入自定義的前綴,我這里是/dfs,如果是別的,更換下就好。第二個就是client_max_body_size了,這個是設置為0表示不管上傳多大的文件都不會報request too large的問題,直接轉發過去,如果需要設置,那么請設置大于等于chunksize的數字。什么是chunksize?就是tus客戶端分塊上傳的時候,每一塊的大小,具體請參考。

負載均衡配置

在配置了集群服務器的情況下,上傳或者下載如何進行負載均衡呢?使用nginx做了反代,配合upstream模塊就可以實現了,具體參考如下配置

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

上面的配置和一般的負載均衡沒有什么不一樣,唯一要注意的是要配置ip_hash,為什么呢?因為使用斷點續傳的時候,文件是分塊上傳的,如果不是ip_hash的話,有可能會前面幾片被上傳到a服務器,后面幾片被上傳到b服務器,那么這樣子文件就不是完整的了,因此需要注意這個問題。

到此,相信大家對“如何使用Nginx配置反向代理”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

瑞昌市| 冷水江市| 揭西县| 高清| 汉沽区| 深州市| 晋州市| 府谷县| 丰原市| 射洪县| 新民市| 二连浩特市| 云林县| 宁波市| 仙桃市| 聂拉木县| 深泽县| 南汇区| 襄樊市| 夏河县| 定兴县| 嘉兴市| 缙云县| 封丘县| 南澳县| 武汉市| 连城县| 淅川县| 长春市| 乌什县| 宣威市| 宜城市| 西乌珠穆沁旗| 乌拉特前旗| 彰化县| 安乡县| 齐齐哈尔市| 辽中县| 东莞市| 岱山县| 崇左市|