RestTemplate和OpenFeign两者的区别
1.RestTemplate:
是springCloud中轻量级的RESTful的http客户端的。RestTemplate内置的Ribbon,用来客户端负载均衡,去调用EurekaService注册的服务。
2.OpenFeign:
在OpenFeign同样也支持Ribbon做负载均衡,在Feign的基础上支持了SpringMVC的注解,。如:@RequstMapping等OpenFeign的@FeignClient可以解析springMVC的@RequestMapping注解下的接口,并通过动态代理产生实现类,实现类中做负载均衡并调用其他服务。完成对服务方的接口绑定、自动封装。
OpenFeign使用步骤
(启用一个组件一般分为四步:1.引入依赖 2.声明 3.启用 4.业务逻辑中使用)
1.引入OpenFeign依赖:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
2.声明(声明接口):
@FeignClient(value = "CLOUD-PAYMENT-SERVICE") //CLOUD-PAYMENT-SERVICE 为目标服务器在注册中心的名字
public interface IPaymentService {
@RequestMapping("/payment/get/{id}") //目标服务的接口、参数等等
CommonResult<Payment> getPaymentById(@PathVariable("id") Long id);
}
3.启用(在主启动类上添加):
@SpringBootApplication
@EnableFeignClients
public class OrderFeignMain80 {
public static void main(String[] args) {
SpringApplication.run(OrderFeignMain80.class,args);
}
}
4.在业务逻辑中使用:
@RestController
@Slf4j
public class OrderFeignController {
@Resource
private IPaymentService paymentService;
@RequestMapping("/consumer/payment/get/{id}")
CommonResult<Payment> getPaymentById(@PathVariable("id") Long id){
return paymentService.getPaymentById(id);
}
}
参考代码
1.地址:
https://github.com/TianLuhua/springCloud2020.git
2.模块:
2.1 客户端 cloud-consume-feign-rorder80
2.2 服务端 cloud-provider-payment8001和cloud-provider-payment8002
2.3 注册中心 cloud-eureka-server7001和cloud-eureka-server7002
其他
1.这里说下客户端的eureka.client.fetch-registry和eureka.client.register-with-eureka。案例中并没有将客户端注册到注册中心去,设置fetch-registry为true照样也能从注册中心获取服务的信息。配置如下:
eureka:
client:
#是否从EurekaServer中获取信息,默认为true。单节点无所谓,集群时候必须开启才能结合ribbon使用负载均衡
fetch-registry: true
#表示是否将自己注册到Euerka中
register-with-eureka: false