Nacos Config 使用自定义的NameSpace & Group

简介: 在之前的章节中,我们并没有对`SpringCloud Alibaba Nacos Config`的`NameSpace`、`Group`做过修改,都是使用的默认值,默认值分别是:`Public`、`DEFAULT_GROUP`,我们本章来看下如何自定义这两项参数。

在之前的章节中,我们并没有对SpringCloud Alibaba Nacos ConfigNameSpaceGroup做过修改,都是使用的默认值,默认值分别是:PublicDEFAULT_GROUP,我们本章来看下如何自定义这两项参数。

在之前文章中我们学习到了SpringCloud Alibaba读取Nacos Config内定义的propertiesYaml类型的配置文件信息、配置信息实时更新、Profile环境下的配置信息读取优先级等。

开始本章

本章同样需要在Nacos Console控制台添加我们需要的配置信息。

Nacos Server

需要在本地安装Nacos Server才能完成本章的内容讲解,具体的安装步骤访问Nacos 官方文档

添加配置

我们通过访问本地的Nacos Console控制台添加本章所需要的配置信息。

添加自定义的NameSpace

不过在添加配置之前我们需要先来自定义一个namespace,如下图所示:

添加完成后在命名空间列表内有一个我们需要用到的参数命名空间ID,这个参数需要配置到我们的应用程序内,下面进行讲解。
回到配置列表后在顶部我们点击测试命名空间就可以查看该NameSpace下所有的配置列表。
添加本章使用的配置信息如下图所示:

在上图中我们定义的Grouphengboy,该参数也需要接下来配置在应用程序内。

创建应用

第一步:创建应用程序
通过Idea开发工具创建一个SpringBoot项目并添加本章使用的依赖信息,pom.xml如下所示:

//...
<properties>
    <java.version>1.8</java.version>
    <spring-cloud.version>Greenwich.RELEASE</spring-cloud.version>
    <spring-cloud-alibaba.version>0.2.1.RELEASE</spring-cloud-alibaba.version>
</properties>

<dependencies>
    <!--spring cloud alibaba config-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
</dependencies>

<dependencyManagement>
    <!--SpringCloud-->
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
        <!--SpringCloud Alibaba-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-alibaba-dependencies</artifactId>
            <version>${spring-cloud-alibaba.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

第二步:bootstrap.yml配置
创建bootstrap.yml配置文件,添加如下配置信息:

spring:
  application:
    name: hengboy-sca-nacos-config-namespace
  cloud:
    nacos:
      config:
        server-addr: 127.0.0.1:8848
        file-extension: yaml
        # 自定义namespace
        namespace: 52cfe0c1-746c-4f82-b161-a8799af1b1e9
        # 自定义分组
        group: hengboy
  • spring.cloud.nacos.config.namespace

配置自定义的namespaceID,该值可以在Nacos Console控制台命名空间列表中获得。

  • spring.cloud.nacos.config.group

配置自定义的group,该值是在添加配置信息时输入的值,也就是hengboy

第三步:读取配置信息
我们通过一个单元测试来读取配置信息,如下所示:

@RunWith(SpringRunner.class)
@SpringBootTest
public class ConfigNameSpaceTest {
    /**
     * logger instance
     */
    static Logger logger = LoggerFactory.getLogger(ConfigNameSpaceTest.class);
    /**
     * 配置信息
     */
    @Value(value = "${hengboy.name:}")
    private String name;

    @Test
    public void getConfig() {
        logger.info("获取配置信息:{}", name);
    }
}

第四步:运行测试
执行ConfigNameSpaceTest#getConfig单元测试方法,查看控制台输出内容如下所示:

2019-03-05 15:55:17.388  INFO 81736 --- [           main] c.y.c.s.a.n.c.n.ConfigNameSpaceTest      : 获取配置信息:yuqiyu

总结

自定义配置NameSpaceGroup对于SpringCloud Alibaba Nacos Config来说是比较简单的,只需要简单的配置就可以,如果你的系统模块较多,建议使用namespacegroup来进行划分,这样就可以更好的管理配置信息。

相关文章
|
Java Nacos 微服务
Spring Cloud Alibaba - 19 Nacos Config配置中心加载不同微服务的通用配置的两种方式
Spring Cloud Alibaba - 19 Nacos Config配置中心加载不同微服务的通用配置的两种方式
509 0
|
7月前
|
负载均衡 算法 Nacos
SpringCloud之LoadBalancer自定义负载均衡算法,基于nacos权重
ReactorLoadBalancer接口,实现自定义负载算法需要实现该接口,并实现choose逻辑,选取对应的节点。
581 0
|
8月前
|
前端开发 Java Nacos
Nacos替换config
Nacos替换config
60 0
|
Java 测试技术 Nacos
SpringCloud 整合Nacos config
SpringCloud 整合Nacos config
131 0
|
Java Nacos Spring
使用Spring Boot的Profile功能来实现不同环境使用不同的Nacos Namespace的配置
使用Spring Boot的Profile功能来实现不同环境使用不同的Nacos Namespace的配置
638 1
|
存储 Nacos 开发工具
微服务配置中心(Nacos Config)
微服务配置中心(Nacos Config)
403 0
|
Java Unix Linux
Nacos config 配置中心详解
Nacos config 配置中心详解
1547 0
|
Java 测试技术 Nacos
Spring Cloud Alibaba - 18 Nacos Config配置中心加载相同微服务的不同环境下的通用配置
Spring Cloud Alibaba - 18 Nacos Config配置中心加载相同微服务的不同环境下的通用配置
144 0
|
22天前
|
存储 网络协议 Nacos
高效搭建Nacos:实现微服务的服务注册与配置中心
Nacos(Dynamic Naming and Configuration Service)是阿里巴巴开源的一款动态服务发现、配置管理和服务管理平台。它旨在帮助开发者更轻松地构建、部署和管理分布式系统,特别是在微服务架构中。
250 81
高效搭建Nacos:实现微服务的服务注册与配置中心
|
1月前
|
JSON Java Nacos
SpringCloud 应用 Nacos 配置中心注解
在 Spring Cloud 应用中可以非常低成本地集成 Nacos 实现配置动态刷新,在应用程序代码中通过 Spring 官方的注解 @Value 和 @ConfigurationProperties,引用 Spring enviroment 上下文中的属性值,这种用法的最大优点是无代码层面侵入性,但也存在诸多限制,为了解决问题,提升应用接入 Nacos 配置中心的易用性,Spring Cloud Alibaba 发布一套全新的 Nacos 配置中心的注解。
205 12