springcloud-nacos简述

Spring Cloud alibaba: nacos服务注册中心,配置中心

服务注册中心

1.项目父工程添加springcloudalibaba依赖


    com.alibaba.cloud
    spring-cloud-alibaba-dependencies
    ${spring-cloud-alibaba.version}
    pom
    import

2.将想要暴露的服务对应的pom文件中添加如下依赖


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

3.工程相应yml文件配置

spring:
  application:
    name: content-api # 服务名称
  cloud:
    nacos:
      server-addr: 192.168.101.65:8848
      discovery:
        namespace: dev402  # 命名空间 要和nacos的相对应
        group: xuecheng-plus-project # 分组

配置完毕后启动content服务,nacos中观察。

springcloud-nacos简述_第1张图片

配置中心

需要配置的服务中要引入nacos的config依赖

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

Data Id 的组成(三部分)

第一部分:application.yaml中配置的应用名,即spring.application.name的值

第二部分:环境名,通过spring.profiles.active指定

第三部分:配置文件 的后缀,目前nacos支持properties、yaml等格式类型。

上面所说的三部分都是要在本地的yaml配置文件中配置的,正因为配置了这三部分服务启动的时候可以从nacos中获取到这个服务的配置的信息,即先去找content-api-dev.yaml这个配置文件。具体配置的优先级后面会说。

spring:
  application:
    name: content-service
  cloud:
    nacos:
      server-addr: 192.168.101.65:8848
      discovery:
        namespace: dev402
        group: xuecheng-plus-project
      config:
        namespace: dev402
        group: xuecheng-plus-project
        file-extension: yaml
        refresh-enabled: true

#profiles默认为dev
  profiles:
    active: dev

配置成功后可以看到控制台中打印NacosRestTemplate.java通过Post方式与nacos服务端交互读取配置信息。

 

 下面直接把完整的配置发出来自己,看一下。我全注释一下,简单东西简单说

server:
  servlet:
    context-path: /content # 服务请求时映射url前缀
  port: 6304 #端口号
#微服务配置
spring:
  application:
    name: content-api # 服务名Data Id 第一部分
  cloud:
    nacos:
      server-addr: 192.168.101.65:8848 # nacos地址,请确保服务可以正常访问
      discovery:   #服务注册的相关配置信息 
        namespace: dev402 # 在nacos页面中创建的命名空间
        group: xuecheng-plus-project # 服务所属分组
      config:   #配置文件相关信息
        namespace: dev402 # 命名空间
        group: xuecheng-plus-project # 服务所属分组
        file-extension: yaml # 程序应该使用 YAML 格式的文件作为配置文件
        refresh-enabled: true
        extension-configs: # 直接引入其他配置文件需要配置extension-configs
          - data-id: content-service-${spring.profiles.active}.yaml
            group: xuecheng-plus-project
            refresh: true
        shared-configs: # 公共配置用这个shared-configs:
          - data-id: swagger-${spring.profiles.active}.yaml
            group: xuecheng-plus-common
            refresh: true
          - data-id: logging-${spring.profiles.active}.yaml
            group: xuecheng-plus-common
            refresh: true
#  直接引用content-service-dev.yaml的数据库配置 但是理论上api层面不应包含数据库相关配置,引用也不行
#  datasource:
#    driver-class-name: com.mysql.cj.jdbc.Driver
#    url: jdbc:mysql://192.168.101.65:3306/gogs?serverTimezone=UTC&userUnicode=true&useSSL=false&
#    username: root
#    password: mysql
  #profiles默认为dev 环境名的Data Id 第二部分
  profiles:
    active: dev

springcloud-nacos简述_第2张图片

 配置优先级

springcloud-nacos简述_第3张图片

 项目启动首先加载bootstrap.yml,拿到nacos的请求地址与id获取到远程的nacos配置

其次加载本地的application.yml配置,并与nacos拉取到的配置合并

最后进行spring容器的创建、bean的加载......

配置文件的有限级:

项目应用名配置文件(data ID) > 扩展配置文件(extension-configs)  > 共享配置文件(shared-configs) > 本地配置文件(其他application.yml)。

配置本地优先

需求:有时候我们在测试程序时直接在本地加一个配置进行测试。

正常在idea的服务配置换个端口就可以但是由于受优先级影响,他会优先去nacos中查找相关服务配置,也就是说我们启动服务就会报错端口被占用。

解决办法:

#配置本地优先 
spring:
 cloud:
  config:
    override-none: true

 

导入配置

如果我们已经有了配置文件的zip包可以直接在nacos中进行配置的导入。

springcloud-nacos简述_第4张图片

 

你可能感兴趣的:(springcloud,spring,cloud,java,spring)