ASP.NET Core使用Nacos作为配置中心的多环境问题
2023-04-18 14:45:02 时间
前言
双11那天离职后,这段时间都待在家里,看看书,写写代码,逛逛招聘网站
周一去Gworld面试的时候,有听到面试官说他们用到了配置中心Apollo,聊下来,听他的意思,大概是处理了多环境这个比较方便。
于是乎就有了这篇短文,来简单谈谈Nacos做为配置中心时,怎么应对多环境的问题。
现在比较流行的配置中心,说来说去,听的比较多的也就下面几个:
- Apollo
- Spring Config
- Nacos
- consul
- etcd
严格意义上说,只要是支持KV的,都可以做为配置中心来耍,看你对它的需求有多少。
下面就来简单看看用Nacos来做配置中心的多环境问题。
多环境问题
当我们所有的环境都共用一套配置中心的时候,最让我们苦恼的问题应该是要怎么样去隔离这些不同的环境!
在Nacos中,推荐的做法是用NameSpace来区分。
首先要为每个环境建一个命名空间,用作区分的标识。
可以考虑用应用名.环境名
的形式,只要统一就好。
为了演示,往每个命名空间都加一个test的配置,对应的值是环境名。
下面要做的就是在不同环境的配置文件中指定对应的命名空间,这里要用那个命名空间ID。
调整配置文件如下:
然后在Startup
中直接读取。
public class Startup
{
public Startup(IConfiguration configuration)
{
Configuration = configuration;
}
public IConfiguration Configuration { get; }
public void ConfigureServices(IServiceCollection services)
{
services.AddNacos(Configuration);
services.AddControllers();
}
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
var nacosConfigClient = app.ApplicationServices.GetRequiredService<Nacos.INacosConfigClient>();
var val = nacosConfigClient.GetConfigAsync(new Nacos.GetConfigRequest
{
DataId = "test"
}).GetAwaiter().GetResult();
Console.WriteLine($"==={env.EnvironmentName}==={val}===");
// ....
}
}
由于这里是不同环境不同的配置文件,在启动命令上面指定环境即可。
dotnet xxx.dll --environment=Test
这里的环境就要和json文件的中间那部分一致了。当然也可以从环境变量中指定,方式很多,大家随便选。
下面是在三个不同环境,读出来不同的配置内容。
其实到这一步,我们已经在同一个配置中心里面,将应用的不同环境隔离开了。
本文的示例代码:
参考资料
相关文章
- DDD落地,如何持久化聚合
- 迁移 dotnet 6 提示必须将目标平台设置为 Windows 平台
- C++|I/O|基于缓冲区的位级IO流
- 006: Django ajax请求
- 012:Django高级请求
- 开发者调查:C#在云应用中失去了地位 在游戏中依然大行其道
- 彻底理解 IO 多路复用实现机制
- 微软.NET 5.1迎来RC1版本 开发者已可上线尝鲜
- 速度和性能狂卷,.NET 7有多少人买单
- 风云再续:他抖任他抖,IO诊断在我手
- 在开源社区的强烈抗议下 微软逆转了有争议的.NET变化
- Windows 11 的 Microsoft Store 上架 Visual Studio
- 微软:.NET 平台采用率的提升归功于开源
- 从文件下载视角来理解Web API
- 你以为的ASP.NET文件上传大小限制是你以为的吗
- 在Ubuntu中搭建.NET开发环境
- gRPC入门与实操(.NET篇)
- Rails MVC 和 CRUD(1)
- FANUC机器人PROFINET双通道板卡组态
- 网络IO