nginx 設置匿名http正向代理

這兩天在研究nginx的正向代理,想通過nginx搭建一個http代理服務器,網站找到了這篇文章(http://www.cnblogs.com/inteliot/archive/2013/01/11/2855907.html):

配置 Nginx Http Proxy 代理服務器,與 [Squid] 功能一樣,適用於正向代理 Http 網站。

一,Nginx 正向代理配置文件:

[html] view plain copy
  1. server {  
  2.     resolver 8.8.8.8;  
  3.     resolver_timeout 5s;  
  4.    
  5.     listen 0.0.0.0:8080;  
  6.    
  7.     access_log  /home/reistlin/logs/proxy.access.log;  
  8.     error_log   /home/reistlin/logs/proxy.error.log;  
  9.    
  10.     location / {  
  11.         proxy_pass $scheme://$host$request_uri;  
  12.         proxy_set_header Host $http_host;  
  13.    
  14.         proxy_buffers 256 4k;  
  15.         proxy_max_temp_file_size 0;  
  16.    
  17.         proxy_connect_timeout 30;  
  18.    
  19.         proxy_cache_valid 200 302 10m;  
  20.         proxy_cache_valid 301 1h;  
  21.         proxy_cache_valid any 1m;  
  22. #allow 127.0.0.1;  
  23. #deny all;  
  24. }  
  25. }  


[text] view plain copy
  1. <span style="font-family:'Helvetica Neue',Helvetica,Arial,sans-serif; font-size:16px">二,Nginx 正向代理配置說明:</span>  

1,配置 DNS 解析 IP 地址,比如 Google Public DNS,以及超時時間(5秒)。

[text] view plain copy
  1. resolver 8.8.8.8;  
  2. resolver_timeout 5s;  

2,配置正向代理參數,均是由 Nginx 變量組成。其中 proxy_set_header 部分的配置,是爲了解決如果 URL 中帶 "."(點)後 Nginx 503 錯誤。

[text] view plain copy
  1. proxy_pass $scheme://$host$request_uri;  
  2. proxy_set_header Host $http_host;  

3,配置緩存大小,關閉磁盤緩存讀寫減少I/O,以及代理連接超時時間。

[text] view plain copy
  1. proxy_buffers 256 4k;  
  2. proxy_max_temp_file_size 0;  
  3. proxy_connect_timeout 30;  

4,配置代理服務器 Http 狀態緩存時間。

[text] view plain copy
  1. proxy_cache_valid 200 302 10m;  
  2. proxy_cache_valid 301 1h;  
  3. proxy_cache_valid any 1m;  

三,不支持代理 Https 網站

因爲 Nginx 不支持 CONNECT,所以無法正向代理 Https 網站(網上銀行,Gmail)。
如果訪問 Https 網站,比如:https://www.google.com,Nginx access.log 日誌如下:

[text] view plain copy
  1. "CONNECT www.google.com:443 HTTP/1.1" 400  

作者寫的很棒,不過,我在配置過程中,遇到問題,就是通過配置的代理訪問頁面都報404(我的nginx版本:1.2),後來我發現需要改下proxy_pass:

[text] view plain copy
  1. proxy_pass $scheme://$host$request_uri;  
改成:

[text] view plain copy
  1. proxy_pass $scheme://$http_host$request_uri;  

這樣就可以了,另外我加上了ip的限制,大家有需要可以將上面的註釋打開就行:

[html] view plain copy
  1. allow 127.0.0.1;  
  2. deny all;  

經驗證,上面的代碼是可以用的。服務器端得到的代碼如下,不過不知道怎麼會帶了一個proxy-connection,這估計只能算是普通匿名,不能算是高級匿名:

[html] view plain copy
  1. head info:{content-type=application/x-www-form-urlencoded; charset=UTF-8, connection=close,  content-length=42user-agent=Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/40.0.2214.111 Safari/537.36, proxy-connection=Keep-Alive}  
發佈了27 篇原創文章 · 獲贊 3 · 訪問量 12萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章