- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Spring Cloud Alibaba Nacos Config进阶使用由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
。
。
。
在日常开发过程中,对于同一个服务或者项目工程在不同的环境所需要的配置是不同的。如访问数据库、redis或者MQ其他中间件,往往需要进行环境隔离,如果每次部署都需要去修改配置文件的话,是十分不方面的。在微服务场景下,这个问题尤为突出,因为代码工程的数量是传统单项目的几十倍。需要建筑一些组件,在不修改配置稳健的前提下动态的切换运行环境。Nacos Config提供了类似的解决方案.
。
在pom文件中添加Nacos Config的依赖包,注意版本 。
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.2.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!--服务注册发现--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> </dependencies> <dependencyManagement> <dependencies> <!--spring-cloud-alibaba 版本控制--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-alibaba-dependencies</artifactId> <version>2.2.6.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
。
spring: cloud: nacos: server-addr: localhost:8848 # nacos服务地址 config: file-extension: yaml # 表示支持扩展的文件名 application: name: nacos-config # 表示当前微服务需要向配置中心索要nacos-config的配置 profiles: active: prod # 表示我需要向配置中心索要生产环境的配置
。
在Nacos Config 配置管理中新增配置如图以及其对应关系如下:
。
索要文件的格式为${application.name}-spring。profiles.active.{file-extension} 体现在nacos中,对应尚曼的格式Data id得知应该是nacos-config-prod.yaml 。
。
官网: https://nacos.io/zh-cn/docs/quick-start.html 。
# 启动命令(standalone代表着单机模式运行,非集群模式):# linuxsh startup.sh -m standalone# Windowsstartup.cmd -m standalone
http://localhost:8848/nacos/ 账号/密码:nacos/nacos 。
。
标签 | 值 | 说明 |
---|---|---|
Data ID | nacos-config-prod.yaml | |
Group | DEFAULT_GROUP | 默认,可以自定义 |
描述 | 简述生产环境配置 | |
配置格式 | yaml | 文件扩展名选择 |
配置内容 | nacosProd: Production environment configuration | 和配置yml文件格式语法一样 |
。
。
。
package com.gblfy.alibab.nacosconfig.controller;import org.springframework.beans.factory.annotation.Value;import org.springframework.cloud.context.config.annotation.RefreshScope;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RestController;@RestController@RefreshScopepublic class NacosConfigController { @Value("${nacosProd}") private String nacosProd; @GetMapping("/nacosProd") public String getNacosProd() { return nacosProd; }}
。
。
打开浏览器访问http://localhost:8080/nacosProd验证测试结果结果如图:
。
修改bootstrap.yaml文件中激活环境调整为test环境spring.profiles.active.test 。
spring: cloud: nacos: server-addr: localhost:8848 # nacos服务地址 config: file-extension: yaml # 表示支持扩展的文件名 application: name: nacos-config # 表示当前微服务需要向配置中心索要nacos-config的配置 profiles: active: test # 表示我需要向配置中心索要生产环境的配置
。
在nacos中新建data_id为nacos-config-test.yaml,并添加相同的配置参数,把环境参数的内容调整为test测试环境的 。
。
。
添加test测试环境方法,把刚才生产的方法注释掉,因为咱们现在激活的是test测试环境的配置 。
// @Value("${nacosProd}")// private String nacosProd;//// @GetMapping("/nacosProd")// public String getNacosProd() {// return nacosProd;// } @Value("${nacosTest}") private String nacosTest; @GetMapping("/nacosTest") public String getNacosTest() { return nacosTest; }
。
。
打开浏览器访问http://localhost:8080/nacosTest验证测试结果结果如图:
。
在修改nacos中修改配置实时生效测试 修改前配置:
修改后配置:
发布规则 。
不停止项目服务,打开浏览器访问http://localhost:8080/nacosTest验证测试结果结果如图:
其他环境同上这里就不一一验证了.
。
这里演示修改配置文件,到正式环境,激活那个环境配置是在命令脚本中配置好的 会采用下面这种方式激活环境配置,这个命令配置环境的优先级比项目中的配置文件中的优先级高 。
java -jar xxx.jar -Dspring.profiles.active=test
。
。
在实际的开发过程中,我们的工程项目所用到的配置参数大多数并不需要根据不同的环境进行区分,生产、测试、开发环境所用到的参数值是相同的。如何解决同一服务在多环境中,引用相同配置的问题呢?Nacos Config也提供了相应的解决方案.
。
在Nacos Config中添加配置,data_id为nacos-config.yaml,如图所示:
。
在NacosConfigController类中添加读取项目中共有相同配置的方法进行测试 。
// @Value("${nacosProd}")// private String nacosProd;//// @GetMapping("/nacosProd")// public String getNacosProd() {// return nacosProd;// } @Value("${nacosTest}") private String nacosTest; @GetMapping("/nacosTest") public String getNacosTest() { return nacosTest; } @Value("${nacosCommon}") private String nacosCommon; @GetMapping("/nacosCommon") public String getNacosCommon() { return nacosCommon; }
。
。
打开浏览器访问http://localhost:8080/nacosTest验证测试结果结果如图:
打开浏览器访问http://localhost:8080/nacosCommon验证测试结果结果如图:
从上面测试可以看出,访问test环境独有的配置可以正常访问。访问项目中共有相同的配置也正常。 此时,我们已经在nacos中配置了3个配置文件,nacos-config-prod.yaml、nacos-config-test.yaml和nacos-config.yaml 。
。
。
验证这个其实很简单,只需要在环境独有的配置中配置共有相同配置文件中相同的配置标签让他值不一样,浏览器访问不就知道了,对吧? 这样,演示在nacos-config-test.yaml文件中配置nacos-config.yaml文件中nacosCommon标签,给他赋予不同的值进行测试.
。
nacos-config.yaml文件中原配置:
在nacos-config-test.yaml文件中配置nacosCommon标签值为 添加相同配置 在测试配置中添加与公用配置一样的标签属性值不同,观察谁的配置生效即可 。
nacosTest: Test environment configuration v2nacosCommon: Common Environment Configuration 测试配置文件中,配置相同属性值不同的测试案例
规则发布 。
。
打开浏览器访问http://localhost:8080/nacosCommon验证测试结果结果如图:
实际读取的配置信息是从nacos-config-test.yaml文件中读取的。 结论:如果配置了spring.profiles.active,则优先获取nacos-config-{spring.profiles.active}.yaml中的值.
。
。
像这种共有中间件的配置信息企业会采用单独的配置文件来维护,Nacos Config为我们提供了二种配置方式来解决此类场景的问题,分别是extension-configs和shard-configs配置方式.
。
在nacos中新建redis.yaml,添加配置信息,reidsip:127.0.0.1,然后,配置信息发布生效 。
修改项目的bootstrap.yaml的配置文件,添加配置spring.cloud.nacos.config.shared-configs[0] 。
spring: cloud: nacos: server-addr: localhost:8848 # nacos服务地址 config: file-extension: yaml # 表示支持扩展的文件名 shared-configs[0]: data_id: redis.yaml refresh: true # 默认是false 如果需要支持自动刷新,需要配置true,搭配@RefreshScope实现动态刷新 #group: # 可以不写 默认DEFAULT_GROUP application: name: nacos-config # 表示当前微服务需要向配置中心索要nacos-config的配置 profiles: active: test # 表示我需要向配置中心索要生产环境的配置
添加测试方法 。
@Value("${redisip}") private String redisip; @GetMapping("/redisip") public String getredisip() { return redisip; }
打开浏览器访问http://localhost:8080/redisip验证测试结果结果如图:
http://localhost:8080/redisip
。
在nacos中新建mq.yaml,添加配置信息mqip: 127.0.0.2 。
修改项目的bootstrap.yaml问阿金,并添加shared-configs[1]:配置,具体配置线如下:
spring: cloud: nacos: server-addr: localhost:8848 # nacos服务地址 config: file-extension: yaml # 表示支持扩展的文件名 shared-configs[0]: data_id: redis.yaml refresh: true # 默认是false 如果需要支持自动刷新,需要配置true,搭配@RefreshScope实现动态刷新 #group: # 可以不写 默认DEFAULT_GROUP shared-configs[1]: data_id: mq.yaml refresh: true # 默认是false 如果需要支持自动刷新,需要配置true,搭配@RefreshScope实现动态刷新 #group: # 可以不写 默认DEFAULT_GROUP application: name: nacos-config # 表示当前微服务需要向配置中心索要nacos-config的配置 profiles: active: test # 表示我需要向配置中心索要生产环境的配置
新增一个获取mq信息的url以及方法 。
package com.gblfy.alibab.nacosconfig.controller;import org.springframework.beans.factory.annotation.Value;import org.springframework.cloud.context.config.annotation.RefreshScope;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RestController;@RestController@RefreshScopepublic class NacosConfigController {// @Value("${nacosProd}")// private String nacosProd;//// @GetMapping("/nacosProd")// public String getNacosProd() {// return nacosProd;// } @Value("${nacosTest}") private String nacosTest; @GetMapping("/nacosTest") public String getNacosTest() { return nacosTest; } @Value("${nacosCommon}") private String nacosCommon; @GetMapping("/nacosCommon") public String getNacosCommon() { return nacosCommon; } @Value("${redisip}") private String redisip; @GetMapping("/redisip") public String getredisip() { return redisip; } @Value("${mqip}") private String mqip; @GetMapping("/mqip") public String getmqip() { return mqip; }}
打开浏览器访问http://localhost:8080/mqip验证测试结果结果如图:
。
修改bootstrap.yaml文件,删除shared-configs相关配置,增加extension-configs[0]和extension-configs[1]的配置如下:
spring: cloud: nacos: server-addr: localhost:8848 # nacos服务地址 config: file-extension: yaml # 表示支持扩展的文件名 extension-configs[0]: # shared-configs是一个列表 List<Config> sharedConfigs data_id: redis.yaml refresh: true # 默认是false 如果需要支持自动刷新,需要配置true,搭配@RefreshScope实现动态刷新 extension-configs[1]: # shared-configs是一个列表 List<Config> sharedConfigs data_id: mq.yaml refresh: true # 默认是false 如果需要支持自动刷新,需要配置true,搭配@RefreshScope实现动态刷新 #group: # 可以不写 默认DEFAULT_GROUP application: name: nacos-config # 表示当前微服务需要向配置中心索要nacos-config的配置 profiles: active: test # 表示我需要向配置中心索要生产环境的配置
重新启动项目,分别访问http://localhost:8080/redisip和http://localhost:8080/mqip验证是否可以正常读取redis.yaml和mq.yaml的配置信息 。
。
在nacos中修改redis.yaml和mq.yaml的信息,不重启项目,直接访问浏览器,验证配置是否生效 redis.yaml原配置:
mq.yaml修改后配置:
mq.yaml原配置:
mq.yaml修改后配置:
访问http://localhost:8080/redisip和http://localhost:8080/mqip验证 。
。
。
如果多个shard-configs的文件中存在相同的配置,最终会以那个配置文件中的值为准?
。
这样场景 。
例如:在redis.yaml和mq.yaml配置文件中有一个相同的配置属性但是值不一样,然后在项目中存在多个shard-configs的文件,到底优先获取谁的配置问价心中的信息呢?对吧 。
。
。
spring: cloud: nacos: server-addr: localhost:8848 # nacos服务地址 config: file-extension: yaml # 表示支持扩展的文件名 extension-configs[0]: # shared-configs是一个列表 List<Config> sharedConfigs data_id: redis.yaml refresh: true # 默认是false 如果需要支持自动刷新,需要配置true,搭配@RefreshScope实现动态刷新 extension-configs[1]: # shared-configs是一个列表 List<Config> sharedConfigs data_id: mq.yaml refresh: true # 默认是false 如果需要支持自动刷新,需要配置true,搭配@RefreshScope实现动态刷新 #group: # 可以不写 默认DEFAULT_GROUP application: name: nacos-config # 表示当前微服务需要向配置中心索要nacos-config的配置 profiles: active: test # 表示我需要向配置中心索要生产环境的配置
@GetMapping("/port") public String getport() { return port; }
http://localhost:8080/port 。
结论:会以数组最后一个配置文件内容为准 。
。
。
提示springboot配置文件优先级 (bootstrap.ptoterties > bootstrap.yaml > application.ptoterties > bootstrap.yaml) 。
。
如果同时在extension-configs和shard-configs存在相同的配置,最终会以那个文件中的值为准? 总结下configdemo.yaml、configdemo-test.yaml、和shard-configs、extension-configs读取优先级 。
extension-configs: - data-id: shareconfig3.yml group: share3_group refresh: true - data-id: shareconfig3.yml group: share4_group refresh: true shared-configs: - data-id: shareconfig1.yml refresh: true - data-id: shareconfig2.yml refresh: true
spring.cloud.nacos.config.extension-configs[n].data-id 其中 n 的值越大,优先级越高,因此会走group=share4_group的配置。 spring.cloud.nacos.config.shared-configs[n].data-id默认跟上面一样的逻辑.
不同方式配置加载优先级 Spring Cloud Alibaba Nacos Config 目前提供了三种配置能力从 Nacos 拉取相关的配置.
A: 通过 spring.cloud.nacos.config.shared-configs[n].data-id 支持多个共享 Data Id 的配置 B: 通过 spring.cloud.nacos.config.extension-configs[n].data-id 的方式支持多个扩展 Data Id 的配置 C: 通过内部相关规则(spring.cloud.nacos.config.prefix、spring.cloud.nacos.config.file-extension、spring.cloud.nacos.config.group)自动生成相关的 Data Id 配置 。
当三种方式共同使用时,他们的一个优先级关系是:A < B < C 。
原文链接:https://blog.csdn.net/weixin_40816738/article/details/118913407 。
最后此篇关于Spring Cloud Alibaba Nacos Config进阶使用的文章就讲到这里了,如果你想了解更多关于Spring Cloud Alibaba Nacos Config进阶使用的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我有一个 Cloud Run 服务,它通过 SQLAlchemy 访问 Cloud SQL 实例.但是,在 Cloud Run 的日志中,我看到 CloudSQL connection failed.
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 4年前关闭。 Improve t
在将 docker 容器镜像部署到 Cloud Run 时,我可以选择一个区域,这很好。 Cloud Run 将构建委托(delegate)给 Cloud Build,后者显然会创建两个存储桶来实现这
我正在尝试将 Cloud Functions 用作由 PubSub 触发的异步后台工作程序,并进行更长时间的工作(以分钟为单位)。完整代码在这里https://github.com/zdenulo/c
这是/etc/cloud/cloud.cfg的内容Ubuntu云16.04镜像: # The top level settings are used as module # and system co
如何从 Google Cloud Function 启动 Cloud Dataflow 作业?我想使用 Google Cloud Functions 作为启用跨服务组合的机制。 最佳答案 我已经包含了
我想使用 Cloud Shell 在我的第二代 Cloud Sql 实例上运行数据库迁移。 我找到了一个 example in the docs关于如何使用 gcloud 进行连接.但是当我运行命令时
我正在尝试使用 Google Cloud PubSub和我的 Google Cloud Dataproc群集,我收到如下身份验证范围错误: { "code" : 403, "errors" :
这是我的用例。 我已经有一个以私有(private)模式部署的 Cloud Run 服务。 (与云功能相同的问题) 我正在开发使用此 Cloud Run 的新服务。我在应用程序中使用默认凭据进行身份验
如何连接到 Cloud SQL 上的数据库,而无需在容器中添加我的凭据文件? 最佳答案 使用 UNIX 域套接字 (Java) 从云运行(完全托管)连接到云 SQL At this time Clou
我有一个google-cloud-ml作业,需要从gs存储桶加载numpy .npz文件。我遵循了this example上关于如何从gs加载.npy文件的操作,但是由于.npz文件已压缩,因此它对我
我想创建链接到另一个项目中的 Cloud Source Repository 的 Cloud Build 触发器。但是当我在应该选择存储库的步骤中时,列表是空的。我尝试了不同的许可,但没有运气。谁能告
向 Twilio 发送 SMS 时,Twilio 会向指定的 URL 发送多个请求,以通过 Webhook 提供该 SMS 传送的状态。我想让这个回调异步,所以我开发了一个 Cloud Functio
我需要更改我的项目 ID,因为要验证的 Firebase 身份验证链接在链接上显示了项目 ID,并且由于品牌 reshape ,项目名称已更改。根据我发现的信息,更改项目 ID 似乎不太可能。我正在考
用于部署我的 Angular 应用程序的 CI/CD 管道已关闭,但我看到 Google Cloud Run 在容器镜像更新后没有部署新修订版。 我已将 Cloud Build 设置为在 GitHub
报价https://cloud.google.com/load-balancing/docs/https/setting-up-https-serverless#enabling While Goog
Cloud Spanner 提供了两种不同的 API。 Cloud Spanner 读取与 Cloud Spanner SQL API 之间有什么区别? 最佳答案 在幕后,它们都使用相同的执行机制,因
我是 GCP 堆栈的新手,所以我对用于存储数据的 GCP 技术数量感到非常困惑: https://cloud.google.com/products/storage 虽然上面的文章中没有提到googl
我发现 Google Cloud Functions 的网络出站费用令人惊讶,我正在尝试了解发生这种情况的原因以及如何避免这种情况。 Stackdriver 监控表明有问题的函数是我的 ingest
我使用 Prisma使用 Cloud Run 和 Cloud SQL。在向 prisma.schema 提供 DATABASE_URL 后,它会在运行时抛出一个错误。 Can't reach data
我是一名优秀的程序员,十分优秀!