【springcloud alibaba】配置中心之nacos

接着上一篇的【springcloud alibaba】注册中心之nacos,这一篇主要讲nacos的配置中心能力。nacos的集群部署及持久化请看上一篇

--------------------------------------------------目录-----------------------------------------------

 

1.微服务配置中心是什么

2.微服务为什么配置中心

  2.1 传统项目中的配置处理,一般可能存在的问题

  2.2 微服务配置中心

3.常见的微服务中心对比

4.nacos配置中心的使用

5.如何技术选型

6.nacos配置中心原理

--------------------------------------正文 -----------------------------------------------

 

1.微服务配置中心是什么

  「配置中心」,顾名思义,就是用来统一管理微服务项目中所有配置的系统。一个规范和成熟互联网研发团队,微服务项目中多般使用到配置中心。

2.微服务为什么配置中心

  2.1 传统项目中的配置处理,一般可能存在的问题

    2.1.1 静态化配置。这种做法虽然简单,但如果参数需要修改,就非常的不灵活,甚至需要重启运行中的项目才能生效。
    2.1.2 配置文件无法区分环境。(springboot项目profile支持环境区分)
    2.1.3 配置文件过于分散。如果一个项目中存在多个逻辑模块独立部署,每个模块所使用的配置内容又不相同,传统的做法是会在每一个模块中都放一个配置文件,甚至不同模块的配置文件格式还不一样。那么长期的结果就是配置文件过于分散混乱,难以管理。
    2.1.4 配置修改无法追溯。(配置放在代码中,通过git/svn提交记录可追溯)

  2.2 微服务配置中心 

    「配置中心」的思路就是把项目中各种配置、各种参数、各种开关,全部都放到一个集中的地方进行统一管理,并提供一套标准的接口。
    简单来说:
      当各微服务应用需要加载配置信息时(例:启动时),会到配置中心获取「配置中心」中的配置信息;
      当需要实时更新运行中的应用的配置时,在置配中心更新对应微服务应用的配置,之后或通过配置中心将配置的变更信息推送给微服务应用,或微服务应用主动到配置中心拉取变更的配置信息。
      即能做到不停机动态变更配置信息。

  即:微服务配置中心能提高配置的安全性(一些敏感信息不需要放在代码的配置文件中),能支持实时修改,不需要重启应用;

3.常见的微服务中心对比

  对比源自:深度对比三种主流微服务配置中心

  功能特性对比总结

  这里列一个表格总结一下三个产品的功能特点:

  

4.nacos配置中心的使用

  4.1 nacos配置中心核心概念

    参考自:https://zhuanlan.zhihu.com/p/165539448

    官网wiki: https://github.com/alibaba/spring-cloud-alibaba/wiki/Nacos-config

    

    配置集

    多个键值对,一般指一个配置文件。

    一组相关或者不相关的配置项的集合称为配置集(多个键值对/一个配置文件)。在系统中,一个配置文件通常就是一个配置集,包含了系统各个方面的配置。例如,一个配置集可能包含了数据源、线程池、日志级别等配置项。

    配置集id

    给这个配置文件起一个全局唯一的 ID。

    Nacos 中的某个配置集的 ID。配置集 ID 是组织划分配置的维度之一。Data ID 通常用于组织划分系统的配置集。一个系统或者应用可以包含多个配置集,每个配置集都可以被一个有意义的名称标识。Data ID 通常采用类 Java 包(如 com.taobao.tc.refund.log.level)的命名规则保证全局唯一性。此命名规则非强制。

    配置分组

    多个配置文件放在一起,形成组,一般用于区分项目。

    Nacos 中的一组配置集,是组织配置的维度之一。通过一个有意义的字符串(如 Buy 或 Trade )对配置集进行分组,从而区分 Data ID 相同的配置集。当您在 Nacos 上创建一个配置时,如果未填写配置分组的名称,则配置分组的名称默认采用 DEFAULT_GROUP 。配置分组的常见场景:不同的应用或组件使用了相同的配置类型,如 database_url 配置和 MQ_topic 配置。

    配置快照

    缓存配置信息。

    Nacos 的客户端 SDK 会在本地生成配置的快照。当客户端无法连接到 Nacos Server 时,可以使用配置快照显示系统的整体容灾能力。配置快照类似于 Git 中的本地 commit,也类似于缓存,会在适当的时机更新,但是并没有缓存过期(expiration)的概念。

    命名空间

    用于进行租户粒度的配置隔离。不同的命名空间下,可以存在相同的 Group 或 Data ID 的配置。Namespace 的常用场景之一是不同环境的配置的区分隔离,例如开发测试环境和生产环境的资源(如配置、服务)隔离等。

  4.2 nacos客户端配置及使用
    首先,启动上一篇部署好的nacos集群,并进行登陆,默认账号/密码为:nacos/nacos

    创建测试项目如:

    

    引入spring-cloud-starter-alibaba-nacos-config 的starter.

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

    在运行此 Example 之前, 必须使用 bootstrap.properties 配置文件来配置Nacos Server 地址,例如:

    bootstrap.properties  
spring.application.name=nacos-config-client
spring.cloud.nacos.config.server-addr=120.79.7.7:8888

    启动类: 

/**
 * @author wjqhuaxia
 * @create 2020-12-28 23:26
 */
@SpringBootApplication
public class ProviderApplication {

    public static void main(String[] args) {
        ConfigurableApplicationContext applicationContext = SpringApplication.run(ProviderApplication.class, args);
        String userName = applicationContext.getEnvironment().getProperty("user.name");
        String userAge = applicationContext.getEnvironment().getProperty("user.age");
        System.err.println("user name :"+userName+"; age: "+userAge);
    }
}

    在nacos配置管理中添加nacos-config-client.properties文件

    启动测试项目,项目启动时默认加载项目名.properties文件,例:nacos-config-client.properties

   获取配置中心的数据项:

 

  4.3 nacos实用配置方式

  

   或者也可以使用namespace区分不同项目,使用group区分不同环境。

5.如何技术选型

  理解需求、技术特点是技术选型的首要任务

  配置中心的维度(是否具备以下能力):
    1.配置集中管理:分布式配置中心最基础的要求
    2.配置实效性:配置的修改实时生效要求
    3.安全性:应用和配置的管理具有完善的权限管理机制,并且新增编辑和发布环节,尽量减少了人工误操作发生的概率,所有的操作都有审计日志,方便追踪
    4.配置修改简单:提供的图形化界面形式的配置管理
    5.部署简单:依赖非常少
    6.开源:源码的重要性不言而喻,无论是解决问题、扩展新功能、或者后期代替官方渠道进而形成满足自身特定需求的版本
    7.版本发布管理:所有的配置发布都有版本概念,从而可以方便地支持配置的回滚
    8.灰度发布:支持配置的灰度发布,比如点了发布后,只对部分应用实例生效,等观察一段时间没问题后再推给所有应用实例
    9.权限管理、发布审核、操作审计:
      应用和配置的管理都有完善的权限管理机制,对配置的管理还分为了编辑和发布两个环节,从而减少人为的错误。
      所有的操作都有审计日志,可以方便地追踪问题
    10.提供开放平台API

6.nacos配置中心原理

   https://www.cnblogs.com/jsjwk/p/10880671.html

参考:

  https://blog.csdn.net/crave_shy/article/details/81285217

  https://www.cnblogs.com/jsjwk/p/10880671.html

  http://www.360doc.com/content/19/0403/17/99071_826205359.shtml

  http://blog.didispace.com/spring-cloud-alibaba-3/

 

posted @ 2020-12-27 10:31  天际星痕  阅读(151)  评论(0编辑  收藏  举报