自建Nacos的方法請看官方的教程:
https://nacos.io/zh-cn/docs/quick-start.html
搭建好后,添加配置信息。

.NetCore的組件的git地址:https://github.com/nacos-group/nacos-sdk-csharp
操作說明:https://nacos-sdk-csharp.readthedocs.io/en/latest/introduction/gettingstarted.html
一、引用2個組件:
nacos-sdk-csharp.AspNetCore
nacos-sdk-csharp.Extensions.Configuration
二、配置文件appsettings.json
{ "NacosConfig": { "Listeners": [ { "Optional": false, "DataId": "common", "Group": "DEFAULT_GROUP" }, { "Optional": false, "DataId": "demo", "Group": "DEFAULT_GROUP" } ], "Namespace": "public", "ServerAddresses": [ "http://10.10.1.90:8848/" ], "UserName": "nacos", "Password": "nacos", "ConfigUseRpc": false, "NamingUseRpc": false } }
注意:
1、必須要有 ConfigUseRpc和NamingUseRpc這2個參數,若用的是http協議,則都是false ,若用grpc協議則為true.(這個官方提供的demo沒有寫,就會報錯)
2、Listeners 對應配置文件。DataId是配置名稱,Tenant是命名空間名稱。Group組名。
3、ServerAddresses是Nacos的服務器地址,可以添加多個。
4、若是新的命名空間,則 Namespace對應的是命名空間的Id.
5、Listeners里添加的配置文件一定要存在,不要有多余的節點,可以少,但是不可以多。Group也不能填錯。
(這個組件的日志不知道怎么打印出來,誰教一下)
三、program里添加代碼
Host.CreateDefaultBuilder(args) .ConfigureAppConfiguration((context, builder) => { var c = builder.Build(); builder.AddNacosV2Configuration(c.GetSection("NacosConfig")); }) .ConfigureWebHostDefaults(webBuilder => { webBuilder.UseStartup<Startup>(); });
主要是添加了ConfigureAppConfiguration這里的代碼,就是將Nacos的添加的配置文件讀取出來,並且支持熱更新。
四、使用
跟.NetCore自帶的讀取配置文件的方法一致。
比如 :
[ApiController] [Route("[controller]")] public class WeatherForecastController : ControllerBase { private readonly ILogger<WeatherForecastController> _logger; private readonly IConfiguration _configuration; public WeatherForecastController(IConfiguration configuration, ILogger<WeatherForecastController> logger) { _logger = logger; _configuration = configuration; } [HttpGet] public string Get() { var test = _configuration.GetValue<string>("ConnectionStrings:redis"); return test; } }
