您好,登錄后才能下訂單哦!
本篇內容介紹了“客戶端遠程調用Feign的方法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
Feign是 Netflix 公司開源的聲明式HTTP客戶端
Github : Feign 源碼
原代碼可讀性不高
復雜的URL難以維護(https://user-center/s?wd={userId}&rsv_spt=1&rsv_iqid=0x93bff3cd000cf3da&issp=1&f=8&rsv_bp=1&rsv_idx=2&ie=utf-8&tn=baiduhome_pg&rsv_enter=1&rsv_sug3=4&rsv_sug1=4&rsv_sug7=100&rsv_t=10c2risCimsUZC0RBruMerdnQRN1gRxFI%2BywuD0L3LwGGNd2dR8XE6x%2FyFOjHnR0oEi0&rsv_sug2=0&inputT=1535&rsv_sug4=1535&rsv_sug=2
)
難以應對需求的快速變化
編碼體驗和我們寫JAVA差異較大
//替換前 ResponseEntity<UserDTO> userEntity = restTemplate.getForEntity( "http://user-center/users/{userId}", UserDTO.class, userId ); UserDTO userDTO = new UserDTO(); if (null != userEntity) { userDTO = userEntity.getBody(); log.info("ShareService#findById userDTO: {}", userDTO); }
添加依賴
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>
啟動類添加注解 @EnableFeignClients
添加配置
實現對應微服務的client
/** * IUserCenterFeignClient for 定義 user-center feign client * * @author <a href="mailto:magicianisaac@gmail.com">Isaac.Zhang | 若初</a> * @since 2019/7/15 */ @FeignClient(name = "user-center") public interface IUserCenterFeignClient { /** * Feign client 會將請求轉換為 * http://user-center/users/{userId} * * @param userId 用戶id * @return 返回用戶對象 */ @GetMapping(path = "/users/{userId}") public UserDTO findById(@PathVariable Long userId); }
替換后代碼
//使用 FeignClient 來替換掉RestTemplate調用 UserDTO userDTO = this.userCenterFeignClient.findById(userId);
級別內容
**Tip **: 有可能出現父子上下文重疊問題
在client添加配置
/** * IUserCenterFeignClient for 定義 user-center feign client * * @author <a href="mailto:magicianisaac@gmail.com">Isaac.Zhang | 若初</a> * @since 2019/7/15 */ @FeignClient(name = "user-center",configuration = UserCenterFeignConfiguration.class) public interface IUserCenterFeignClient { ... }
編寫java配置文件
/** * UserCenterFeignConfiguration for 自定義user-center服務請求中,feign的配置信息 * {@link @Configuration} 不能添加該注解,否則會和ribbon一樣,出現上下文重疊問題,造成配置全局共享 * 如要添加該注解,需要將該類放在主程序啟動掃描不到的包下 * * @author <a href="mailto:magicianisaac@gmail.com">Isaac.Zhang | 若初</a> * @since 2019/7/15 */ public class UserCenterFeignConfiguration { @Bean public Logger.Level level() { // 配置feign 日志級別,記錄請求和響應的header、body以及元數據 return Logger.Level.FULL; } }
一定要在配置文件中添加該client 全路徑
logging: level: #com.sxzhongf: debug com.sxzhongf.sharedcenter.feignclients.IUserCenterFeignClient: debug
打印信息
2019-07-15 15:06:11.650 DEBUG 20286 --- [nio-8010-exec-1] c.s.s.f.IUserCenterFeignClient : [IUserCenterFeignClient#findById] <--- HTTP/1.1 200 (402ms) 2019-07-15 15:06:11.651 DEBUG 20286 --- [nio-8010-exec-1] c.s.s.f.IUserCenterFeignClient : [IUserCenterFeignClient#findById] content-type: application/json;charset=UTF-8 2019-07-15 15:06:11.651 DEBUG 20286 --- [nio-8010-exec-1] c.s.s.f.IUserCenterFeignClient : [IUserCenterFeignClient#findById] date: Mon, 15 Jul 2019 07:06:11 GMT 2019-07-15 15:06:11.651 DEBUG 20286 --- [nio-8010-exec-1] c.s.s.f.IUserCenterFeignClient : [IUserCenterFeignClient#findById] transfer-encoding: chunked 2019-07-15 15:06:11.652 DEBUG 20286 --- [nio-8010-exec-1] c.s.s.f.IUserCenterFeignClient : [IUserCenterFeignClient#findById] 2019-07-15 15:06:11.652 DEBUG 20286 --- [nio-8010-exec-1] c.s.s.f.IUserCenterFeignClient : [IUserCenterFeignClient#findById] {"id":1,"wxId":"","wxNickname":"IsaacZhang","roles":"","avatarUrl":"aaa","createTime":"2019-07-11T06:08:18.000+0000","updateTime":"2019-07-11T06:08:18.000+0000","bonus":100} 2019-07-15 15:06:11.652 DEBUG 20286 --- [nio-8010-exec-1] c.s.s.f.IUserCenterFeignClient : [IUserCenterFeignClient#findById] <--- END HTTP (173-byte body)
使用配置文件來定義log level
#logging: #level: #com.sxzhongf: debug #com.sxzhongf.sharedcenter.feignclients.IUserCenterFeignClient: debug feign: client: config: user-center: #單服務配置 loggerLevel: full --- feign: client: config: default: #全局配置日志級別 loggerLevel: full
官方不建議使用
大多數公司使用?
架構師需要根據自身業務情況來決定,是否需要將不同的微服務進行業務耦合,還是使用冗余代碼的方式來解放業務耦合性。
使用@SpringQueryMap
@FeignClient(name = "user-center") public interface ITestUserCenterFeignClient { @GetMapping("/users/q") public UserDTO query(@SpringQueryMap UserDTO userDTO); }
使用 @RequestParam
@FeignClient(name = "user-center") public interface ITestUserCenterFeignClient { @RequestMapping(value = "/users/q",method = RequestMethod.GET) public UserDTO query(@RequestParam("id") Long id,@RequestParam("name") String name); }
使用Map
構建,(不推薦)
@FeignClient(name = "user-center") public interface ITestUserCenterFeignClient { @RequestMapping(value = "/users/q",method = RequestMethod.GET) public UserDTO query(@RequestParam Map<String,Object> conditions); }
注意:這種方式不建議使用。主要是因為可讀性不好,而且如果參數為空的時候會有一些問題,例如
map.put("username", null);
會導致user-center
服務接收到的username是""
,而不是null。
服務提供者方法
@PostMapping("/create") public User createUser(@RequestBody User user){ return null; }
服務調用者
@FeignClient(name = "user-center") public interface ITestUserCenterFeignClient { @RequestMapping(value = "/users/q",method = RequestMethod.POST) public UserDTO query(@RequestBody UserDTO user); }
@FeignClient(name = "xxxxx",url = "http://www.baidu.com") public interface ITestBaiduFeignClient { @GetMapping("") public String getBaidu(); }
加依賴
<!--Feign 性能優化,需要使用連接池,引入依賴--> <dependency> <groupId>io.github.openfeign</groupId> <artifactId>feign-httpclient</artifactId> </dependency>
加注解(不需要)
改配置
httpclient: # 為feign啟用 apache httpclient 做請求,而不使用默認的urlconection enabled: true # feign 最大連接數 max-connections: 200 # feign 單個路徑請求的最大連接數 max-connections-per-route: 50
加依賴
<!--Feign 性能優化,需要使用連接池,引入依賴--> <dependency> <groupId>io.github.openfeign</groupId> <artifactId>feign-okhttp</artifactId> </dependency>
加注解(不需要)
改配置
httpclient: # 為feign啟用 apache httpclient 做請求,而不使用默認的urlconection #enabled: true # feign 最大連接數 max-connections: 200 # feign 單個路徑請求的最大連接數 max-connections-per-route: 50 okhttp: enabled: true
生產環境使用
Logger.Level.BASIC
“客戶端遠程調用Feign的方法”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。