zoukankan      html  css  js  c++  java
  • 19.SpringCloud实战项目-SpringCloud整合Alibaba-Nacos配置中心

    SpringCloud实战项目全套学习教程连载中

    PassJava 学习教程

    简介

    • PassJava-Learning项目是PassJava(佳必过)项目的学习教程。对架构、业务、技术要点进行讲解。
    • PassJava 是一款Java面试刷题的开源系统,可以用零碎时间利用小程序查看常见面试题,夯实Java基础。
    • PassJava 项目可以教会你如何搭建SpringBoot项目,Spring Cloud项目
    • 采用流行的技术,如 SpringBoot、MyBatis、Redis、 MySql、 MongoDB、 RabbitMQ、Elasticsearch,采用Docker容器化部署。

    更好的阅读体验

    文档连载目录

    1.传统配置方式

    • application.properties文件中定义两个配置:
    member.nickname = "悟空聊架构"
    member.age = "18"
    
    • 示例控制器中定义私有变量nickname和age,@value代表从配置中取值
    @Value("${member.nickname}")
    private  String nickname;
    
    @Value("$member.age")
    private  Integer age;
    
    • 示例控制器中定义方法:获取nick和age的值
    @RequestMapping("/test-local-config")
    public R testLocalConfig() {
        return R.ok().put("nickname", nickname).put("age", age);
    }
    
    • 测试结果

    mark

    总结:从配置文件中获取配置。

    这种方式的缺点是什么呢?如果要修改配置参数,则需要重新启动服务。如果服务很多,则需要重启所有服务,非常不方便。

    有没有什么办法不停服务修改配置而且使其生效呢?

    答案:有的,用Spring Cloud Alibaba的Nacos 组件就可以完成。

    2.引入Nacos依赖

    PassJava-Common项目的pom.xml文件引入Spring Cloud Alibaba Nacos Config依赖

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

    3.配置Nacos元数据

    • passjava-member 添加 /src/main/resources/bootstrap.properties 配置文件(注意:bootstrap.properties 优先级高于其他配置文件)

    • 配置 Nacos Config 元数据

    bootstrap.properties

    spring.application.name=passjava-member
    spring.cloud.nacos.config.server-addr=127.0.0.1:8848
    

    4.Nacos后台新增配置

    Data ID: passjava-member.properties

    Group: DEFAULT_GROUP

    配置格式:

    member.nick="悟空"
    member.age=10
    

    Nacos后台新增配置

    5.开启动态刷新配置功能

    添加注解@RefreshScope开启动态刷新配置功能

    @RefreshScope
    @RestController
    @RequestMapping("member/sample")
    public class SampleController {}
    

    可以从控制台看到日志信息:

    Refresh keys changed: [member.age]
    2020-04-19 23:34:07.154  INFO 8796 --- [-127.0.0.1_8848] c.a.nacos.client.config.impl.CacheData   : [fixed-127.0.0.1_8848] [notify-ok] dataId=passjava-member.properties, group=DEFAULT_GROUP, md5=df136e146c83cbf857567e75acb11e2b, listener=com.alibaba.cloud.nacos.refresh.NacosContextRefresher$1@4f49b78b 
    2020-04-19 23:34:07.154  INFO 8796 --- [-127.0.0.1_8848] c.a.nacos.client.config.impl.CacheData   : [fixed-127.0.0.1_8848] [notify-listener] time cost=529ms in ClientWorker, dataId=passjava-member.properties, group=DEFAULT_GROUP, md5=df136e146c83cbf857567e75acb11e2b, listener=com.alibaba.cloud.nacos.refresh.NacosContextRefresher$1@4f49b78b 
    

    member.age 更新了,通知了member服务,刷新了配置。对应的配置id为passjava-member.properties,分组为DEFAULT_GROUP。监听器为com.alibaba.cloud.nacos.refresh.NacosContextRefresher

    6.测试结果

    访问:http://localhost:10000/member/sample/test-local-config

    结果:nickname和age和Nacos后台配置一致

    结论:只用在Nacos后台改配置即可实时修改配置。

    注意:Nacos的配置项优先级高于application.propertite里面的配置。

    测试结果

    7.命名空间

    我们现在有5个微服务,每个微服务用到的配置可能都不一样,那不同微服务怎么样获取自己微服务的配置呢?

    这里可以用到命名空间,我们针对每个微服务,都创建一个命名空间。

    • 创建命名空间

      创建命名空间

    # 创建5个命名空间
    passjava-channel
    passjava-content
    passjava-member
    passjava-question
    passjava-study
    

    命名空间

    • 命名空间下创建配置

      我们打开配置列表菜单,可以看到有五个命名空间。

      命名空间下创建配置

    选中passjava-channel命名空间,然后新增配置项,与之前新增配置的步骤一致,也可以通过克隆命名空间来克隆配置。

    克隆配置

    • 修改指定的命名空间

      bootstrap.properties配置命名空间

      spring.cloud.nacos.config.namespace=passjava-member
      
    • 测试配置是否生效

      修改passjava-member.properties的配置内容

      passjava-member.properties

      重启member服务

      访问方法:/member/sample/test-local-config

      执行结果:

      {
          "msg": "success",
          "code": 0,
          "nickname": ""悟空member"",
          "age": 30
      }
      

      说明获取的是passjava-member命名空间的配置

    8.分组

    如果我们有多套环境,比如开发环境,测试环境,生产环境,每一套环境的配置参数不一样,那配置中心该如何配置呢?

    我们可以使用配置中心的分组功能。每一套环境都是一套分组。

    • 首先创建一套dev环境配置项,然后克隆配置到test和prod环境

    dev环境

    dev、test、prod分组

    • bootstrap.properties配置当前使用的分组:prod
    spring.cloud.nacos.config.group=prod
    
    • 测试获取生产环境配置

      {
          "msg": "success",
          "code": 0,
          "nickname": ""悟空-prod"",
          "age": 10
      }
      

      可以看到获取到的是prod分组的配置

    9.多配置集

    我们可以将application.yml文件中的datasource、mybatis-plus等配置进行拆解,放到配置中心。group可以创建3套,dev/test/prod。

    1.配置中心新建datasource.yml 配置

    datasource.yml 配置

    2.配置中心新建mybatis.yml 配置

    mybatis.yml配置

    3.配置中心新建more.yml 配置

    more.yml配置

    4.克隆dev环境配置到test和prod环境

    mark

    5.bootstrap.properties增加nacos配置,application.yml注释配置

    spring.application.name=passjava-member
    spring.cloud.nacos.config.server-addr=127.0.0.1:8848
    
    spring.cloud.nacos.config.namespace=passjava-member
    spring.cloud.nacos.config.group=prod
    
    spring.cloud.nacos.config.extension-configs[0].data-id=datasource.yml
    spring.cloud.nacos.config.extension-configs[0].group=dev
    spring.cloud.nacos.config.extension-configs[0].refresh=true
    
    spring.cloud.nacos.config.extension-configs[1].data-id=mybatis.yml
    spring.cloud.nacos.config.extension-configs[1].group=dev
    spring.cloud.nacos.config.extension-configs[1].refresh=true
    
    spring.cloud.nacos.config.extension-configs[2].data-id=more.yml
    spring.cloud.nacos.config.extension-configs[2].group=dev
    spring.cloud.nacos.config.extension-configs[2].refresh=true
    

    6.测试配置是否生效

    • 测试passjava-member.properties和more.yml配置是否生效

    请求url:http://localhost:10000/member/sample/test-local-config

    返回配置的nick和age,且端口是10000,且member服务注册到注册中心

    {
        "msg": "success",
        "code": 0,
        "nickname": ""悟空-prod1"",
        "age": 22
    }
    
    • 测试datasource.yml和mybatis.yml配置是否生效

    请求url:http://localhost:10000/member/member/list

    返回数据库查询结果

    {
        "msg": "success",
        "code": 0,
        "page": {
            "totalCount": 0,
            "pageSize": 10,
            "totalPage": 0,
            "currPage": 1,
            "list": []j
        }
    }
    

    说明以上配置都生效了。

    更多配置项

    配置项 key 默认值 说明
    服务端地址 spring.cloud.nacos.config.server-addr
    DataId前缀 spring.cloud.nacos.config.prefix spring.application.name
    Group spring.cloud.nacos.config.group DEFAULT_GROUP
    dataID后缀及内容文件格式 spring.cloud.nacos.config.file-extension properties dataId的后缀,同时也是配置内容的文件格式,目前只支持 properties
    配置内容的编码方式 spring.cloud.nacos.config.encode UTF-8 配置的编码
    获取配置的超时时间 spring.cloud.nacos.config.timeout 3000 单位为 ms
    配置的命名空间 spring.cloud.nacos.config.namespace 常用场景之一是不同环境的配置的区分隔离,例如开发测试环境和生产环境的资源隔离等。
    AccessKey spring.cloud.nacos.config.access-key
    SecretKey spring.cloud.nacos.config.secret-key
    相对路径 spring.cloud.nacos.config.context-path 服务端 API 的相对路径
    接入点 spring.cloud.nacos.config.endpoint UTF-8 地域的某个服务的入口域名,通过此域名可以动态地拿到服务端地址
    是否开启监听和自动刷新 spring.cloud.nacos.config.refresh-enabled true

    10.使用Nacos总结

    • 1.引入Nacos依赖

    • 2.配置Nacos数据源

    • 3.配置中心配置数据集DataId和配置内容

    • 4.开启动态刷新配置@RefreshScope

    • 5.获取配置项的值@value

    • 6.优先使用配置中心的配置

    • 7.使用命名空间namespace来创建各服务的配置

    • 8.使用分组group来区分不同环境

    • 9.使用多配置集extension-configs区分不同类型的配置

    代码地址

    https://github.com/Jackson0714/PassJava-Platform

    公众号

    公众号

  • 相关阅读:
    JBPM 入门阅读
    Jquery ligerui下拉框复选,使下拉框中相应值对勾选中
    spring quartz 1.6配置方法
    断点续传的原理
    转:DWR详细应用介绍
    转:第一个DWR示例
    解决(CXF):SOAPFaultException: Fault occurred while processing
    s2sh保存错误: a different object with the same identifier value was already associated
    解决 java.lang.NoSuchMethodError: org.objectweb.asm.ClassVisitor.visit(IILjava/lang/String;Ljava/lan
    转载:struts2重要标签学习
  • 原文地址:https://www.cnblogs.com/jackson0714/p/12752833.html
Copyright © 2011-2022 走看看