.NET使用YARP通過編碼方式配置域名轉(zhuǎn)發(fā)實(shí)現(xiàn)反向代理
前面介紹了 YARP 通過配置文件的方式配置代理轉(zhuǎn)發(fā)(傳送門),而眾所周知,微軟的一貫作風(fēng)就是能通過配置文件做的事情,通過編碼的方式也能實(shí)現(xiàn)!YARP 也不例外,廢話不多說,直接上代碼!
首先,參照官方文檔,我們先新建一個(gè) InMemoryConfigProvider 類,并且繼承 IProxyConfigProvider 接口,類里面還包含了一個(gè) IProxyConfig 的類,別看漏了噢!
這里多嘴一下,下面的代碼出現(xiàn)了 volatile 關(guān)鍵字,介紹一下它:volatile 是 C# 中用于控制同步的關(guān)鍵字,其意義是針對(duì)程序中一些敏感數(shù)據(jù),不允許多線程同時(shí)訪問,保證數(shù)據(jù)在任何訪問時(shí)刻,最多有一個(gè)線程訪問,以保證數(shù)據(jù)的完整性,volatile 是修飾變量的修飾符。
public class InMemoryConfigProvider : IProxyConfigProvider{ private volatile InMemoryConfig _config; public InMemoryConfigProvider(IReadOnlyList<RouteConfig> routes, IReadOnlyList<ClusterConfig> clusters) {_config = new InMemoryConfig(routes, clusters); } public IProxyConfig GetConfig() => _config; public void Update(IReadOnlyList<RouteConfig> routes, IReadOnlyList<ClusterConfig> clusters) {var oldConfig = _config;_config = new InMemoryConfig(routes, clusters);oldConfig.SignalChange(); } private class InMemoryConfig : IProxyConfig {private readonly CancellationTokenSource _cts = new();public InMemoryConfig(IReadOnlyList<RouteConfig> routes, IReadOnlyList<ClusterConfig> clusters){ Routes = routes; Clusters = clusters; ChangeToken = new CancellationChangeToken(_cts.Token);}public IReadOnlyList<RouteConfig> Routes { get; }public IReadOnlyList<ClusterConfig> Clusters { get; }public IChangeToken ChangeToken { get; }internal void SignalChange(){ _cts.Cancel();} }}
然后添加一個(gè)擴(kuò)展 InMemoryConfigProviderExtensions
public static class InMemoryConfigProviderExtensions{ public static IReverseProxyBuilder LoadFromMemory(this IReverseProxyBuilder builder, IReadOnlyList<RouteConfig> routes, IReadOnlyList<ClusterConfig> clusters) {builder.Services.AddSingleton<IProxyConfigProvider>(new InMemoryConfigProvider(routes, clusters));return builder; }}
接下來就是寫配置了,我個(gè)人還是喜歡在配置文件中寫,但是有動(dòng)態(tài)配置需求的話,又不想登錄服務(wù)器編輯 appsetting 文件,通過編碼的方式確實(shí)更為方便,將配置寫進(jìn)庫或者其它存儲(chǔ)方式里面,那將是隨心所欲??!上代碼:
Program.cs
var routes = new[]{ new RouteConfig() {RouteId = "admin",ClusterId = "admin",Match = new RouteMatch{ Hosts = new string[] {"test1.ysmc.net.cn" }, Path = "{**catch-all}"} }, new RouteConfig() {RouteId = "blazor",ClusterId = "blazor",Match = new RouteMatch{ Hosts = new string[] {"test2.ysmc.net.cn" }, Path = "{**catch-all}"} }};var clusters = new[]{ new ClusterConfig() {ClusterId = "admin",LoadBalancingPolicy = "RoundRobin",Destinations = new Dictionary<string, DestinationConfig>(StringComparer.OrdinalIgnoreCase){ { "admin", new DestinationConfig() { Address = "https://admin.blazor.zone" } }} }, new ClusterConfig() {ClusterId = "blazor",LoadBalancingPolicy = "RoundRobin",Destinations = new Dictionary<string, DestinationConfig>(StringComparer.OrdinalIgnoreCase){ { "blazor", new DestinationConfig() { Address = "https://www.blazor.zone" } }} }};builder.Services.AddReverseProxy().LoadFromMemory(routes, clusters);
上面的配置代碼,跟配置文件方式的節(jié)點(diǎn)和屬性,都是對(duì)應(yīng)的,照著寫就是了
"ReverseProxy": { "Routes": { "admin": { "ClusterId": "admin", "Match": {"Hosts": [ "test1.ysmc.net.cn" ],"Path": "{**catch-all}" } }, "blazor": { "ClusterId": "blazor", "Match": {"Hosts": [ "test2.ysmc.net.cn" ],"Path": "{**catch-all}" } } }, "Clusters": { "admin": { "LoadBalancingPolicy": "RoundRobin", "Destinations": {"admin": { "Address": "https://admin.blazor.zone/"} } }, "blazor": { "LoadBalancingPolicy": "RoundRobin", "Destinations": {"blazor": { "Address": "https://www.blazor.zone/"} } } }}
最終效果還是依舊的完美,感謝大佬的觀看,謝謝!
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章:
1. ASP.NET延遲調(diào)用或多次調(diào)用第三方Web API服務(wù)2. 使用Hangfire+.NET 6實(shí)現(xiàn)定時(shí)任務(wù)管理(推薦)3. .NET6打包部署到Windows Service的全過程4. ASP.NET MVC使用異步Action的方法5. .NET SkiaSharp 生成二維碼驗(yàn)證碼及指定區(qū)域截取方法實(shí)現(xiàn)6. .Net Core和RabbitMQ限制循環(huán)消費(fèi)的方法7. ASP.NET Core依賴注入DI容器的方法實(shí)現(xiàn)8. ASP.NET Core按用戶等級(jí)授權(quán)的方法9. asp.net core應(yīng)用docke部署到centos7的全過程10. ASP.NET堆和棧三之引用類型對(duì)象拷貝和內(nèi)存分配
