.NET Core 下使用 Apollo 配置中心
Apollo(阿波罗)是携程框架部门研发的分布式配置中心,能够集中化管理应用不同环境、不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的权限、流程治理等特性,适用于微服务配置管理场景。服务端基于Spring Boot和Spring Cloud开发,打包后可以直接运行,不需要额外安装Tomcat等应用容器。
Apollo
开源地址:https://github.com/ctripcorp/apollo
更多产品介绍可以查看Apollo配置中心介绍,本篇主要介绍在 .NET 环境下如何使用 Apollo
配置中心。
1|0Quick Start
- 本地部署:https://github.com/ctripcorp/apollo/wiki/Quick-Start
- Docker部署:https://github.com/ctripcorp/apollo/wiki/Apollo-Quick-Start-Docker部署
- 分布式部署:https://github.com/ctripcorp/apollo/wiki/分布式部署指南
为了方便,本次我选择使用Docker部署,快速运用。
另外需要说明的是,不管是Docker方式部署Quick Start还是常规方式部署的,Quick Start只是用来快速入门、了解Apollo。如果部署Apollo在公司中使用,请参考分布式部署。
请确保开发环境有docker环境,然后下载docker-compose.yml
和所需的sql文件,然后在根目录执行docker-compose up
,一次执行会触发下载镜像等操作,需要耐心等待一些时间。
搜索所有apollo-quick-start
开头的日志,看到以下日志说明启动成功:
数据库的端口映射为13306,所以如果希望在宿主机上访问数据库,可以通过localhost:13306,用户名是root,密码留空。如要查看更多服务的日志,可以通过docker exec -it apollo-quick-start bash登录, 然后到/apollo-quick-start/service和/apollo-quick-start/portal下查看日志信息。
访问http://localhost:8070,可以看到Apollo
UI界面,默认账号密码为:apollo/admin
2|0.NET Core 接入
新建一个 ASP.NET Core API项目,ApolloDemo
,添加组件Com.Ctrip.Framework.Apollo.Configuration
。
Apollo
配置中心的 .NET 集成包开源地址:https://github.com/ctripcorp/apollo.net/tree/dotnet-core
接入也比较简单,在appsettings.json
中配置Apollo
服务地址。
关于配置可以查看文档:https://github.com/ctripcorp/apollo.net/tree/dotnet-core/Apollo.Configuration
为什么地址端口是8080而不是8070?
因为在docker-compose.yml
中我们暴露两个端口:8080个8070,8070是我们的Apollo
配置中心管理界面,而8080端口是Spring Eureka
服务注册中心。所以配置的应该是服务端的地址。
紧接着在Program.cs
应用配置,代码如下:
然后我们在Apollo
管理界面新建一个与配置在appsettings.json
中AppId同名的项目ApolloDemo
。
Apollo
有一个核心的概念:Namespace
。
Namespace
是配置项的集合,类似于一个配置文件的概念。Namespace
类型有三种:私有类型、公共类型、关联类型(继承类型)。Namespace
的获取权限分为两种:private (私有的)、public (公共的),这里的获取权限是相对于Apollo客户端来说的。
配置文件有多种格式,例如:properties、xml、yml、yaml、json等。同样Namespace也具有这些格式。在Portal UI中可以看到“application”的Namespace上有一个“properties”标签,表明“application”是properties格式的。
非properties格式的namespace,在客户端使用时需要调用ConfigService.getConfigFile(String namespace, ConfigFileFormat configFileFormat)来获取,如果使用Http接口直接调用时,对应的namespace参数需要传入namespace的名字加上后缀名,如datasources.json。
apollo-client 1.3.0版本开始对yaml/yml做了更好的支持,使用起来和properties格式一致:Config config = ConfigService.getConfig("application.yml");,Spring的注入方式也和properties一致。
关于Namespace`的文档:https://github.com/ctripcorp/apollo/wiki/Apollo核心概念之“Namespace”
接下来去新增几个配置属性,然后发布。
现在去写一个接口,来实时读取Apollo
中的配置。
使用起来也非常简单,这里根据传入的key值不同,获取到我们配置在Apollo
中的value,并且是具有热更新,实时动态改变的。
然后修改name和age的值,在调用接口看看。注意在Apollo
中修改后,需要发布才会生效。
简单介绍了 .NET Core 下使用Apollo
配置中心,Apollo
的功能远不止于此,根据需要可以去Github查看官网Wiki介绍,有详细的使用说明文档。
__EOF__

本文链接:https://www.cnblogs.com/meowv/p/13614404.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?