国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

基于 Nginx 的動態代理

wean / 761人閱讀

摘要:目前最常用的軟件反向代理服務器有和。基于實現動態代理為了實現動態代理方案,需要在反向代理服務器中增加定制的功能。同時,由于反向代理服務器需要處理大量的代理請求,因此會頻繁的讀取反向代理配置數據。

基于 Nginx 的動態代理

作者:趙波
日期:2016 年 8 月 4 日

在實際應用中,遇到了這樣一個場景:

已有一個手機 APP 客戶端,需要在該 APP 客戶端中實現通過 Web 的形式接入其他的應用頁面。按照常規的流程,在 APP 中為應用設置入口鏈接按鈕,當用戶點擊應用入口按鈕時,APP 啟動 WebView 并打開設置的應用鏈接即可。

但在該場景中,接入 APP 的應用均部署在內網服務器,外網無法直接訪問,因此在 APP 中配置的鏈接是內網地址,當用戶通過外網使用 APP 時,將無法訪問接入的 Web 應用。

針對如上場景中遇到的問題,本文中提出了基于 Nginx 實現動態代理的解決方案。

使用代理

在前面的場景中,要實現內網應用能夠被外網訪問,一般有兩種方式:

將應用部署到可被外網訪問的服務器,通常為 DMZ 區服務器

使用反向代理服務器,將外網請求代理轉發到內網的應用服務器

其中,將內網應用部署到可被外網訪問的服務器上的方法,通常受限于可提供的硬件環境、安全控制等方面的問題,并不是解決該類問題的首選方案。因此,通常會在可被外網訪問的服務器上部署反向代理服務器,使用代理轉發來解決。

目前最常用的軟件反向代理服務器有 Apache 和 Nginx 。通過配置文件設置,就可以將特定的鏈接向應用服務器轉發。例如 Nginx 可通過以下簡單的配置,即可實現代理轉發:

server
{
    listen 80;
    server_name domain.com;
    location /app1 {
        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;
        proxy_pass http://192.168.10.38:3000/app1;
    }
    access_log logs/domain.com.access.log;
}

在以上實例中,Nginx 配置完成后,即可將 http://domain.com/app 的所有請求代理轉發到 http://192.168.10.38:3000/app1 地址,這樣就可以實現針對 app1 的從外網訪問內網應用的代理轉發功能。此時 app1 對于外網的訪問地址就變成了 http://domain.com/app 。

通過使用代理服務器, 所有的應用將擁有統一域名 ,而通過 二級目錄區分 不同的應用。

在 Apache 中同樣可以采用類似的策略進行代理轉發,本文中主要以 Nginx 作為實例。

在多個接入多個應用的情況下,只要按照上述實例中的配置,為不同的應用分配不同的二級目錄,即可實現向不同應用進行代理轉發。這樣就可以解決文章開始提出的問題。

但是這一解決方案也存在問題:

當需要新增/修改/刪除應用的代理轉發配置時,需要人工修改配置文件,并重啟代理轉發服務器,這將導致服務的暫時不可用。

當接入應用較多時,配置文件將越來越大,對用人工維護造成極大的不便。

當代理轉發服務器進行集群化部署時,每次對配置文件的更新,都需要更新所有代理轉發服務器,并進行重啟,這將增大維護的風險。

針對以上的問題,需要對該訪問進行進一步改進。

使用動態代理

如果能夠使反向代理服務器動態的通過集中的配置數據更新針對應用的代理配置,就可以解決上述方案中存在的問題。

經過研究分析,本文中提出 動態代理 方案,流程如下:

當請求進入反向代理服務器時,反向代理服務器將分析進入的請求 URL ,識別 URL 中的二級目錄(用于區分不同的應用),然后使用該二級目錄作為應用標識,到代理配置數據數據中進行查詢,獲得代理地址的返回結果,然后將該請求轉發到對應的應用服務器。

同時,管理人員可以通過特定的管理端,對代理配置數據進行 CRUD 操作,方便管理人員對代理應用配置的實時管理。

通過以上流程,即可實現在不中斷服務的情況下,動態修改代理配置。同時也可以確保集群化的反向代理服務器同步更新,都可以獲得最新的配置數據。

使用動態代理方案,即可以解決在文章開頭提出的問題。

基于 Nginx 實現動態代理

為了實現動態代理方案,需要在反向代理服務器中增加定制的功能。針對這一目的,研究了目前主流的反向代理服務器 Apache 和 Nginx ,結論如下:

Apache 和 Nginx 均可以增加定制的模塊以實現定制的功能。但是 Apache 目前必須使用 C 語言按照 Apache 的要求編寫模塊,這對于開發者要求相對較高。而 Nginx 同樣可以使用 C 語言開發擴展模塊,但除此之外,目前已有針對 Nginx 開發的 Lua 語言解釋器模塊,即可以在 Nginx 的配置文件中直接調用 Lua 語言開發的腳本程序,這種方式極大的降低了定制功能開發的難度。因此,采用 Nginx 作為反向代理服務器,使用 Lua 語言作為定制功能開發語言,進行動態代理功能實現。

同時,由于反向代理服務器需要處理大量的代理請求,因此會頻繁的讀取反向代理配置數據。基于這一情況,選用 Redis 作為數據庫,利用其高性能的數據讀寫,支撐代理配置數據的頻繁訪問。

根據以上的技術選型,設計流程圖如下:

在 Nginx 的配置文件中通過 Lua 解釋器模塊,調用 Lua 腳本。請求進入 Nginx 后,通過 Lua 腳本處理請求,并連接 Redis 獲取當前 URL 對應的應用的代理地址,處理完成后,將代理地址回寫到 Nginx 的配置塊,由 Nginx 完成后續的代理轉發工作。

在運行期間,管理人員可以使用代理管理端,對 Redis 中的代理配置數據進行操作,操作完成后,Nginx 代理服務器將及時讀取到最新的配置數據進行轉發。

經過調研,在具體開發過程中,采用了基于 Nginx 進行了模塊擴展的 OpenResty。OpenResty 基于 Nginx 擴展了大量的模塊,其中非常核心的特點就是在 Nginx 中集成了 Lua 解釋器,實現了 Nginx 調用 Lua 腳本。同時 OpenResty 還提供了 Lua 語言實現的訪問 Redis 的代碼模塊。

Nginx 動態代理優化 代理配置數據緩存

在實際測試過程中,當訪問量較大時,由于 Nginx 服務器每次代理都會查詢 Redis ,可能是導致 Redis 壓力過大而無法響應,導致請求被阻塞。

為了應對這一問題,在 Nginx 中,使用 Lua 腳本設置內存緩存,從 Redis 獲取的代理數據將在一定時間內保留在 Nginx 服務器的內存中,在內存緩存數據有效期內,將不會再重復向 Redis 請求數據。

經過測試,在進行數據緩存優化后,極大的提高了 Redis 訪問的穩定性。

Redis 集群化

由于單點 Redis 一旦無法提供服務,將導致 Nginx 代理服務無法正常使用。針對這一問題,需要對 Redis 進行集群化。

目前比較成熟的解決方案是對 Redis 進行主從備份,一個主節點提供對外服務,多個從節點進行數據備份,并在主節點停止服務后產生新的主節點繼續提供服務。使用 Redis 提供的 Redis Sentinel 進行主從節點監控,并向 Nginx 提供最新的主節點信息。

Nginx 集群化

隨著訪問量逐漸增大,單機的 Nginx 將無法再支持過大的訪問量,同時單機 Nginx 一旦停止服務,將影響整個系統的正常運行。因此需要將 Nginx 進行集群化,部署多個 Nginx 反向代理服務器,提供同樣的服務。

基于 Nginx 的動態代理方案,提供的代理服務為無狀態服務,因此可以直接復制 Nginx 以實現集群化。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/39359.html

相關文章

  • UCloud基于SD-WAN架構GitHub加速方案

    摘要:客戶收益與展望利用的云網基礎架構,該公司通過較低的成本,在不到一周的時間內,快速搭建一套高速穩定的加速平臺方案。背景Git是目前世界上最流行的分布式版本控制系統,GitHub是一個基于Git的代碼托管平臺,一個擁有143萬開發者的社區,是一個巨大的開源寶庫。作為全球程序員和編程愛好者的聚集地,諸多優秀的開源項目代碼都托管于GitHub上。UCloud深圳某初創客戶,正在開發運營一款海外社交A...

    Tecode 評論0 收藏0
  • koa中利用nginx反向代理動態及靜態文件

    摘要:背景最近在做一個基于的微信公眾平臺腳手架,由于我只有一個域名,現在同時有好幾個應用在上面掛載著,所以只能做一下反向代理,可是反向代理只能代理動態文件,對于靜態資源貌似沒有什么好的解決方法本文針對以上問題進行逐步解決,通過修改相關配置,并結合 背景 最近在做一個基于koa的微信公眾平臺腳手架,由于我只有一個域名demozhan.com,現在同時有好幾個web應用在上面掛載著,所以只能做一...

    opengps 評論0 收藏0
  • koa中利用nginx反向代理動態及靜態文件

    摘要:背景最近在做一個基于的微信公眾平臺腳手架,由于我只有一個域名,現在同時有好幾個應用在上面掛載著,所以只能做一下反向代理,可是反向代理只能代理動態文件,對于靜態資源貌似沒有什么好的解決方法本文針對以上問題進行逐步解決,通過修改相關配置,并結合 背景 最近在做一個基于koa的微信公眾平臺腳手架,由于我只有一個域名demozhan.com,現在同時有好幾個web應用在上面掛載著,所以只能做一...

    figofuture 評論0 收藏0
  • 基于Linux環境搭建Nginx+uWSGI+Python框架方法介紹

    摘要:目前在和平臺下使用最廣泛的免費服務器有和。涉及到普通用戶執行命令時權限不足的問題,可在命令前增加指令解決。是基于二進制的線路協議,與協議作用相同,但屬于服務器自有協議是服務器,它實現了協議等協議安裝。 前言 瀏覽器上網的過程簡單來說即是瀏覽器從服務器中獲取網站信息,經過渲染后將效果呈現給用戶。這里側重介紹下在幕后默默工作著的服務器。Web服務器是運行在物理服務器上的一個程序,永久地等待...

    spacewander 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<