Ocelot簡易教程(一)之Ocelot是什麼

做者:依樂祝
原文地址:http://www.javashuo.com/article/p-gpeksziu-cg.htmlhtml

Ocelot簡易教程目錄

  1. Ocelot簡易教程(一)之Ocelot是什麼
  2. Ocelot簡易教程(二)之快速開始1
  3. Ocelot簡易教程(二)之快速開始2
  4. Ocelot簡易教程(三)之主要特性及路由詳解
  5. Ocelot簡易教程(四)之請求聚合以及服務發現
  6. Ocelot簡易教程(五)之集成IdentityServer認證以及受權
  7. Ocelot簡易教程(六)之重寫配置文件存儲方式並優化響應數據
  8. Ocelot簡易教程(七)之配置文件數據庫存儲插件源碼解析
    簡單的說Ocelot是一個用.NET Core實現而且開源的API網關技術。
    可能你又要問了,什麼是API網關技術呢?Ocelot又有什麼特別呢?咱們又該如何集成到咱們的asp.net core程序中呢?
    下面我會經過一些列通俗易懂的教程來爲你們講解。今天的這篇文檔先給你們簡述下什麼是API網關技術,以及Ocelot是什麼,一個Ocelot的總體架構。git

    API網關是什麼?

    API網關是系統暴露在外部的一個訪問入口。就像一個公司的門衛承擔着尋址、限制進入、安全檢查、位置引導、等等功能。從面向對象設計的角度看,它與外觀模式相似。API網關封裝了系統內部架構,爲每一個客戶端提供一個定製的API。它可能還具備其它職責,如身份驗證、監控、負載均衡、緩存、請求分片與管理、靜態響應處理等等。
    API網關方式的核心要點是,全部的客戶端和消費端都經過統一的網關接入微服務,在網關層處理全部的非業務功能。一般,網關也是提供REST/HTTP的訪問API。服務端經過API-GW註冊和管理服務。github

    Ocelot在API網關實現上有什麼優勢呢?

    首先,上面已經講述了Ocelot是一個用.NET Core技術實現而且開源的API網關技術。除此以外還有什麼優勢呢?那就是它強大的功能以及使用上的簡單了。它的功能包括了:路由、請求聚合、服務發現、認證、鑑權、限流熔斷、並內置了負載均衡器、Service Fabric、Skywalking等的集成。並且這些功能都只須要簡單的配置便可完成。
    目前,騰訊和微軟是Ocelot在官網貼出來的客戶。
    另外,附上Ocelot的開源地址:https://github.com/ThreeMammals/Ocelotweb

    Ocelot工做流程是怎樣的呢?

    實際上Ocelot就是一系列按特定順序排列的中間件。
    Ocelot首先經過配置將HttpRequest對象保存到一個指定的狀態直到它到達用來建立HttpRequestMessage對象並將建立的HttpRequestMessage對象發送到下游服務中的請求構造中間件。經過中間件來發出請求是Ocelot管道中作的最後一件事。它不會再調用下一個中間件。下游服務的響應會存儲在每一個請求 scoped repository中,並做爲一個請求返回到Ocelot管道中。有一箇中間件將HttpResponseMessage映射到HttpResponse對象並返回給客戶端。
    接下來是你使用Ocelot是可能會使用的配置。數據庫

    基本集成

OcelotBasic

用一臺web service來host Ocelot,在這裏有一個json配置文件,裏面設置了全部對當前這個網關的配置。它會接收全部的客戶端請求,並路由到對應的下游服務器進行處理,再將請求結果返回。而這個上下游請求的對應關係也被稱之爲路由。json

集成 IdentityServer

OcelotIndentityServer

當咱們涉及到認證和鑑權的時候,咱們能夠跟Identity Server進行結合。當網關須要請求認證信息的時候會與Identity Server服務器進行交互來完成。api

網關集羣配置

OcelotMultipleInstances

只有一個網關是很危險的,也就是咱們一般所講的單點,只要它掛了,全部的服務全掛。這顯然沒法達到高可用,因此咱們也能夠部署多臺Ocelot網關。固然這個時候在多臺網關前,你還須要一臺負載均衡器。緩存

結合Consul服務發現

OcelotMultipleInstancesConsul (1)

在Ocelot已經支持簡單的負載功能,也就是當下遊服務存在多個結點的時候,Ocelot可以承擔起負載均衡的做用。可是它不提供健康檢查,服務的註冊也只能經過手動在配置文件裏面添加完成。這不夠靈活而且在必定程度下會有風險。這個時候咱們就能夠用Consul來作服務發現,它能與Ocelot完美結合。安全

結合Service Fabric

OcelotServiceFabric

總結

本文首先介紹了API網關的概念,進而引出asp.net core中的一個開源的API網關技術Ocelot。並介紹了Ocelot的優勢以及工做原理及架構圖。接下來會詳細介紹Ocelot如何經過簡單地配置實現路由、請求聚合、服務發現、認證、鑑權、限流熔斷、並內置了負載均衡器、Service Fabric、Skywalking等等功能。服務器

相關文章
相關標籤/搜索