網關常見問題

来源: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
  • 移動開發(一):使用.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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...