SpringCloudAlibaba--Nacos作为服务配置中心

Nacos作为配置中心–基础配置

新建cloudalibaba-config-nacos-client3377
依赖:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>cloud2020</artifactId>
        <groupId>pers.zhang.springcloud</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>cloudalibaba-config-nacos-client3377</artifactId>

    <dependencies>
        <!--nacos-config-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>
        <!--nacos-discovery-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <!--web + actuator-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <!--一般基础配置-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

</project>

配置:

Nacos和SpringCloud-config一样,在项目初始化时,要保证先从配置中心进行配置拉取,拉取配置成功之后,才能保证项目的正常启动。

springboot中配置文件的加载顺序是存在优先顺序的,bootstrap优先级高于application。

bootstrap.yml:

server:
  port: 3377

spring:
  application:
    name: nacos-config-client
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 #Nacos服务注册中心地址
      config:
          server-addr: localhost:8848 #Nacos作为配置中心地址
          file-extension: yaml #指定格式
          
# #{spring.application.name}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}

application.yml:

spring:
  profiles:
    active: dev #指定为开发环境

启动类:

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

Controller:

@RestController
@RefreshScope //支持Nacos的动态刷新
public class ConfigClientController {
    @Value("${config.info}")
    String configInfo;
    
    @GetMapping("/config/info")
    public String getConfigInfo() {
        return configInfo;
    }
}

Nacos中添加配置信息

官网:https://nacos.in/zh-cn/docs/quick-start-spring-cloud.html

Nacos中的匹配规则:

说明:之所以需要配置 spring.application.name ,是因为它是构成 Nacos 配置管理 dataId字段的一部分。

扫描二维码关注公众号,回复: 10023810 查看本文章

在 Nacos Spring Cloud 中,dataId 的完整格式如下:

${prefix}-${spring.profile.active}.${file-extension}
  • prefix 默认为 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。
  • spring.profile.active 即为当前环境对应的 profile,详情可以参考 Spring Boot文档。 注意:当 - spring.profile.active 为空时,对应的连接符 -也将不存在,dataId 的拼接格式变成 ${prefix}.${file-extension}
    -file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。目前只支持propertiesyaml 类型。

最终格式:{spring.application.name}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}

新增配置:
在这里插入图片描述

测试:

启动3377微服务,访问:localhost:3377/config/info,成功获取配置:
在这里插入图片描述

nacos自带动态刷新:

修改nacos中的配置文件为version=2,再次调用接口:
在这里插入图片描述
在这里插入图片描述

Nacos作为配置中心–分类配置

解决多环境多项目管理问题。

配置管理:
在这里插入图片描述

public为默认的保留命名空间。

Namespace+Group+Data ID的关系:

类似Java里面的package名和类名,最外层的namespace是可以用于区分部署环境的,Group和Data ID逻辑上区分两个目标对象。
在这里插入图片描述
默认情况:Namespace=public, Group=DEFAULT_GROUP,默认Cluster是DEFAULT

Nacos默认的命名空间是public,Namespace主要用来实现隔离。

比如说现在有三个环境:开发、测试、生产环境,我们就可以创建三个Namespace,不同的Namespace之间是隔离的。

Group默认是DEFAULT_GROUP,Group可以把不同的微服务划分到同一个分组里面去。

Service就是微服务;一个Service可以包含多个Cluster(集群),Nacos默认Cluster是DEFAULT,Cluster是对指定微服务的一个虚拟划分。比方说为了容灾,将Service微服务分别部署在了杭州机房和广州机房,这时就可以给杭州机房的Service微服务起一个集群名称(HZ),给广州机房的Service微服务起一个集群名称(GZ),还可以让同一个机房的王i服务相互调用,以提升性能。

Instance就是微服务的实例。

指定spring.profile.active和配置文件的Data ID来使不同环境下读取不同的配置

  • 默认空间+默认分组+新建dev和test两个Data ID

新建dev配置Data ID:
在这里插入图片描述
新建test配置Data ID:
在这里插入图片描述
在这里插入图片描述
此时,通过spring.profile.active属性就能进行多环境下配置文件的读取:
在这里插入图片描述
在这里插入图片描述

group分组方案:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在config下增加一条group的配置即可。可配置为DEV_GROUP或TEST_GROUP。
在这里插入图片描述
在这里插入图片描述

namespace方案:

新建dev/test的Namespace:
在这里插入图片描述
在这里插入图片描述
按照域名配置填写:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
修改bootstrap.yml,添加命名空间:
在这里插入图片描述
application.yml:
在这里插入图片描述

在这里插入图片描述

发布了843 篇原创文章 · 获赞 2259 · 访问量 29万+

猜你喜欢

转载自blog.csdn.net/cold___play/article/details/105005462