加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 服务器 > 系统 > 正文

自从使用了 Nacos再也不用担心配置管理混乱的问题

发布时间:2021-05-22 12:11:38 所属栏目:系统 来源:互联网
导读:副标题#e# Hello 大家好,今天给大家分享微服务环境下必须要使用的一个强大的组件 Nacos。自从使用了 Nacos,服务再也没有担心过服务注册和发现以及配置管理混乱的问题了。 背景 Nacos 致力于帮助开发人员发现、配置和管理微服务,Nacos 提供了一组简单易用
副标题[/!--empirenews.page--]

Hello 大家好,今天给大家分享微服务环境下必须要使用的一个强大的组件 Nacos。自从使用了 Nacos,服务再也没有担心过服务注册和发现以及配置管理混乱的问题了。

背景

Nacos 致力于帮助开发人员发现、配置和管理微服务,Nacos 提供了一组简单易用的特性集,快速实现动态服务发现、服务配置、服务元数据及流量管理。

目前主流的互联网服务都是基于微服务架构的,那服务与服务之间的交互是必不可少的,而且各个服务的上下线都是相互独立的,而且服务的配置信息也是会动态调整的,这就需要我们的服务更加灵活。Nacos 的出现就是帮助我们实现这些繁琐的功能。

详细的 Nacos 介绍和部署可以参考官方网站 Nacos.io。这里只介绍一下在 SpringBoot 项目中如何快速接入以及接入和使用过程中可能会遇到的坑。

接入

加入依赖

第一步在 pom 配置文件中加入下面的依赖,用于实现服务注册发现和配置中心功能。

<!-- nacos 配置中心 --> 

<dependency> 

  <groupId>com.alibaba.cloud</groupId> 

  <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> 

</dependency> 

<!-- nacos 注册发现 --> 

<dependency> 

  <groupId>com.alibaba.cloud</groupId> 

  <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> 

</dependency> 

增加配置

1.第二步在 SpringBoot 项目的启动类上增加如下注解 @EnableDiscoveryClient 用于启动服务注册发现功能。

2.增加配置文件,对应的配置信息需要修改成适合自己的,为了方便管理,应用的分组名称,命名空间以及相关的配置都需要合理的设置。多个业务使用同一个 nacos 集群的时候,需要根据各个的业务设定各自的命名空间。所有的配置文件都需要在对应的命名空间下设置,避免多个业务混用,另外业务需要根据用到的组件或者配置,设定独立的配置文件,例如数据库的配置,Redis 的配置等都需要单独设定,这样是为了同一个应用其他的其他服务也可以使用,而且再有地址变更的时候可以只修改一个文件就好,不会忘记。

# 应用服务名称 

spring.application.name=application-name 

# 应用分组名称 

spring.cloud.nacos.config.group=GROUP-NAME 

# 配置文件的后缀名 

spring.cloud.nacos.config.file-extension=properties 

# nacos 对应的命名空间,在后台创建好命名空间后会自动生成 

spring.cloud.nacos.config.namespace=xxxxxxxxxxxxxxxxxxxxxxxxx 

# 对应的配置文件 

# MySQL 相关配置 

spring.cloud.nacos.config.ext-config[0].data-id=mysql.properties 

spring.cloud.nacos.config.ext-config[0].group=GROUP-NAME 

# Redis 相关配置 

spring.cloud.nacos.config.ext-config[1].data-id=redis.properties 

spring.cloud.nacos.config.ext-config[1].group=GROUP-NAME 

# 其他配置等 

spring.cloud.nacos.config.ext-config[2].data-id=other.properties 

spring.cloud.nacos.config.ext-config[2].group=GROUP-NAME 

# 配置中心地址,多个逗号分隔 

spring.cloud.nacos.config.server-addr=xxx.xx.xx.xx:xxxx 

# 服务注册发现地址,多个逗号分隔 

spring.cloud.nacos.discovery.server-addr=xxx.xx.xx.xx:xxxx 

# 集群名称 

spring.cloud.nacos.discovery.cluster-name=CLUSTER-NAME 

3.代码中可以使用注解 @Value() 来直接读取 Nacos 配置中的属性参数,也可以使用 @ConfigurationProperties(prefix = "spring.datasource") 读取批量参数。

4.spring.cloud.nacos.config.ext-config[0].refresh=true 该参数表示是否开启自动更新,根据是否需要自动更新觉得是否配置,如果需要自动更新,加上这个配置后还需要在需要自动更新配置的 Bean 上面增加@RefreshScop 注解。然后对应的 Bean 内部的属性就可以实现自动更新了。增加了spring.cloud.nacos.config.ext-config[0].refresh=true 配置后在修改了 Nacos 中的配置过后日志会出现下面信息,会重新加载配置,并且输出变更的 key 信息。

5.

服务调用

当所有的服务都接入 Nacos 过后,我们在 Nacos 的后台就可以看到每个服务的情况,如下图,可以看到服务状态。

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读