1. 他管理配置文件方式是在自己所在服务器上形成一个版本库,因此不需要再创建远程版本库
2. nacos 作为统一配置中心管理配置文件时,同样也是存在版本控制
此处将 第十八章 的 order-server 和 product-server 作为Nacos config 客户端。并都引入 Nacos 配置中的客户端依赖。
com.alibaba.cloud spring-cloud-starter-alibaba-nacos-config
org.springframework.cloud spring-cloud-starter-bootstrap springcloud2020 版本 把Bootstrap被默认禁用,spring.config.import加入了对解密的支持。对于Config Client、Consul、Vault和Zookeeper的配置导入,如果你需要使用原来的bootstrap的配置引导功能,那么需要将org.springframework.cloud:spring-cloud-starter-bootstrap依赖引入到工程中。
此处将 第十八章 的 order-server 和 product-server 中的配置全部转移到Nacos config 中心。
在客户端的resources中的 bootstrap 中告知 客户端需要到哪个位置拉取文件。
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
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
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; } }
创建命名空间
修改引导文件 bootstrap ,指定命名空间,切记,命名空间使用其id。
spring: cloud: nacos: config: #客户端指定 要拉取文件的配置中心的地址 server-addr: localhost:8848 # 配置nacos server 配置中心地址 namespace: bbcccf09-be17-419e-864f-d2cce63bb258 #指定命名空间 group: DEV # 指定拉取的组 name: order-dev # 指定拉取的文件名字 file-extension: yaml
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脚本