文章目录
一、HTTP客户端Feign
1. Feign代替RestTemplate
RestTemplate发起远程调用的代码
String url = "http://user-service/user/" + order.getUserId();
User user = restTemplate.getForObject(url, User.class);
存在的问题:
- 代码可读性差,编程体验不统一
- 参数复杂URL难以维护
Feign:是一个声明式客户端,作用是帮我们实现http请求的发送,解决上面提到的问题
定义和使用Feign客户端:
-
引入依赖
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>
-
在order-service的启动类添加注解开启Feign的功能
@SpringBootApplication @EnableFeignClients //开启Feign的功能 public class OrderApplication { public static void main(String[] args) { SpringApplication.run(OrderApplication.class, args); } }
-
编写Feign客户端
@FeignClient("user-service") public interface UserClient { @GetMapping("/user/{id}") User findById(@PathVariable Long id); }
主要是基于SpringMVC的注解来声明远程调用的信息,如:
- 服务名称:userservice
- 请求方式:GET
- 请求路径:/user/{id}
- 请求参数:Long id
- 返回值类型:User
-
调用Feign客户端实现远程调用
@Service public class OrderService { @Resource private OrderMapper orderMapper; @Autowired private UserClient userClient; public Order queryOrderById(Long orderId) { // 1.查询订单 Order order = orderMapper.findById(orderId); //2. 利用Feign发起http请求,查询用户 User user = userClient.findById(order.getUserId()); //3. 封装user到order order.setUser(user); return order; } }
2. 自定义配置
Feign运行自定义配置来覆盖默认配置,可修改的配置如下:
配置Feign日志有两种方式:
-
方式一:配置文件方式
-
全局生效:
feign: client: config: default: # 此处为default对所有服务生效 loggerLevel: FULL
-
局部生效:
feign: client: config: user-service: # 此处为服务名称只对该服务生效 loggerLevel: FULL
-
-
方式二:通过java代码配置
首先声明一个bean
public class FeignClientConfiguration { @Bean public Logger.Level feignLogLevel(){ return Logger.Level.BASIC; } }
如果是全局配置,则把它放在启动类的
@EnableFeignClients
注解中@SpringBootApplication @EnableFeignClients(defaultConf