搭建Nginx正向代理服務

来源:https://www.cnblogs.com/Dfengshuo/archive/2019/11/22/11911406.html
-Advertisement-
Play Games

需求背景: 前段時間公司因為業務需求需要部署一個正向代理,需要內網服務通過正向代理訪問到外網移動端廠商功能變數名稱通道等效果,之前一直用nginx做四層或者七層的反向代理,正向代理還是第一次配置,配置的過程也遇到些小坑,今天就分享出來。 安裝環境準備: nginx本身是不支持https協議請求轉發,為了讓n ...


需求背景:

    前段時間公司因為業務需求需要部署一個正向代理,需要內網服務通過正向代理訪問到外網移動端廠商功能變數名稱通道等效果,之前一直用nginx做四層或者七層的反向代理,正向代理還是第一次配置,配置的過程也遇到些小坑,今天就分享出來。

安裝環境準備:

         nginx本身是不支持https協議請求轉發,為了讓nginx能達到這一效果需要藉助第三方模塊ngx_http_proxy_connect_module。首先下載這一模塊:https://github.com/chobits/ngx_http_proxy_connect_module到伺服器,然後準備nginx環境

yum -y install pcre-devel zlib-devel gcc gcc+c++ make openssl-devel pcre-devel  zlib-devel patch   
tar xf nginx-1.6.0.tar.gz
unzip /root/ngx_http_proxy_connect_module-master.zip
cd  /root/nginx-1.6.0/
patch  -p1 < /root/ngx_http_proxy_connect_module-master/proxy_connect.patch  
./configure --add-module=/root/ngx_http_proxy_connect_module-master/ngx_http_proxy_connect_module
make &&  make install

編譯安裝成功後,配置nginx正向代理:

#user  nobody;
worker_processes  1;
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;
#pid        logs/nginx.pid;
events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;
    #access_log  logs/access.log  main;
    sendfile        on;
    #tcp_nopush     on;
    keepalive_timeout  65;
    #gzip  on;

server {
        listen 88;                #監聽埠
        resolver 183.60.82.98;   #dns解析地址
        server_name  _;
        #charset koi8-r;
        #access_log  logs/host.access.log  main;
        location / {
             proxy_pass https://$host$request_uri;     #設定http代理伺服器的協議和地址 
             proxy_set_header HOST $host;
             proxy_buffers 256 4k;
             proxy_max_temp_file_size 0k;
             proxy_connect_timeout 30;
             proxy_send_timeout 60;
             proxy_read_timeout 60;
             proxy_next_upstream error timeout invalid_header http_502;
            #root   html;
            #index  index.html index.htm;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

    }



server {
       resolver 8.8.8.8;   #dns解析地址
       listen 89;          #代理監聽埠
       proxy_connect;
       proxy_connect_allow            443 563;
       location / {
             proxy_pass https://$host$request_uri;     #設定https代理伺服器的協議和地址 
             proxy_set_header HOST $host;
             proxy_buffers 256 4k;
             proxy_max_temp_file_size 0k;
             proxy_connect_timeout 30;
             proxy_send_timeout 60;
             proxy_read_timeout 60;
             proxy_next_upstream error timeout invalid_header http_502;

       }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

    }   

}  

當配置文件配置好之後保存即可,重啟nginx,進行測試:

去內網伺服器里curl,可以在環境變數里添加代理:

vim  /etc/profile
...
...
#export https_proxy=正向代理IP:埠
export https_proxy=192.168.3.17:89

  

另一種 方式不用加環境變數,臨時代理

#curl -i  --proxy 代理IP:埠      要訪問功能變數名稱
curl -i  --proxy 192.168.3.17:89      www.baidu.com

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近的項目中,有一個編寫linux shell腳本的任務。由於之前不是很熟悉,在這個過程中遇到了很多困難,查找了很多資料,也收穫了很多。下麵是linux shell腳本中常用的知識總結。 1基礎語法 1.1變數 使用一個定義過的變數,只要在變數名前面加美元符號即可 `echo $your_name` ...
  • 需求是統計某個業務的訪問個數日誌伺服器上的目錄結構是如下,搜索最近7天的指定關鍵字數據,併排重統計個數: for迴圈的一行表示形式for ((i=15;i<=21;i++));do xxx;donewhile迴圈的一行表示 while true;do xxx;done獲取當前年月`date +%Y- ...
  • 一 前期準備 1.1 基礎知識 Heketi提供了一個RESTful管理界面,可以用來管理GlusterFS捲的生命周期。Heketi會動態在集群內選擇bricks構建所需的volumes,從而確保數據的副本會分散到集群不同的故障域內。同時Heketi還支持任意數量的ClusterFS集群。 提示: ...
  • 添加用戶--root角色才有許可權 useradd -d主目錄 -m username useradd -d /home/hadoop2 -m hadoop2; 刪除用戶 userdel -f username su #切換root su username #切換回普通用戶 which path #變 ...
  • 1、ifconfig #查看網路(設置IP臨時生效) 2、hostname [主機名] #查看或設置主機名 預設的是localhost 3、ifdown [網卡設備名] #禁用該網卡設備 ifup [網卡設備名] #啟用該網卡設備 與ifconfig [網卡名稱] down或ficonfig [網卡 ...
  • 基於https://www.cnblogs.com/Dfengshuo/p/11911406.html這個基礎上,在來補充下七層代理的配置方式。簡單理解下四層和七層協議負載的區別吧,四層是網路層,負載方式也就是IP+埠的方式負載,七層(應用層)協議的負載方式就是通過URL的方式來進行負載。這就是一 ...
  • 需求背景: 前段時間公司因為業務需求需要部署一個正向代理,我已經分享出來了https://www.cnblogs.com/Dfengshuo/p/11911406.html,現有因架構個更改,需要再加個在原先的反向代理下再加一層,ok,其實還是挺雞肋的,但是沒辦法,領導安排就要根據安排需求做。其實n ...
  • 如今許多網校平臺開始網路直播線上教育培訓,你是不是也想著開發一個這樣的平臺呢,大家跟著我來看一下,這個線上教育系統首頁功能開發到底是怎樣開發呢! 在這裡先給大家嘮叨一下這個開發流程,當客戶在某處找到們開發商信息時,一般會主動找你咨詢具體開發事項,接下來如果雙方確定了合作,首先要對開發需求進行具體溝通 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...