SpringCloudAlibaba-Nacos

概述和版本说明

xml 复制代码
<spring.boot.version>3.2.0</spring.boot.version>
<spring.cloud.version>2023.0.0</spring.cloud.version>
<spring.cloud.alibaba.version>2022.0.0.0</spring.cloud.alibaba.version>

注册中心,配置中心及动态刷新广播通知

Spring Cloud Alibaba 参考文档 (spring-cloud-alibaba-group.github.io)

下载安装使用

Release 2.2.3 (May 25th, 2023) · alibaba/nacos (github.com)

shell 复制代码
D:\tool\nacos-server-2.2.3\nacos\bin>startup.cmd -m standalone

服务注册中心

provider

xml 复制代码
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
yaml 复制代码
server:
  port: 9001
spring:
  application:
    name: nacos-pay-provider
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 # nacos地址
java 复制代码
@SpringBootApplication
@EnableDiscoveryClient
public class Main9001 {

    public static void main(String[] args) {
        SpringApplication.run(Main9001.class, args);
    }
}
java 复制代码
@RestController
public class PayAlibabaController {

    @Value("${server.port}")
    private String serverPort;

    @GetMapping("/pay/nacos/{id}")
    public String getPayInfo(@PathVariable("id") Integer id) {
        return "nacos registry serverPost: " + serverPort + ", id: " + id;
    }
}

consumer

需要额外添加 load-balance 依赖

yaml 复制代码
server:
  port: 9000
spring:
  application:
    name: nacos-order-consume
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 # nacos地址

service-url:
  nacos-user-service: http://nacos-pay-provider

配置 RestTemplate

java 复制代码
@RestController
public class OrderController {

    @Resource
    private RestTemplate restTemplate;

    @Value("${service-url.nacos-user-service}")
    private String serverURL;

    @GetMapping("/order/pay/nacos/{id}")
    public String paymentInfo(@PathVariable("id") Integer id) {
        return restTemplate.getForObject(serverURL + "/pay/nacos/" + id, String.class);
    }

}

-DServer.port=9002

GET http://localhost:9000/order/pay/nacos/112 测试负载均衡 端口 9001 9002 交替出现

服务配置中心和动态刷新

xml 复制代码
<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

也是需要 bootstrap

yaml 复制代码
spring:
  application:
    name: nacos-config-client
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
      config:
        server-addr: localhost:8848
        file-extension: yaml
java 复制代码
@RestController
@RefreshScope // 支持动态刷新功能
public class NacosConfigClientController {

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

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

nacos 中配置匹配规则

nacos-config-client-dev.yaml

测试接口和动态刷新

ps: nacos 历史配置回滚功能

Nacos数据模型 Namespace-Group-DataId三元组

解决多项目多环境配置问题

DataId 方案

使用默认 Namespace 默认 Group

不同 DataId,使用服务名+环境名来区分

Group 方案

通过Group实现环境区分,默认 Namespace

新建 group PROD_GROUP 的配置

Namespace 环境区分

新建命名空间 Prod_Namespace,不填写id,会自动生成

相关推荐
不知疲倦的仄仄9 小时前
第一天:从 ByteBuffer 内存模型到网络粘包处理实战
java·网络·nio
Tinachen889 小时前
YonBIP旗舰版本地开发环境搭建教程
java·开发语言·oracle·eclipse·前端框架
星火开发设计10 小时前
堆排序原理与C++实现详解
java·数据结构·c++·学习·算法·排序算法
七七powerful10 小时前
docker28.1.1和docker-compose v.2.35.1安装
java·docker·eureka
小白学大数据10 小时前
百科词条结构化抓取:Java 正则表达式与 XPath 解析对比
java·开发语言·爬虫·正则表达式
2501_9418072610 小时前
在迪拜智能机场场景中构建行李实时调度与高并发航班数据分析平台的工程设计实践经验分享
java·前端·数据库
一 乐10 小时前
餐厅点餐|基于springboot + vue餐厅点餐系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端
ss27310 小时前
volatile的可见性、安全发布的秘密与ThreadLocal原理
java·开发语言
Blossom.11810 小时前
基于多智能体协作的自动化数据分析系统实践:从单点工具到全流程智能
运维·人工智能·分布式·智能手机·自动化·prompt·边缘计算
小猪配偶儿_oaken10 小时前
SpringBoot实现单号生成功能(Java&若依)
java·spring boot·okhttp