推荐一款配置中心新贵:Nacos,阿里开源,是真的香!!

Java技术栈

共 4008字,需浏览 9分钟

 ·

2020-12-17 12:12

bc3b172a1070883336fcb4e0de01e512.webp

Java技术栈

www.javastack.cn

关注阅读更多优质文章



作者:废物大师兄
来源:www.cnblogs.com/cjsblog/p/14007311.html

本文探讨 Nacos 作为配置中心,如何实现不同环境(开发、测试、灰度、正式)的配置管理问题。

51bd5d60bfa9fd553a07989795aa4ad7.webp

就像Maven用groupId、artifactId、version三者来定位jar包在仓库中的位置一样,Nacos也提供了 Namespace (命名空间) 、Data ID (配置集ID)、 Group (组) 来确定一个配置文件(或者叫配置集)。

由此,实现多环境配置的方案也有三种:

1、用命名空间(namespace)来区分不同的环境,一个命名空间对应一个环境;

2、用配置组(group)来区分不同的环境,命名空间用默认的public即可,一个组对应一种环境;

3、用配置集ID(Data ID)名称来区分不同的环境,命名空间和组用默认的即可,通过文件命名来区分;

接下来,逐个来看

http://{host}:{port}/nacos

http://{host}:{port}/nacos/index.html

默认用户名密码都是nacos

0103f2dc8e21ce119afacb0945689d60.webp

为了方便演示,这里建了一个名为example的Spring Boot项目:

434cb17851f58fcc5ed029da06d24f22.webp

pom.xml

 1 "1.0" encoding="UTF-8"?>
 2 "http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 3          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
 4     4.0.0
 5     
 6         org.springframework.boot
 7         spring-boot-starter-parent
 8         2.3.6.RELEASE
 9          
10     

11     com.example
12     example
13     0.0.1-SNAPSHOT
14     example
15 
16     
17         1.8
18         2.2.3.RELEASE
19     

20 
21     
22         
23             org.springframework.boot
24             spring-boot-starter-web
25         

26         
27             com.alibaba.cloud
28             spring-cloud-starter-alibaba-nacos-config
29         

30     

31 
32     
33         
34             
35                 com.alibaba.cloud
36                 spring-cloud-alibaba-dependencies
37                 ${spring-cloud-alibaba.version}
38                 <type>pomtype>
39                 import
40             

41         

42     

43 
44     
45         
46             
47                 org.springframework.boot
48                 spring-boot-maven-plugin
49             

50         

51     

52 
53 

bootstrap.yml

spring:
  application:
    name: example
  cloud:
    nacos:
      config:
        server-addr: 192.168.100.10:8848
        file-extension: yaml

Spring Boot 基础不介绍了,不会的推荐看下这个教程:

https://github.com/javastacks/spring-boot-best-practice

HelloController.java

package com.example.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.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @author ChengJianSheng
 * @data 2020/11/19
 */
@RestController
@RequestMapping("/hello")
@RefreshScope
public class HelloController {

    @Value("${greet.hello}")
    private String greet;

    @GetMapping("/sayHi")
    public String sayHi() {
        return greet;
    }
}

1、利用 Data ID 命名 来区分环境

利用Data ID命名来区分环境,命名空间和组默认即可。

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

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

用命令行启动也是一样的:

43f2ebd02dae92bcc7a6fbb46adf4fdd.webp

例如:

java -Dspring.profiles.active=test -jar example-0.0.1-SNAPSHOT.jar
b35f80db143f07569a3326b20c887d69.webp

2、利用 Group 来区分环境

项目不变,我们把spring.application.name改成example2

命名空间用默认的public

9b517ef166040bf67154028ba6931ec9.webpf0f0c053f707ce21279ae6e4a2ddd10f.webpd0917c07d34c6cdbff33fd608504fc08.webp
java -Dspring.cloud.nacos.config.group=DEV_GROUP -jar example-0.0.1-SNAPSHOT.jar
61d33c802b4bcf129feb6d1fc4b0ed12.webp
java -Dspring.cloud.nacos.config.group=TEST_GROUP -jar example-0.0.1-SNAPSHOT.jar
80d417ecee7aafa3a7febc61c8e54c46.webp
java -Dspring.profiles.active=test -Dspring.cloud.nacos.config.group=TEST_GROUP -jar example-0.0.1-SNAPSHOT.jar

如果是这样的话,这个时候,Data ID 命名就应该是 example2-test.yaml

3、利用 Namespace 区分环境

a075b84724addcdcfc5609c7da161559.webp

创建命名空间的时候,如果不指定ID,则自动生成的id就是这样的uuid字符串,我们还是自己指定一个有意义的ID吧

83d9fd3b8ddf03821a54988947608a31.webpa0024531ff09470de55664ba50ab72c3.webp9227500fe3b9b07689e62fd2b9407553.webp2b27f7a5bce605844fb004730e5d15f9.webpe3322cf854aceca270304ba7828cb7b0.webpc6300c448a62c2291141e5907f95ff34.webp3ca8f3ac84ede2b443c9ee3e98c4516f.webp
java -Dspring.cloud.nacos.config.namespace=ns_dev -jar example-0.0.1-SNAPSHOT.jar
be9257a84ef96886c5a68030cca02034.webp
java -Dspring.profiles.active=dev -Dspring.cloud.nacos.config.namespace=ns_dev -jar example-0.0.1-SNAPSHOT.jar
a1e41299b0b27d3e76f14f878e2b2e26.webp
java -Dspring.cloud.nacos.config.namespace=ns_test -jar example-0.0.1-SNAPSHOT.jar
2b8c69b1daa3a935eb63ef02b2c7da2a.webp
java -Dspring.profiles.active=test \
     -Dspring.cloud.nacos.config.namespace=ns_test \
     -Dspring.cloud.nacos.config.group=TEST_GROUP \
     -jar example-0.0.1-SNAPSHOT.jar
3d25ffe6a9ddd1d581798a919befb721.webp

4、小结

第一种,用 Data ID 区分环境,虽然简单,但是每个项目要创建4个配置文件,随着项目的增多,都在一个命名空间下回显得很混乱,查找起来也不是很方便,而且不利于做权限控制

第二种,用Group区分,问题也是一样的

综上,最好的是用Namespace区分环境,清晰明了,而且有利于做权限控制

https://nacos.io/zh-cn/docs/concepts.html

d5d5301f236c76a196b6c9b696e80e61.webp


f73da3c6f65c390bc5133dddfa9c40af.webp

f48eb6da2446ead21ea711212e8ded0f.webp
74825a5b049dbe66842629f67ad3aed5.webp4e737c2a45135551e6939b1ee65f11ce.webp13b9e73833e8280c476409ebde1fbd34.webp
458091a0c11b4a968722f0099517de31.webp



关注Java技术栈看更多干货



c5bcbefb4a2f4316607315c08df64d4e.webp戳原文,获取精选面试题!
浏览 3
点赞
评论
收藏
分享

手机扫一扫分享

举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

举报