springcloud - 提供者-消费者

本文介绍了如何创建服务提供者和消费者,利用Eureka实现服务注册与发现。服务提供者配置了两个端口8020和8021,并创建了订单服务类。消费者端配置了服务发现,使用@LoadBalanced的RestTemplate进行负载均衡调用。启动后,消费者能从Eureka获取服务提供者的地址并进行轮询访问。

一、创建服务提供者

1、创建order 

2、启动类上添加属性

@EnableDiscoveryClient

3、修改配置文件,注册到euraka, 使用profiles设置两个端口

spring:
  profiles:
    active: order8020
  application:
    name: order
eureka:
  instance:
    hostname: eureka8001.com
  client:
    service-url:
      defaultZone: http://eureka8002.com:8002/eureka/,http://eureka8001.com:8001/eureka/
---
server:
  port: 8020
spring:
  config:
    activate:
      on-profile: order8020

---

server:
  port: 8021
spring:
  config:
    activate:
      on-profile: order8021

 

4、创建订单服务类

@RestController
public class OrderController {
   Logger logger = LoggerFactory.getLogger(OrderController.class);
   @GetMapping("/order")
   public String getOrder(String userName){
      logger.info("订单");
      return userName+"的订单";
   }
}

5、默认有一个配置是8020端口的,添加一个启动配置8021

二、创建消费者

1、创建项目

2、启动类上添加属性

@EnableDiscoveryClient

3、修改配置文件

server:
  port: 8010
spring:
  application:
    name: customer
eureka:
  instance:
    hostname: eureka8001.com
  client:
    service-url:
      defaultZone: http://eureka8002.com:8002/eureka/,http://eureka8001.com:8001/eureka/

 

4、添加服务发现实体类,

@LoadBalanced,可以提供负载均衡支持,如果有两个服务提供者,则默认是轮询访问服务。
@Configuration
public class RespTemplateConfig {
   @Bean
   @LoadBalanced
   public RestTemplate getRestTemplate(){
      return new RestTemplate();
   }
}

 

5、添加服务消费类,

http://ORDER, 这个ORDER就是上面服务的名称,通过这个名称在euraka中查找对应注册的地址,来进行负载均衡
@RestController
public class CustomerController {

   @Resource
   private RestTemplate restTemplate;

   @GetMapping("/customer")
   public String getCustomer(){
      Map<String,String> map = new HashMap<>();
      map.put("userName","cww");

      String result = restTemplate.getForObject("http://ORDER/order?userName={userName}",
              String.class,map);
      return "Hello ,"+result;
   }
}

三、启动

 

 

### Spring Cloud Consumer 使用方法 #### 定义消费者函数 为了创建一个有效的Spring Cloud Stream应用程序,需要明确定义消费者函数。此函数名需与`spring.cloud.function.definition`下的名称相匹配[^1]。 ```yaml spring: cloud: stream: function: definition: consumer1 ``` 对于上述配置,在Java代码中实现对应的消费逻辑如下: ```java @Bean public Consumer<String> consumer1() { return data -> { System.out.println("Received message: " + data); }; } ``` #### 绑定消息通道到绑定器 除了定义消费者外,还需指定如何连接至实际的消息中间件。这通过设置`spring.cloud.stream.bindings`来完成,其中指定了目标主题或队列等细节信息。 ```yaml spring: cloud: stream: bindings: consumer1-in-0: destination: my-topic group: my-group ``` 这里假设使用的是Kafka作为消息代理,则会订阅名为`my-topic`的主题,并加入组`my-group`以便于负载均衡和偏移管理。 #### 替代RestTemplate的方式 当构建基于声明式HTTP客户端的服务间通信时,可以考虑采用Feign替代传统的RestTemplate方式。这样做不仅简化了API调用过程,还提供了更优雅的接口设计[^2]。 在POM文件里引入必要的依赖项之后,只需编写简单的接口即可发起远程请求: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> ``` 接着定义FeignClient接口并标注相应的URL路径和服务ID: ```java @FeignClient(name="license", url="http://localhost:9090") public interface LicenseServiceClient { @GetMapping("/v1/organizations/{organizationId}/licenses") public String getLicenses(@PathVariable("organizationId") String organizationId, @RequestParam(value = "productCode", required = false, defaultValue = "") String productCode); } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值