【微服务SpringCloud-Alibaba】:Nacos 配置中心

这篇具有很好参考价值的文章主要介绍了【微服务SpringCloud-Alibaba】:Nacos 配置中心。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、Nacos 配置中心

在 SpringCloud 中,我们使用了 Config 组件管理所有配置文件,使用了 Bus 消息总线更新配置,两者需要配合使用才能动态的管理配置文件。而 Nacos 可以替代这两个组件,实现动态的管理所有配置文件。

2、快速入门

2.1、添加配置文件

想要管理配置,先要有配置文件。在使用 Config 组件管理配置文件时,需要将配置文件 GitHub 或者 Gitee 中。当使用 Nacos 做配置中心的时候可以直接使用 Nacos Server 中添加配置文件。

【微服务SpringCloud-Alibaba】:Nacos 配置中心
配置文件的 DataId 一定要以${prefix}-${spring.profiles.active}.${file-extension}为格式,因为当服务通过 Nacos 获取配置文件时,也是以这个格式来寻找配置文件的。

  • prefix:表示服务的名称
  • active:表示服务的开发环境(用于区分开发环境,测试环境、生产环境等)
  • file-extension:表示配置文件的后缀

知道了配置文件的命名方式,我们就可以创建一个配置文件,并填写一定的内容。
【微服务SpringCloud-Alibaba】:Nacos 配置中心

2.2、配置的获取

在创建完配置文件之后,我们就可以通过具体的服务实现动态获取配置文件。具体步骤如下:

  • 引入依赖:引入 Nacos 有关配置中心的依赖

    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
    </dependency>
    
  • 添加配置文件:配置文件一定要以 bootstrap.yml 为名称

    server:
      port: 3270
    
    spring:
      application:
        name: nacos-config-client
      profiles:
        active: dev #开发环境,这里是dev
      cloud:
        nacos:
          discovery:
            server-addr: localhost:8848 #配置Nacos地址
          config:
            server-addr: localhost:8848 #Nacos作为配置中心地址
            file-extension: yaml # 文件后缀名
    

    配置文件中添加了三个配置:
    spring.profiles.active表示当前开发环境
    spring.cloud.nacos.config.server-addr表示配置文件的地址
    spring.cloud.nacos.config.file-extension表示获取的配置文件的后缀

    将 name 、active 和 file-extension 按照${prefix}-${spring.profiles.active}.${file-extension}格式结合起来就是需要获取的配置文件的名称。

  • 编写业务类:

    @RestController
    @RefreshScope //该注解使当前类下的配置支持Nacos的动态刷新功能。
    public class OrderController {
    
        @Value("${server.port}")
        public String port;	
    
        @Value("${nacos.info}")
        public String info;
    
        @GetMapping(value = "/nacos/order/{id}")
        public String getOrder(@PathVariable("id") Integer id){
            return "查询订单"+id+",当前端口号为:"+port+","+info;
        }
    }
    
  • 添加启动类:

    @EnableDiscoveryClient
    @SpringBootApplication
    public class OrderMain3270 {
        public static void main(String[] args) {
            SpringApplication.run(OrderMain3270.class, args);
        }
    }
    

然后启动服务,访问http://localhost:3270/nacos/order/1地址,可以得到如下页面:
【微服务SpringCloud-Alibaba】:Nacos 配置中心

上述代码可以完成从 Nacos 中获取配置信息,并且通过@RefreshScope注解已经实现了自动更新,除了这种方式还有另外一种方式自动更新:

@Component
@Data
@ConfigurationProperties(prefix = "nacos")
public class UpdateProperties {
    public String info;
}

然后在业务类中去掉@RefreshScope注解,并修改代码:

@RestController
public class OrderController {

    @Value("${server.port}")
    public String port;

    @Autowired
    private UpdateProperties updateProperties;

    @GetMapping(value = "/nacos/order/{id}")
    public String getOrder(@PathVariable("id") Integer id){
        return "查询订单"+id+",当前端口号为:"+port+","+updateProperties.info;
    }
}

两种方式完成自动更新:通过@Value注解和@RefreshScope注解完成自动更新,通过@ConfigurationProperties注解注完成自动更新,一般推荐使用第二种方式。

3、配置文件分类

上述过程中,我们通过 Nacos 完成了一个配置文件的获取。但是在实际开发中,一个微服务项目只是要经过开发、测试、生产环境三个步骤。这三个步骤可能使用的配置文件都不相同,所以 Nacos 可以通过命名空间、配置分组、配置文件的DataID 这三种方式来将配置文件分类。

  • 配置文件的DataID是有三部分组成${prefix}-${spring.profiles.active}.${file-extension},我们可以控制 active 属性的值将配置分类
  • 配置分组,是将配置文件放在不同组中。就类似于 Java的报名,在Java中不同包下(不同的分组),可以有同名的类(同名的配置文件)
  • 命名空间,在使用 Nacos 的注册中心功能时有提到过。

命名空间通过 Nacos Server 进行创建,如下图:

【微服务SpringCloud-Alibaba】:Nacos 配置中心

分组和配置文件的DataID,是在创建配置文件时指定的:
【微服务SpringCloud-Alibaba】:Nacos 配置中心

然后需要修改配置文件的内容,以获取到不同命名空间,不同分组和不同 DataID 的配置文件:文章来源地址https://www.toymoban.com/news/detail-426427.html

cloud:
   nacos:
     discovery:
       server-addr: localhost:8848 #Nacos服务注册中心地址
	 config:
	   server-addr: localhost:8848 #Nacos作为配置中心地址
	   file-extension: yaml #这里我们获取的yaml格式的配置
	   namespace: 5973c734-0625-47b3-8ae8-5db216d70e10
	   group: dev_GROUP

到了这里,关于【微服务SpringCloud-Alibaba】:Nacos 配置中心的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • SpringCloud(17~21章):Alibaba入门简介、Nacos服务注册和配置中心、Sentinel实现熔断与限流、Seata处理分布式事务

    Spring Cloud Netflix项目进入维护模式 https://spring.io/blog/2018/12/12/spring-cloud-greenwich-rc1-available-now 说明 Spring Cloud Netflix Projects Entering Maintenance Mode 什么是维护模式 将模块置于维护模式,意味着 Spring Cloud 团队将不会再向模块添加新功能。我们将修复 block 级别的 bug 以及安全问题,我

    2024年01月19日
    浏览(46)
  • SpringCloud Alibaba集成 Gateway(自定义负载均衡器)、Nacos(配置中心、注册中心)、Loadbalancer

    路由(route):路由是网关最基础的部分,路由信息由一个ID,一个目的URL、一组断言工厂和一 组Filter组成。如果断言为真,则说明请求URL和配置的路由匹配。 断言(Predicate):Java8中的断言函数,Spring Cloud Gateway中的断言函数输入类型是 Spring5.0框架中的ServerWebExchange。Sprin

    2024年04月12日
    浏览(42)
  • Spring Cloud Alibaba--Nacos服务注册和配置中心

    Nacos 是Dynamic Naming and Configuration Service的首字母简称,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。 Nacos的特性,官网解释如下: 服务发现和服务健康监测 Nacos 支持基于 DNS 和基于 RPC 的服务发现。服务提供者使用 原生SDK、OpenAPI、或一个独立的Age

    2024年02月05日
    浏览(35)
  • Spring Cloud Alibaba Nacos(服务注册及配置中心)

    Nacos是由阿里巴巴提供的一款专门构建云本地应用的 动态服务发现、配置中心和服务管理平台 。 在Spring Cloud Alibaba中常使用Nacos作为注册中心和分布式配置中心。  (1)服务发现和管理 动态服务发现是以服务为中心(例如微服务或云原生)体系结构的关键。Nacos支持基于DN

    2024年02月16日
    浏览(36)
  • Spring Cloud Alibaba 微服务2,注册中心演变 + Nacos注册中心与配置中心

    🏆作者简介: 哪吒 ,CSDN2022博客之星Top1、CSDN2021博客之星Top2、多届新星计划导师✌、博客专家💪 , 专注Java硬核干货分享,立志做到Java赛道全网Top N。 🏆本文收录于 Java基础教程系列(进阶篇) ,本专栏是针对大学生、初级Java工程师精心打造, 针对Java生态,逐个击破,

    2024年02月02日
    浏览(35)
  • day10-Spring Cloud Alibaba Nacos-服务注册与配置中心

    官网:https://github.com/alibaba/nacos,Nacos官方中文手册 Nacos:Spring Cloud Alibaba服务注册与配置中心(非常详细) (biancheng.net) Spring Cloud Alibaba系列-一文读懂Nacos原理 - 掘金 (juejin.cn) Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service的首字母简称,一个更易于构建云原生应用的动态服

    2024年02月08日
    浏览(35)
  • SpringCloud Alibaba--nacos简介和注册中心和登录

    目录 一.理论基础 二.nacos 2.1 简介 2.2 安装 三.父项目 三.生产者 3.1 配置依赖 3.2 配置文件 3.3 启动类 3.4 控制类 四.消费者 4.1 配置依赖 4.2 配置文件 4.3 启动类 4.4 feign的接口 五.效果 六.负载均衡--权重算法 6.1重启nacos 6.2 设置权重 6.3 设置配置 6.4 效果 SpringCloudAlibaba-登录 1.登录

    2024年04月26日
    浏览(24)
  • 【云原生】SpringCloud Alibaba 之 Nacos注册中心实战

    注册中心, 也称命名服务(Naming servive), 它的核心功能与DNS服务类似, 无非就是通过一个特定的名字来查找相关的实例集合, 但是它们也有很多不同点 Nacos与eureka的共同点 都支持服务注册和服务拉取 都支持服务提供者心跳方式做健康检测 Nacos与Eureka的区别 Nacos支持服务端主动检

    2024年02月03日
    浏览(69)
  • SpringCloud + Gateway(网关) + Nacos(注册中心+配置中心)+ Dubbo(内部服务调用)

    Apache Dubbo是一款微服务开发框架,它提供了 RPC通信 与 微服务治理 两大关键能力 1、协议支持方面 Feign更加优雅简单。Feign是通过REST API实现的远程调用,基于Http传输协议,服务提供者需要对外暴露Http接口供消费者调用,服务粒度是http接口级的。通过短连接的方式进行通信,

    2024年02月06日
    浏览(48)
  • 【深入了解Spring Cloud Alibaba Nacos:服务注册和配置中心】—— 每天一点小知识

                                                                💧 深入了解 S p r i n g C l o u d A l i b a b a N a c o s :服务注册和配置中心 color{#FF1493}{深入了解Spring Cloud Alibaba Nacos:服务注册和配置中心} 深入了解 Sp r in g Cl o u d A l ibaba N a cos :服务注

    2024年02月11日
    浏览(35)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包