第十九章 Nacos统一配置中心详解

一、nacos作为统一配置中心

1. 他管理配置文件方式是在自己所在服务器上形成一个版本库,因此不需要再创建远程版本库
2. nacos 作为统一配置中心管理配置文件时,同样也是存在版本控制

二、Nacos统一配置中心使用步骤

1. 创建独立配置中心的客户端

       此处将 第十八章 的 order-server 和 product-server 作为Nacos config 客户端。并都引入 Nacos 配置中的客户端依赖。

<!-- 引入Nacos Config  Client 配置中心客户端依赖 -->
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>

        springcloud2020 版本 把Bootstrap被默认禁用,spring.config.import加入了对解密的支持。对于Config Client、Consul、Vault和Zookeeper的配置导入,如果你需要使用原来的bootstrap的配置引导功能,那么需要将org.springframework.cloud:spring-cloud-starter-bootstrap依赖引入到工程中。


2. 将自身配置交给 Nacos config 管理

       此处将 第十八章 的 order-server 和 product-server 中的配置全部转移到Nacos config 中心。

 

3. 通知客户端拉取文件位置

       在客户端的resources中的 bootstrap 中告知 客户端需要到哪个位置拉取文件。

  • 告知 config server 地址,即Nacos server地址
  • 告知 服务的组。
  • 告知 配置文件的名字 

spring:
  cloud:
    nacos:
      config:
        #告知客户端到哪台服务器去找 nacos server 注册中心总的地址
        server-addr: localhost:8848 # 配置nacos server 注册中心地址
        group: DEFAULT_GROUP # 指定拉取的组
        name: order-prod # 指定拉取的文件名字
        file-extension: yaml

spring:
  cloud:
    nacos:
      config:
        #客户端指定 要拉取文件的配置中心的地址
        server-addr: localhost:8848 # 配置nacos server 配置中心地址
        group: DEFAULT_GROUP # 指定拉取的组
        name: product-prod # 指定拉取的文件名字
        file-extension: yaml

三、动态刷新

       此处将 第十八章 的 order-server 和 product-server 的controller基础上修改,并都使用注解@RefreshScope ,代码修改如下:

  • OrderController 使用注解@RefreshScope

OrderController 

import com.hwadee.springcloud.entity.Product;
import com.hwadee.springcloud.service.IOrderFeignService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/order")
@RefreshScope
public class OrderController {

    @Autowired
    IOrderFeignService orderFeignService;

    @RequestMapping("/buy/{id}")
    public Product buy(@PathVariable Long id) {
        Product product = orderFeignService.findOrderById(id);
        return product;
    }
}
  • ProductController 使用注解@RefreshScope 

 ProductController 

import com.hwadee.springcloud.entity.Product;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.math.BigDecimal;

@RestController
@RequestMapping("/product")
@RefreshScope
public class ProductController {
    //方便后面讲负载均衡,查看ip,此处获取配置中的端口号和ip
    @Value("${server.port}")
    private String port;
    @Value("${spring.cloud.client.ip-address}")
    private String ip;

    @RequestMapping("/buy/{id}")
    public Product findById(@PathVariable Long id) {
        Product product = new Product();
        product.setId(id);
        // 后面需要测试负载均衡,所以返回 ip 地址及端口号
        product.setName("当前访问服务地址:" + ip + ":" + port+"  "+"查询商品订单,订单号:"+id);
        product.setPrice(new BigDecimal(10000.0));
        System.out.println(product);
        return product;
    }
}
  • 重启服务修改Nacos上配置文件,进行测试

四、三个重要概念

  • 命名空间:默认命名空间是public,从项目的角度隔离多个项目的配置文件
  • 组:每个命名空间的组默认是DEFAULT_GROUP,从同一个项目的不同微服务角度隔离多个配置文件。
  • DataID:文件唯一标识(即文件名)

 1. 命名空间

     创建命名空间

2. 创建组 和 DataID 

 3. 指定命名空间、组和DataID

     修改引导文件 bootstrap ,指定命名空间,切记,命名空间使用其id。

  • order-server引导文件bootstrap.yml修改
spring:
  cloud:
    nacos:
      config:
        #客户端指定 要拉取文件的配置中心的地址
        server-addr: localhost:8848 # 配置nacos server 配置中心地址
        namespace: bbcccf09-be17-419e-864f-d2cce63bb258 #指定命名空间
        group: DEV # 指定拉取的组
        name: order-dev # 指定拉取的文件名字
        file-extension: yaml
  •  product-server引导文件bootstrap.yml修改
spring:
  cloud:
    nacos:
      config:
        #客户端指定 要拉取文件的配置中心的地址
        server-addr: localhost:8848 # 配置nacos server 配置中心地址
        namespace: bbcccf09-be17-419e-864f-d2cce63bb258  #指定命名空间
        group: DEV # 指定拉取的组
        name: order-dev # 指定拉取的文件名字
        file-extension: yaml

 4、启动测试

五、持久化切换配置

       Nacos默认使用自带的嵌入式数据库derby实现数据的存储。将 order-prod.yaml 等配置文件信息报错在本地。如果重新启动Nacos文件会消失。且如果启动多个默认配置下的Nacos节点,数据存储是存在一致性问题的。为了解决这个问题,Nacos采用了集中式存储的方式来支持集群化部署,目前只支持MySQL的存储。

Nacos 配置持久化 MySQL 存储步骤:

1. 安装数据库 mysql 数据库

2. 执行 mysql脚本
 

第十八章:第十八章 Nacos注册中心详解-入门案例及服务通信

第二十章:alibaba sentinel详解-简介及下载安装

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值