簡介
微服務的系統應用中,閘道器係統使用的是ocelot,ocelot目前已經比較成熟了
ocelot就不做介紹了,等整體介紹完後再進行各類擴充套件介紹,ocelot原始碼地址:https://github.com/ThreeMammals/Ocelot
ocelot目前由很多功能元件組成,每個元件都可以根據自己的實際情況進行擴充套件(暫時不做過多介紹)
本文主要介紹ocelot閘道器使用中個人認為應該最先處理的東西
健康檢查
在實際的應用中閘道器專案都會部署多臺,然後透過nginx進行軟負載,在更新部署閘道器專案的過程中服務肯定是無法使用,這個時候我們就需要利用nginx的健康檢查機制進行控制
閘道器需要給nginx提供一個健康檢查地址,ocelot使用的url path地址進行路由匹配,當匹配不到時會傳回404,所以我們需要單獨處理一個健康檢查地址
Ocelot提供了一個中介軟體配置替換的方法OcelotPipelineConfiguration,我們對OcelotPipelineConfiguration的PreErrorResponderMiddleware中介軟體方法進行擴充套件,程式碼如下:
閘道器和路由配置
閘道器的配置包含四個部分,ReRoutes、DynamicReRoutes、Aggregates、GlobalConfiguration,
ocelot配置的獲取預設是使用配置檔案的方式,上面已經說了閘道器一般都會部署多臺,使用檔案配置還是存在一定弊端
ocelot的配置獲取方法是IFileConfigurationRepository介面,所以如果我們實現了此介面就可以滿足配置儲存方式的擴充套件,目前已擴充套件mysql和redis,程式碼如下
redis:
mysql:
可以看到四項配置裡並不是全部都進行可配置化,如果有需求可以自行增加欄位實現
redis的儲存是大json方式,而mysql是一條一條的,因為配置的管理是以mysql為主,然後同步到其他儲存介質中的
閘道器配置的更新
有載入就有更新,在ocelot中配置的更新是使用自己的實現來完成配置的熱更新,方式如下
1、配置檔案方式是透過配置檔案的IOptionsMonitor的OnChange方式重新載入配置資訊
2、第三方儲存方式是透過預設實現的FileConfigurationPoller方法定時(預設1s)取獲取配置資訊的
所以我們擴充套件的獲取配置形式,在註冊的時候要把FileConfigurationPoller HostedService一同註入進去,程式碼如下
其中涉及到Bucket.DbContext和Bucket.Redis元件很簡單,也可自行實現
配置的管理
其實最開始的時候,使用的是consul儲存配置,然後透過閘道器自帶的配置介面進行配置的管理,但是在ocelot的一次升級的時候出現了一個問題(配置資訊丟失),雖然當時修改了ocelot的原始碼解決了,後來還是決定擴充套件儲存方式,所以上面的獲取配置介面的set方法都不實現了
上面已經說了是已mysql進行配置儲存然後同步到其他介質上,所以我們只要維護好mysql資料庫就可以了
具體程式碼就不貼了,後續會進行具體介紹,管理專案地址:github地址,截幾張管理圖
原文地址:https://www.cnblogs.com/tianxiangzhe/p/10336923.html
.NET社群新聞,深度好文,歡迎訪問公眾號文章彙總 http://www.csharpkit.com