手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心

 

  SpringCloud Alibaba全集文章目录:

零、手把手教你搭建SpringCloudAlibaba项目

一、手把手教你搭建SpringCloud Alibaba之生产者与消费者

二、手把手教你搭建SpringCloudAlibaba之Nacos服务注册中心

三、手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心

四、手把手教你搭建SpringCloudAlibaba之Nacos服务集群配置

五、手把手教你搭建SpringCloudAlibaba之Nacos服务持久化配置

六、手把手教你搭建SpringCloudAlibaba之Sentinel实现流量实时监控

七、手把手教你搭建SpringCloudAlibaba之Sentinel实现流量控制

八、手把手教你搭建SpringCloudAlibaba之Sentinel服务降级

九、手把手教你搭建SpringCloudAlibaba之Sentinel热点key限流

十、手把手教你搭建SpringCloudAlibaba之Sentinel系统保护规则

十一、手把手教你搭建SpringCloudAlibaba之Sentinel服务熔断

十二、手把手教你搭建SpringCloudAlibaba之Sentinel规则持久化

十三、手把手教你搭建SpringCloudAlibaba之Seata分布式事务

点击跳转学习 -------------->手把手教你搭建SpringCloud项目

一、如何整合Nacos作为配置中心?

Nacos既然要作为配置中心,我们的配置肯定是要放在Nacos当中,具体怎么配置呢?

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第1张图片

即在配置管理下的配置列表进行配置。点击右上角的+,进行添加配置。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第2张图片

 Data ID :如何进行命名呢,命名的规则是什么呢?

配置规则为${prefix}-${spring.profile.active}.${file-extension}

prefix 默认为spring.applaction.name的值,也可以通过配置项spring.cloud.nacos.config.prefix来配置。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第3张图片

spring.profile.active 即为当前环境对应的profile,详情可以参考SpringBoot文档,注意:当spring.profile.active 为空时,对应的连接符 - 也将不存在,dataId的拼接格式变为${prefix}.${spring.cloud.nacos.config.file-extension}

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第4张图片

file-extension   为配置内容的数据格式,可以通过项spring.cloud.nacos.config.file-extension 来配置。目前只支持properties和yaml类型。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第5张图片

Nacos Spring Cloud 快速开始Nacos Spring Cloud 快速开始https://nacos.io/zh-cn/docs/quick-start-spring-cloud.html

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

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

我们首先就将我们生产者的服务的配置文件放到Nacos的配置列表当中。

1、加入配置中心所需要的jar包

   
        com.alibaba.cloud
        spring-cloud-starter-alibaba-nacos-config
    

2、在Nacos当中新建配置文件,命令规则就是上边所说的规则。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第6张图片

 贴出配置文件

server:
  port: 8001 #服务端口
spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource  #当前数据源操作类型
    driver-class-name: org.gjt.mm.mysql.Driver  #数据库驱动包
    url: jdbc:mysql://localhost:3306/test?autoReconnect=true&useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false
    username: root
    password: 123456

management:
  endpoints:
    jmx:
      exposure:
        include: '*'

#mybatis:配置
mybatis:
  mapperLocations: classpath:dao/*.xml
  type-aliases-package: com.buba.springcloud.pojo    # 所有pojo别名类所在包

3、我们在resources下新建bootstrap.yml配置文件

spring:
  application:
    name: mcroservice-payment  #服务名
  cloud:
    nacos:
      config:
        server-addr: localhost:8848
        # 配置中心配置文件的后缀名格式
        file-extension: yaml
        # 是否动态刷新,默认为false
        refresh: true
      discovery:
        server-addr: localhost:8848
 # 当前环境对应的profile
  profiles:
    active: dev

我们的项目目录结构就成了

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第7张图片

4、在我们启动类上加上注解

@RefreshScope 该注解支持nacos的动态刷新的功能,Springcloud原生的注解,实现配置自动更新

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第8张图片

 5、启动服务,在控制就可以看到我们的服务启动的时候加载了nacos数据,数据ID:“mcroservice-payment-dev.yaml”,组:“DEFAULT_GROUP”,对应的profile是dev,也读取到我们配置的端口号8081。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第9张图片

 6、我们访问http://localhost:8001/payment/get/1,可以返回数据,说明我们的配置中心就配置成功啦。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第10张图片


有时候我们会在配置文件中配置一些信息,比如我们与第三方的集成的时候,会在配置文件加上对方的配置的域名、ip端口啥的,当这些信息发生改变的话,我们使用nacos的话就可以直接修改我们nacos中的配置文件,不用动我们项目中的配置,也不用重新打包、启动。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第11张图片

 在PaymentControler的类上加上@RefreshScope注解,类中加入如下代码,看能否获取到我们新增的配置信息

    @Value("${config.info}")
    private  String configInfo;

    @GetMapping("/config/info")
    public String getConfigInfo(){
        System.out.println(configInfo);
        return configInfo;
    }

访问http://localhost:8001/config/info可以成功获取到我们刚刚配置的信息,如下图:

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第12张图片

可以动态的刷新配置,那我们修改其配置的信息,看看不重启服务,会不会获取到修改后的信息。将端口修改成了8003。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第13张图片

在我们发布的时候,控制台也有日志记录,说我们config.info这个key发生了更改。

 

我们访问http://localhost:8001/config/info可以看到已经获取到我们修改的的端口8003。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第14张图片

二、了解Nacos中的分类设计思想

1、一个大型分布式微服务会有很多的的微服务子项目,每个微服务项目又都有响应的开发环境、测试环境、正式环境,那怎么对这些微服务配置进行管理呢?

Nacos为我们提供了命令空间(NameSpace)+分组(Group)+dataid的分类设计思想,我们可以看到在Nacos的界面有命名空间,且有默认的值为public,是不能删除的,可以看到当前空间只有一个配置文件。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第15张图片

NameSpace主要是用来隔离的,比如我们不同的环境,就可以新建不同的命名空间,不同的命名空间是隔离的。

而看我们刚才的配置文件就是在public这个命名空间当中,且是默认的分组DEFAULT_GROUP,可以把不同的微服务划分到同一个分组中去。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第16张图片

那我们就接下来新建一个命名空间看一下,我们新建命名空间为test,可以看到dadataid是自动生成的,也可以自己写dadataid,是需要唯一的。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第17张图片

 可以看到新的命名空间就新建成功了。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第18张图片

我们分别在test的命名空间下新建两个文件,分别在不同的分组下,如下图:

这是DEFAULT_GROUP默认分组下的mcroservice-payment-test.yaml的配置文件                                                                       

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第19张图片

这是在DEV_GROUP下的 mcroservice-payment-dev.yaml配置文件

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第20张图片

然后我们先测试一下再test命名空间下的DEV_GROUP分组下的mcroservice-payment-test.yaml的配置文件,如下图:

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第21张图片

访问 http://localhost:8001/config/info,如下图,获取到了DEFAULT_GROUP默认分组下我们配置的info信息。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第22张图片

 我们再测试一下再test命名空间下的DEFAULT_GROUP默认分组下的mcroservice-payment-test.yaml的配置文件,如下图:

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第23张图片

访问 http://localhost:8001/config/info,如下图,获取到了DEV_GROUP分组下我们配置的info信息。

手把手教你搭建SpringCloudAlibaba之Nacos服务配置中心_第24张图片

你可能感兴趣的:(微服务学习篇,微服务,spring,cloud,spring,boot,spring,java)