鍍金池/ 教程/ Java/ 反向代理
定時(shí)任務(wù)
函數(shù)的參數(shù)
超時(shí)
一個(gè) openresty 內(nèi)存“泄漏”問題
獲取 uri 參數(shù)
局部變量
sleep
灰度發(fā)布
TIME_WAIT
代碼覆蓋率
連接池
CentOS 平臺(tái)安裝
稀疏數(shù)組
如何只啟動(dòng)一個(gè) timer 工作?
變量的共享范圍
break,return 關(guān)鍵字
Nginx
SQL 注入
如何引用第三方 resty 庫(kù)
不同階段共享變量
獲取請(qǐng)求 body
動(dòng)態(tài)生成的 lua-resty-redis 模塊方法
動(dòng)態(tài)加載證書和 OCSP stapling
repeat 控制結(jié)構(gòu)
編碼為 array 還是 object
Nginx 靜態(tài)文件服務(wù)
執(zhí)行階段概念
Lua 函數(shù)
日期時(shí)間函數(shù)
健康監(jiān)測(cè)
與其他 location 配合
for 控制結(jié)構(gòu)
函數(shù)定義
HTTPS 時(shí)代
點(diǎn)號(hào)與冒號(hào)操作符的區(qū)別
String 庫(kù)
文件操作
OpenResty 最佳實(shí)踐
<code>ngx.shared.DICT</code> 非隊(duì)列性質(zhì)
使用動(dòng)態(tài) DNS 來(lái)完成 HTTP 請(qǐng)求
代碼規(guī)范
什么是 JIT?
Windows 平臺(tái)安裝
正確的記錄日志
LuaNginxModule
不用標(biāo)準(zhǔn)庫(kù)
C10K 編程
控制結(jié)構(gòu)
請(qǐng)求中斷后的處理
Lua 環(huán)境搭建
Test::Nginx 能指定現(xiàn)成的 nginx.conf,而不是自動(dòng)生成一個(gè)嗎
Lua 基礎(chǔ)數(shù)據(jù)類型
動(dòng)態(tài)限速
PostgresNginxModule
簡(jiǎn)單API Server框架
API 測(cè)試
location 匹配規(guī)則
虛變量
單元測(cè)試
防止 SQL 注入
select + set_keepalive 組合操作引起的數(shù)據(jù)讀寫錯(cuò)誤
阻塞操作
全動(dòng)態(tài)函數(shù)調(diào)用
Web 服務(wù)
典型應(yīng)用場(chǎng)景
Nginx 新手起步
TLS session resumption
輸出響應(yīng)體
調(diào)用代碼前先定義函數(shù)
module 是邪惡的
怎樣理解 cosocket
模塊
Socket 編程發(fā)展
如何對(duì) Nginx Lua module 添加新 api
如何在后臺(tái)開啟輕量級(jí)線程完成定時(shí)任務(wù)?
如何定位問題
table 庫(kù)
json 解析的異常捕獲
如何安裝火焰圖生成工具
lua 中如何 continue
if 是邪惡的
為什么我們的域名不能被解析
抵制使用 module() 定義模塊
測(cè)試
body 在 location 中的傳遞
Lua 入門
子查詢
pipeline 壓縮請(qǐng)求數(shù)量
如何發(fā)起新 HTTP 請(qǐng)求
Lua 簡(jiǎn)介
緩存失效風(fēng)暴
Ubuntu 平臺(tái)安裝
日志輸出
緩存
Lua 面向?qū)ο缶幊?/span>
Nginx 陷阱和常見錯(cuò)誤
Redis 接口的二次封裝(發(fā)布訂閱)
日志
訪問有授權(quán)驗(yàn)證的 Redis
正則表達(dá)式
lock
熱裝載代碼
調(diào)用 FFI 出現(xiàn) &quot;table overflow&quot;
數(shù)據(jù)合法性檢測(cè)
禁止某些終端訪問
控制結(jié)構(gòu) if-else
調(diào)試
與 Docker 使用的網(wǎng)絡(luò)瓶頸
PostgresNginxModule 模塊的調(diào)用方式
用 do-end 整理你的代碼
FFI
什么時(shí)候使用
簡(jiǎn)介
環(huán)境搭建
Mac OS X 平臺(tái)安裝
火焰圖
負(fù)載均衡
while 型控制結(jié)構(gòu)
如何定位 openresty 崩潰 bug
使用 Nginx 內(nèi)置綁定變量
判斷數(shù)組大小
請(qǐng)求返回后繼續(xù)執(zhí)行
Redis 接口的二次封裝
KeepAlive
反向代理
協(xié)議無(wú)痛升級(jí)
數(shù)學(xué)庫(kù)
元表
Vanilla 介紹
HelloWorld
LuaCjsonLibrary
持續(xù)集成
代碼靜態(tài)分析
網(wǎng)上有大量對(duì) Lua 調(diào)優(yōu)的推薦,我們應(yīng)該如何看待?
script 壓縮復(fù)雜請(qǐng)求
非空判斷
性能測(cè)試
函數(shù)返回值
API 的設(shè)計(jì)
kong 介紹
表達(dá)式
不支持事務(wù)
LuaRestyDNSLibrary 簡(jiǎn)介

反向代理

什么是反向代理

反向代理(Reverse Proxy)方式是指用代理服務(wù)器來(lái)接受 internet 上的連接請(qǐng)求,然后將請(qǐng)求轉(zhuǎn)發(fā)給內(nèi)部網(wǎng)絡(luò)上的服務(wù)器,并將從服務(wù)器上得到的結(jié)果返回給 internet 上請(qǐng)求連接的客戶端,此時(shí)代理服務(wù)器對(duì)外就表現(xiàn)為一個(gè)反向代理服務(wù)器。

舉個(gè)例子,一個(gè)用戶訪問 http://www.example.com/readme,但是 www.example.com 上并不存在 readme 頁(yè)面,它是偷偷從另外一臺(tái)服務(wù)器上取回來(lái),然后作為自己的內(nèi)容返回給用戶。但是用戶并不知情這個(gè)過程。對(duì)用戶來(lái)說,就像是直接從 www.example.com 獲取 readme 頁(yè)面一樣。這里所提到的 www.example.com 這個(gè)域名對(duì)應(yīng)的服務(wù)器就設(shè)置了反向代理功能。

反向代理服務(wù)器,對(duì)于客戶端而言它就像是原始服務(wù)器,并且客戶端不需要進(jìn)行任何特別的設(shè)置??蛻舳讼蚍聪虼淼拿臻g(name-space)中的內(nèi)容發(fā)送普通請(qǐng)求,接著反向代理將判斷向何處(原始服務(wù)器)轉(zhuǎn)交請(qǐng)求,并將獲得的內(nèi)容返回給客戶端,就像這些內(nèi)容原本就是它自己的一樣。如下圖所示:

http://wiki.jikexueyuan.com/project/openresty/images/proxy.png" alt="proxy" />

反向代理典型應(yīng)用場(chǎng)景

反向代理的典型用途是將防火墻后面的服務(wù)器提供給 Internet 用戶訪問,加強(qiáng)安全防護(hù)。反向代理還可以為后端的多臺(tái)服務(wù)器提供負(fù)載均衡,或?yàn)楹蠖溯^慢的服務(wù)器提供 緩沖 服務(wù)。另外,反向代理還可以啟用高級(jí) URL 策略和管理技術(shù),從而使處于不同 web 服務(wù)器系統(tǒng)的 web 頁(yè)面同時(shí)存在于同一個(gè) URL 空間下。

Nginx 的其中一個(gè)用途是做 HTTP 反向代理,下面簡(jiǎn)單介紹 Nginx 作為反向代理服務(wù)器的方法。

場(chǎng)景描述:訪問本地服務(wù)器上的 README.md 文件 http://localhost/README.md,本地服務(wù)器進(jìn)行反向代理,從 https://github.com/moonbingbing/openresty-best-practices/blob/master/README.md 獲取頁(yè)面內(nèi)容。

nginx.conf 配置示例:

worker_processes 1;

pid logs/nginx.pid;
error_log logs/error.log warn;

events {
    worker_connections 3000;
}

http {
    include mime.types;
    server_tokens off;

    ## 下面配置反向代理的參數(shù)
    server {
        listen    80;

        ## 1. 用戶訪問 http://ip:port,則反向代理到 https://github.com
        location / {
            proxy_pass  https://github.com;
            proxy_redirect     off;
            proxy_set_header   Host             $host;
            proxy_set_header   X-Real-IP        $remote_addr;
            proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
        }

        ## 2.用戶訪問 http://ip:port/README.md,則反向代理到
        ##   https://github.com/.../README.md
        location /README.md {
            proxy_set_header  X-Real-IP  $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_pass https://github.com/moonbingbing/openresty-best-practices/blob/master/README.md;
        }
    }
}

成功啟動(dòng) Nginx 后,我們打開瀏覽器,驗(yàn)證下反向代理的效果。在瀏覽器地址欄中輸入 localhost/README.md,返回的結(jié)果是我們 GitHub 源代碼的 README 頁(yè)面。如下圖:

http://wiki.jikexueyuan.com/project/openresty/images/proxy_example.png" alt="proxy_example" />

我們只需要配置一下 nginx.conf 文件,不用寫任何 web 頁(yè)面,就可以偷偷地從別的服務(wù)器上讀取一個(gè)頁(yè)面返回給用戶。

下面我們來(lái)看一下 nginx.conf 里用到的配置項(xiàng):

(1) location

location 項(xiàng)對(duì)請(qǐng)求 URI 進(jìn)行匹配,location 后面配置了匹配規(guī)則。例如上面的例子中,如果請(qǐng)求的 URI 是 localhost/,則會(huì)匹配 location / 這一項(xiàng);如果請(qǐng)求的 URI 是 localhost/README.md,則會(huì)匹配 location /README.md 這項(xiàng)。

上面這個(gè)例子只是針對(duì)一個(gè)確定的 URI 做了反向代理,有的讀者會(huì)有疑惑:如果對(duì)每個(gè)頁(yè)面都進(jìn)行這樣的配置,那將會(huì)大量重復(fù),能否做 批量 配置呢?此時(shí)需要配合使用 location 的正則匹配功能。具體實(shí)現(xiàn)方法可參考本書的 URL 匹配章節(jié)。

(2) proxy_pass

proxy_pass 后面跟著一個(gè) URL,用來(lái)將請(qǐng)求反向代理到 URL 參數(shù)指定的服務(wù)器上。例如我們上面例子中的 proxy_pass https://github.com,則將匹配的請(qǐng)求反向代理到 https://github.com。

(3) proxy_set_header

默認(rèn)情況下,反向代理不會(huì)轉(zhuǎn)發(fā)原始請(qǐng)求中的 Host 頭部,如果需要轉(zhuǎn)發(fā),就需要加上這句:proxy_set_header Host $host;

除了上面提到的常用配置項(xiàng),還有 proxy_redirect、proxy_set_body、proxy_limit_rate 等參數(shù),具體用法可以到Nginx 官網(wǎng)查看。

正向代理

既然有反向代理,自然也有正向代理。簡(jiǎn)單來(lái)說,正向代理就像一個(gè)跳板,例如一個(gè)用戶訪問不了某網(wǎng)站(例如 www.google.com),但是他能訪問一個(gè)代理服務(wù)器,這個(gè)代理服務(wù)器能訪問 www.google.com,于是用戶可以先連上代理服務(wù)器,告訴它需要訪問的內(nèi)容,代理服務(wù)器去取回來(lái)返回給用戶。例如一些常見的翻墻工具、游戲代理就是利用正向代理的原理工作的,我們需要在這些正向代理工具上配置服務(wù)器的 IP 地址等信息。