• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

搭建SpringCloudAlibaba:Nacos服务配置心

武飞扬头像
一直Tom猫
帮助1

  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当中,具体怎么配置呢?

学新通

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

学新通

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

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

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

学新通

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

学新通

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

学新通

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包

  1.  
    <dependency>
  2.  
    <groupId>com.alibaba.cloud</groupId>
  3.  
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
  4.  
    </dependency>

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

学新通

 贴出配置文件

  1.  
    server:
  2.  
    port: 8001 #服务端口
  3.  
    spring:
  4.  
    datasource:
  5.  
    type: com.alibaba.druid.pool.DruidDataSource #当前数据源操作类型
  6.  
    driver-class-name: org.gjt.mm.mysql.Driver #数据库驱动包
  7.  
    url: jdbc:mysql://localhost:3306/test?autoReconnect=true&useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false
  8.  
    username: root
  9.  
    password: 123456
  10.  
     
  11.  
    management:
  12.  
    endpoints:
  13.  
    jmx:
  14.  
    exposure:
  15.  
    include: '*'
  16.  
     
  17.  
    #mybatis:配置
  18.  
    mybatis:
  19.  
    mapperLocations: classpath:dao/*.xml
  20.  
    type-aliases-package: com.buba.springcloud.pojo # 所有pojo别名类所在包
学新通

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

  1.  
    spring:
  2.  
    application:
  3.  
    name: mcroservice-payment #服务名
  4.  
    cloud:
  5.  
    nacos:
  6.  
    config:
  7.  
    server-addr: localhost:8848
  8.  
    # 配置中心配置文件的后缀名格式
  9.  
    file-extension: yaml
  10.  
    # 是否动态刷新,默认为false
  11.  
    refresh: true
  12.  
    discovery:
  13.  
    server-addr: localhost:8848
  14.  
    # 当前环境对应的profile
  15.  
    profiles:
  16.  
    active: dev
学新通

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

学新通

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

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

学新通

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

学新通

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

学新通


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

学新通

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

  1.  
    @Value("${config.info}")
  2.  
    private String configInfo;
  3.  
     
  4.  
    @GetMapping("/config/info")
  5.  
    public String getConfigInfo(){
  6.  
    System.out.println(configInfo);
  7.  
    return configInfo;
  8.  
    }

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

学新通

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

学新通

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

 学新通

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

学新通

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

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

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

学新通

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

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

学新通

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

学新通

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

学新通

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

学新通

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

学新通

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

学新通

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

学新通

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

学新通

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

学新通

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

学新通

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhiabkha
系列文章
更多 icon
同类精品
更多 icon
继续加载