網關常見問題

来源:https://www.cnblogs.com/taojietaoge/archive/2023/01/05/17028384.html
-Advertisement-
Play Games

網關常見問題 侯門一入深似海,從此蕭郎是路人 1、什麼是網關 總而言之,網關就是統一入口、鑒權校驗、動態路由和過濾封裝。 2、為什麼需要網關 微服務架構下,單體應用被切割成多個微服務,如果將所有的微服務直接對外暴露,會出現安全方面的各種問題,且內外耦合嚴重。 Gateway 網關架構可以細到為每一個 ...


網關常見問題

 

      侯門一入深似海,從此蕭郎是路人

 

1、什麼是網關

總而言之,網關就是統一入口、鑒權校驗、動態路由和過濾封裝。

2、為什麼需要網關

  • 微服務架構下,單體應用被切割成多個微服務,如果將所有的微服務直接對外暴露,會出現安全方面的各種問題,且內外耦合嚴重。
  •  Gateway 網關架構可以細到為每一個服務的實例單獨配置一個 Gateway,也可以粗到為整個架構配置一個 Gateway。這樣,原本複雜的系統架構就會變得更簡單可控。

3、網關設計

我認為沒有很大的必要去重覆造車,現在市面上較為成熟的網關方案還是挺有借鑒價值的,不過我們仍可以瞭解下網關的設計思路。

不管是何種網關都需要滿足以下的功能和特性: 請求路由、服務註冊、負載均衡、彈力服務、安全、高性能和高可用

請求路由

當客戶端請求過來,調用端無需知道自己實際調用的其它服務地址,統一交給 Gateway 來處理,避免了內部多個微服務直接對外暴露。

服務註冊

網關的服務註冊功能,就是為後端的服務實例提供服務的地址註冊、取消註冊,也就是註冊一些 API 介面。這樣 Gateway 就可以根據接收到的請求中的信息來決定路由到正確的後端服務上。

負載均衡

一個網關用於接收多個服務實例,所以網關還需要在各個對等的服務實例上做負載均衡策略。常見的策略就是 Round-Robin 輪詢、權重和最少使用。

彈力服務

網關應該讓應用服務只關心自己的業務邏輯,要引入非同步、重試、冪等、流控、熔斷和監視等彈力服務手段。

安全

外界訪問的第一步就是網關,其安全要求毋庸置疑。打頭陣的網關作為全系統第一道防線對後端的服務進行保護,基本要滿足SSL 加密及證書管理、Session 驗證、授權、數據校驗,以及對請求源進行惡意攻擊的防範。

4、網關落地

瞭解了大概的網關設計思路,可以根據公司項目業務需求進行技術選型,現主要分為流量網關業務網關兩大類。

流量網關

流量網關,大致就是控制流量進入集群的一類網關,比如一個服務集群有很多非法或無效的請求,需要將請求拒之門外,降低集群的流量壓力。

業務網關

業務網關更註重與伺服器應用層交互,如各個微服務的許可權控制、日誌輸出、數據加密和熔斷限流等。

5、常見的開源網關

OpenResty

  • OpenResty是一個流量網關。
  • OpenResty是基於 Nginx Lua 的高性能 Web 平臺,其內部集成了大量精良的 Lua 庫、第三方模塊以及大多數的依賴項。用於方便地搭建能夠處理超高併發、擴展性極高的Web 服務和動態網關。

Kong

  • Kong 是基於OpenResty開發的一個流量層網關,是一個雲原生、快速、可擴展、分散式的Api 網關
  • Kong繼承了OpenResty的高性能、易擴展性等特點,且支持通過簡單的增加機器節點,可以很容易的水平擴展。
  • Kong優化了網關的訪問限制、安全、流量控制、分析監控、日誌、請求轉發和合成功能相關功能。
  • Kong更加專註於全局的Api管理策略,如全局流量監控、日誌記錄、全局限流、黑白名單控制、接入請求到業務系統的負載均衡等。

Zuul1.0

  • ZuulNetflix開發的一套通用API網關,Zuul1.0採用同步阻塞架構,優化後的Zuul2,用Netty Server代替Servlet,升級為非同步非阻塞架構。
  • Zuul使用了一系列不同類型的過濾器,夠快速靈活地將動態路由、監視、彈性和安全性等功能應用到服務中。
  • Zuul提供了一個動態讀取、編譯和運行這些過濾器的框架。過濾器之間不直接通信,而是通過每個請求特有的RequestContext共用狀態。

Spring Cloud Gateway

  • SpringCloud Gateway Spring Cloud 生態系統中的網關,底層使用了高性能的通信框架Netty,其目的就是為微服務架構提供一種簡單有效的統一的 API 路由管理方式,替代 Zuul 實現微服務全家桶技術棧。
  • Spring Cloud Gateway 不僅提供統一的路由方式,並且基於 Filter 鏈的方式提供了網關基本的功能,例如:安全、監控/指標、集成熔斷和限流。

 

 

 

 

侯門一入深似海 從此蕭郎是路人

 

 

 

 


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

-Advertisement-
Play Games
更多相關文章
  • 本文簡介 點贊 + 關註 + 收藏 = 學會了 記錄一個在使用 HBuilderX 開發 App 時遇到的問題。 同步資源失敗,未得到同步資源的授權,請停止運行後重新運行,並註意手機上的授權提示 出現這個問題的原因是我把手機的 HBuilder App 給刪掉了,通過電腦連接數據線的方式安裝就會提示 ...
  • 小程式≠微信小程式 說到小程式,大部分同學的第一反應,可能是微信小程式、支付寶小程式,確實,小程式的概念深入人心,並且已經被約定俗成的綁定到某些互聯網公司的 APP 上。 但是,“小程式”並不是一個註冊商標,也不是哪一家的專利。 小程式作為一種人機交互的軟體載體、一種數字內容格式、一種代碼分發傳播機 ...
  • Scanner的幾個常用next輸入方法要點 1. next(): 一直接收從鍵盤中打入的內容直到讀取到回車,==此回車並不會被讀取==,且一定要讀取到有效字元後才可以結束輸入。 對輸入有效字元之前遇到的空格鍵、Tab鍵或Enter鍵等結束符,next()方法會自動將其去掉,只有在輸入有效字元之後, ...
  • .gitignore文件配置 .gitignore 文件可以用來忽略被指定的文件或文件夾的改動。記錄在.gitignore文件里的文件或文件夾是不會被 git 跟蹤到,也就是被忽略的文件是不會被上傳到遠程倉庫的,如果文件已經存在於遠程倉庫中就無法通過.gitignore文件來忽略。 下麵總結了一些可 ...
  • 由char和byte的關係引申出去——總結一下java中的字元編碼相關知識 一、字元編碼 手持兩把錕斤拷,口中直呼燙燙燙 ​ 在文章伊始,先來複習一下電腦中關於編碼的一些基礎知識,著重理清以下幾個基本概念。 1. 碼點(code point) ​ 電腦只能以二進位的形式存儲文字,故而電腦中每一 ...
  • 2023-01-05 一、設置購物項加號 (1)找到“+”號的位置,在“cart.html”中的第61行中,添加單擊事件,通過“非同步”操作來設置 <span class="count" @click="addCount">+</span> (2)在Vue中新建一個函數 addCount:functi ...
  • 題目鏈接 可以通過參考一道例題來加深對dfs的認知和學習 題意描述 按照字典序輸出自然數 1 到 n 所有不重覆的排列,即 n 的全排列,要求所產生的任一數 字序列中不允許出現重覆的數字。 輸出格式 由 1 ∼ n 組成的所有不重覆的數字序列,每行一個序列。每個數字保留 5 個場寬。 數據範圍 :1 ...
  • 2023-01-05 一、CommonResult工具 1、CommonResult工具的目的是:為了方便團隊開發。一般是在使用非同步的時候使用。 2、CommonResult工具的使用: (1)前端發送非同步請求到servlet。 (2)servlet給響應數據的時候,將所有數據都封裝到CommonR ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...