微服務架構中API網關的角色

来源:http://www.cnblogs.com/shsxt/archive/2017/10/17/7681868.html
-Advertisement-
Play Games

【上海尚學堂的話】:本文主要講述了Mashape的首席技術執行官Palladino對API網關的詳細介紹,以及API網關在微服務中所起的作用,同時介紹了Mashape的一款開源API網關Kong。 API網關提供商Mashape的首席技術執行官Marco Palladino預測,儘管它們在命名方面存 ...


上海尚學堂的話】:本文主要講述了Mashape的首席技術執行官Palladino對API網關的詳細介紹,以及API網關在微服務中所起的作用,同時介紹了Mashape的一款開源API網關Kong。

API網關提供商Mashape的首席技術執行官Marco Palladino預測,儘管它們在命名方面存在差異,但新出現的服務網格並不完全不同於API網關,兩者之間的相似性會隨著時間的推移而不斷增長。

Palladino指出,這兩種技術實際上提供了相當類似的功能。API網關,比如Amazon Web Services的API網關或Mashape的開源API網關Kong,已經在過去的十年左右的時間主要用於映射外部流量到內部資源,而最近開發了服務網格——比如Lyft’s EnvoyUber’s Catylist——主要是在微服務架構中代理內部資源。

“當你想到網關的時候,你通常會想到一個集中的層,一個額外的跳在網路上處理附加的功能。但這並不一定是真的,”Palladino上周在洛杉磯舉行的2017年MesosCon上發表的講話。網關還可以提供一種有效的方式來處理跨微服務之間的通信。他說:“你也可以在現有的微服務上運行Kong,擺脫額外的跳躍,減少延遲。”

在過去的10年裡,API一直是一種受歡迎的通信交互方式,Docker使其易於設置微服務架構,其中應用程式和服務是由較小的可交換組件組成。但這些組件之間需要一種方式進行發現與調用。這就是API網關的作用。

API網關“可以成為一個抽象層它位於這些微服務中每個請求的訪問路徑上,”Palladino說道。

網關鞏固了通往系統常用功能的所有路徑,比如身份驗證或者服務發現,通過插件都能被網關識別。“插件是一種有效的中間件功能你能動態應用於所有的微服務上,”他講到。

API網關可以聚合服務請求和這些特性。客戶端可以做出一個響應,網關可以將其分解為多個請求,節省了客戶端自身調用的帶寬。網關同樣還可以跟蹤這些請求。

從單體應用中改造微服務就像從雞身上製作炸雞塊,還要讓雞保持活著。—@thefosk #MesosCon — The New Stack (@thenewstack) 2017年9月14號

當一個組織開始把一個單體應用拆分為微服務時,網關可以將對客戶端的影響最小化。“網關就像裝載單體應用前的一個窗帘。客戶端只會處理網關,而你可以在窗帘後面解耦你的單體應用,不必擔心更新你的客戶端,”他說道。

他說:“當你沒掌控你的客戶端的時候這個特別有用”。

傳統上,API網關在組織網路的邊緣上被使用,處理的流量大部分來自於單體應用和外部客戶端之間的交互。然而微服務架構將大部分的流量轉移到內部網路,因為不同的微服務之間要進行交互。“你可以有外部的客戶端使用案例,但這成為了當前消費微服務的眾多客戶端之一。”

構建在Nginx這高性能的伺服器上,Mashape的Kong是使用最廣泛的開源API網關,一個月超過20W運行實例,Palladino講到。使用Kong,Nginx被擴展到中間件上,能夠動態提供被一個JSON RESTful調用。(上海尚學堂java培訓原作,請多多支持關註,陸續發佈java相關技術文章)

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

-Advertisement-
Play Games
更多相關文章
  • STL
    模板和標準模板庫(STL) 一、模板的起源 變數四要素:類型、名稱、值、地址 數據類型:存儲形式、編碼格式、運算規則、訪問方式 int a = 0; // 補碼 float b = 0; // 階碼 char c = 'A'; // ASCII char_t d = 'A'; // UCS 4 in ...
  • 概述 我們都知道面向對象有四個基本特性:抽象、封裝、繼承、多態。這四個特性,概括起來可以這麼理解,抽象、封裝、繼承是多態的基礎,多態是抽象、封裝、繼承的表現。多態,是Java中非常重要的一個部分,所以今天來談一下多態(Polymorphism)。 什麼是多態 不同類的對象對同一消息作出不同的響應就叫 ...
  • Python 生成器 ...
  • 說到記憶體管理,筆者這裡想先比較一下java與C、C++之間的區別: 在C、C++中,記憶體管理是由程式員負責的,也就是說程式員既要完成繁重的代碼編寫工作又要時常考慮到系統記憶體的維護 在java中,程式員無需考慮記憶體的控制和維護,而是交由JVM自動管理,這樣就不容易出現記憶體泄漏和溢出的問題。然而,一旦出 ...
  • random是內置模塊,使用時直接import random random.random() --> 生成一個0到1的隨機符點數: 0 <= n < 1.0 random.uniform(a,b) --> 生成一個a到b的隨機符點數: a <= n < b random.randint(a,b) - ...
  • 也許上一篇博文提到的property內置函數的用法你還覺得記憶猶新,那麼有沒有更多的類似的方法呢?有的,就是本篇文章要說的魔法方法 魔法方法 1.什麼是魔法方法 (其實前面已經提到多次,每次我都是說暫且不談,後面會提到,在這裡終於填坑了) 總是被雙下劃線包圍的方法,比如__init__ 魔法方法是面 ...
  • 2017-10-16 公司裡面其他人發現了一個問題,五糧液金品庫存出現了問題,刪除了庫存也沒還回來,一瓶一千多。而且在我的功能塊,在我看出貨詳情的時候,詭異的事情發生了,第一眼看上去沒問題呀,刷新了一下,天哪!頁面上的數字隨著我的刷新在變動,刷一下變一下,資料庫也是。想起前幾天,老大說這裡展示有點問 ...
  • 單例模式的要點有三個: 一是某個類只能有一個實例; 二是它必須自行創建這個實例; 三是它必須自行向整個系統提供這個實例。 單例模式的要點有三個: 為什麼要使用PHP單例模式 2.簡單工廠模式 ①抽象基類:類中定義抽象一些方法,用以在子類中實現 ②繼承自抽象基類的子類:實現基類中的抽象方法 ③工廠類: ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...