SpringCloudAlibaba

Nacos

下载安装

基础概念

  • nacos配置中心通过namespacegroupdataId 来唯一确定一条配置,
  • dataId的格式:${prefix}-${spring.profiles.active}.${file-extension}
    • prefix:默认为spring.application.name
    • spring.profiles.active:当前激活的环境,当spring.profiles.active为空时,对应的连接符-也将不存在,dataId的拼接格式变 成:${prefix}.${file-extension}
    • ${file-extension}:默认为properties
  • 拉取多个共享文件,要在同一命名空间下,不能跨命名空间
  • 注意springboot和springcloud的版本对应

配置中心

  • 引入依赖

    java 复制代码
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-bootstrap</artifactId>
        <version>4.1.5</version>
    </dependency>
        
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        <version>2021.0.1.0</version>
    </dependency>
  • 完整bootstrap.properties配置:

    properties 复制代码
    spring.application.name=testccb
    spring.cloud.nacos.config.username=nacos
    spring.cloud.nacos.config.password=nacos
    spring.cloud.nacos.config.server-addr=192.168.1.211:8848
    spring.cloud.nacos.config.namespace=4f4b-363e-47a5-8a-dbd288c
    spring.cloud.nacos.config.group=com.iotsh
    
    # 拉取共享的配置
    spring.cloud.nacos.config.extension-configs[0].data-id=testccb.properties
    spring.cloud.nacos.config.extension-configs[0].group=ccb
    spring.cloud.nacos.config.extension-configs[0].refresh=true

注册中心

  • 引入依赖

    java 复制代码
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-bootstrap</artifactId>
        <version>4.1.5</version>
    </dependency>
    
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        <version>2021.0.1.0</version>
    </dependency>
  • 配置文件

    properties 复制代码
    spring.cloud.nacos.discovery.server-addr=192.168.1.211:8848
    spring.cloud.nacos.discovery.username=nacos
    spring.cloud.nacos.discovery.password=nacos
    spring.cloud.nacos.discovery.namespace=ed4b94b3-deff-49f1-8973-34029756083d
  • 主启动类:@EnableDiscoveryClient

OpenFeign

  • 引入依赖

    properties 复制代码
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>
  • 主启动类:@EnableFeignClients

    java 复制代码
    @SpringBootApplication
    @EnableDiscoveryClient
    @EnableFeignClients 
    public class EurekaClientApplication {
        public static void main(String[] args) {
            SpringApplication.run(CategoryApplication.class,args);
        }
    }
  • 配置文件

    yaml 复制代码
    feign:
      client:
        config:
          default:
            connect-timeout: 5000
            read-timeout: 5000
  • 创建FeignClient (调用者),注意传参

    java 复制代码
    @FeignClient(value = "product") // 被调用的服务名称
    public interface ProductClient {
        
        @RequestMapping("/status") // 被调用的服务接口
        public String status();
    
        @GetMapping("/paramRequest")
        public String paramRequest(@RequestParam("id") Integer id, @RequestParam("name") String name);
    
        @PostMapping("/bodyRequest")
        public String bodyRequest(@RequestBody User user);
    }
  • Controller中使用

    java 复制代码
    @RestController
    public class UserController {
        @Autowired
        private ProductClient productClient;  
    
        @GetMapping("/find")
        public String find(){
            return productClient.status();
        }
    }
  • 被调用的服务

    java 复制代码
    @RestController
    public class ProductController {
        // 没有参数
        @RequestMapping("/status")
        public String status(){
            return "client b is ok!";
        }
    
        // param参数
        @GetMapping("/paramRequest")
        public String paramRequest(@RequestParam("id") Integer id, @RequestParam("name") String name){
            return "paramRequest method is ok!, id:" + id +", name:"+ name;
        }
    
        // body有参数
        @PostMapping("/bodyRequest")
        public String bodyRequest(@RequestBody User user){
            return "bodyRequest method is ok!, user:" + user.toString();
        }
    }
相关推荐
短剑重铸之日12 小时前
《SpringCloud实用版》 Seata 分布式事务实战:AT / TCC / Saga /XA
后端·spring·spring cloud·seata·分布式事务
FAFU_kyp12 小时前
RISC0_ZERO项目在macOs上生成链上证明避坑
开发语言·后端·学习·macos·rust
qq_124987075312 小时前
基于springboot的会议室预订系统设计与实现(源码+论文+部署+安装)
java·vue.js·spring boot·后端·信息可视化·毕业设计·计算机毕业设计
女王大人万岁13 小时前
Go语言time库核心用法与实战避坑
服务器·开发语言·后端·golang
J_liaty13 小时前
Spring Boot + MinIO 文件上传工具类
java·spring boot·后端·minio
短剑重铸之日13 小时前
《SpringCloud实用版》Stream + RocketMQ 实现可靠消息 & 事务消息
后端·rocketmq·springcloud·消息中间件·事务消息
没有bug.的程序员13 小时前
Spring Boot 事务管理:@Transactional 失效场景、底层内幕与分布式补偿实战终极指南
java·spring boot·分布式·后端·transactional·失效场景·底层内幕
LuminescenceJ14 小时前
GoEdge 开源CDN 架构设计与工作原理分析
分布式·后端·网络协议·网络安全·rpc·开源·信息与通信
Tony Bai14 小时前
【分布式系统】11 理论的试金石:用 Go 从零实现一个迷你 Raft 共识
开发语言·后端·golang
短剑重铸之日14 小时前
《SpringCloud实用版》统一认证授权:Spring Authorization Server + OAuth2 + JWT 生产级方案
java·后端·spring·jwt·oauth2