nginx之反向代理
在設定nginx反向代理之間我們得先準備兩台測試伺服器,web1與web2。
1.安裝httpd
[root@web1 ~]# yum install -y httpd [root@web2 ~]# yum install -y httpd
2.提供測試頁面
[root@web1 ~]# echo "<h1>web1.test.com</h1>" > /var/www/html/index.html [root@web2 ~]# echo "<h1>web2.test.com</h1>" > /var/www/html/index.html
3.啟動httpd服務
[root@web1 ~]# service httpd start 正在启动 httpd: [确定] [root@web2 ~]# service httpd start 正在启动 httpd: [确定]
4.測試一下
5.簡單說一下,正向代理與反向代理
(1).正向代理的概念
正向代理,也就是傳說中的代理,他的工作原理就像一個跳板,簡單的說,我是一個用戶,我訪問不了某網站,但是我能訪問一個代理伺服器,這個代理伺服器呢,他能訪問那個我不能訪問的網站,於是我先連上代理伺服器,告訴他我需要那個無法訪問網站的內容,代理伺服器去取回來,然後返回給我。從網站的角度,只在代理伺服器來取內容的時候有一次記錄,有時候並不知道是用戶的請求,也隱藏了用戶的資料,這取決於代理告不告訴網站。
結論就是,正向代理程式是位於客戶端和原始伺服器(origin server)之間的伺服器,為了從原始伺服器取得內容,客戶端向代理程式傳送一個請求並指定目標(原始伺服器),然後代理程式向原始伺服器轉交請求並將獲得的內容傳回給客戶端。客戶端必須要進行一些特別的設定才能使用正向代理。
(2).反向代理的概念
繼續範例:
範例使用者造訪http://www.test. com/readme,但www.test.com上並不存在readme頁面,他是偷偷從另外一台伺服器上取回來,然後作為自己的內容返回用戶,但用戶並不知情。這裡所提到的 www.test.com 這個網域對應的伺服器就設定了反向代理功能。
結論就是,反向代理正好相反,對於客戶端而言它就像是原始伺服器,並且客戶端不需要進行任何特別的設定。客戶端向反向代理的命名空間(name-space)中的內容發送普通請求,接著反向代理將判斷向何處(原始伺服器)轉交請求,並將獲得的內容傳回給客戶端,就像這些內容原本就是它自己的一樣。
(3).兩者差異
從用途來講:
從安全性來講:
以上是nginx之反向代理怎麼配置的詳細內容。更多資訊請關注PHP中文網其他相關文章!