中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Spring cloud踩坑記錄之使用feignclient遠程調用服務404的方法

發布時間:2020-10-23 04:12:02 來源:腳本之家 閱讀:421 作者:李軍軍 欄目:編程語言

前言

公司項目進行微服務改造,由之前的dubbo改用SpringCloud,微服務之間通過FeignClient進行調用,今天在測試的時候,eureka注冊中心有相應的服務,但feignclient就是無法調通,一直報404錯誤,排查過程如下:

一、問題:

服務提供方定義的接口如下:

/**
 * 黑白名單查詢接口
 *
 * @author LiJunJun
 * @since 2018/10/18
 */
@Component(value = "blackAndWhiteListFeignClient")
@FeignClient(value = "pear-cache-service", path = "v1/cache/limitlist")
public interface IBlackAndWhiteListFeignClient {

 /**
  * 獲取黑白名單手機號分組編號
  *
  * @param trace 請求流水
  * @param phoneNum 電話號碼
  * @return 電話號碼所在分組
  */
 @RequestMapping(value = "/blackAndWhiteList", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
 ResultData<String> blackAndWhiteList(@RequestHeader(name = "Trace") String trace, @RequestParam("phoneNum") String phoneNum);
}

接口實現類如下:

/**
 * 黑白名單controller
 *
 * @author LiJunJun
 * @since 2018/10/18
 */
@ProtectedLdApi
@RestController
@RequestMapping(value = "v1/cache/limitlist")
@Api(value = "黑白名單緩存", description = "黑白名單緩存相關接口")
public class BlacklAndWhiteListController extends AbstractController implements IBlackAndWhiteListFeignClient {

 /**
  * 日志記錄器
  */
 private final static Log LOGGER = new Log(BlacklAndWhiteListController.class);

 /**
  * 注入tedis
  */
 @Autowired
 private JedisSentinelPoolExt jedisSentinelPool;

 /**
  * 獲取黑白名單手機號分組編號
  *
  * @param trace 請求流水
  * @param phoneNum 電話號碼
  * @return 電話號碼所在分組
  */
 @Override
 @ApiOperation(value = "獲取黑白名單手機號分組編號", notes = "根據電話號碼從緩存中獲取黑白名單分組")
 @RequestMapping(value = "/blackAndWhiteList", method = RequestMethod.POST, consumes = MediaType.APPLICATION_JSON_UTF8_VALUE, produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
 public ResultData<String> blackAndWhiteList(@RequestHeader(name = "Trace") String trace, @RequestParam("phoneNum") String phoneNum) {
  do something...
 }
}

調用方如下:

public class MessageListController {

 private static final Log LOGGER = new Log(MessageListController.class);

 @Autowired
 private IBlackAndWhiteListFeignClient blackAndWhiteListFeignClient;

 @RequestMapping(value = "/testBlackAndWhiteList", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
 public ResultData<String> testBlackAndWhiteList() {

  LOGGER.info("開始調用緩存接口");

  ResultData<String> res = blackAndWhiteListFeignClient.blackAndWhiteList("asdqwezxxc", "B18037903086");

  LOGGER.info("調用結果:" + res.getResultData());

  return res;
 }

調用結果:

Spring cloud踩坑記錄之使用feignclient遠程調用服務404的方法

 華麗麗的404了,很頭疼,經過各種度娘,發現導致這個問題有兩個原因,以下是解決方法:

二、問題分析

經過百度,說將SpringBoot配置文件里面 server.servlet.context-path 注釋掉即可,抱著試一哈的態度,注釋了,重啟,調用,結果驚喜的發現,依舊報錯了,但仔細一看,錯誤代碼已經不是404,變成了415,這就相當于調通了,但是,Content-Type的類型不對,于是,返回去看代碼(此時已經肯定,今天能把feignclient接口調通),

仔細一看發現,接口上定義的@RequestMapping中,只定義了 produces = MediaType.APPLICATION_JSON_UTF8_VALUE,而實現類中,@RequestMapping定義了consumes、produces均為 "application/json;charset=UTF-8"

我們知道,consumes定義了方法接受的Http的請求類型,produces則定義了Http請求返回的類型;

然后我們說下FeignClient,它的底層實現,就是根據定義的FeignClient接口,來組裝Http請求進行遠程調用,而Http默認的Content-type是x-www-form-urlencoded類型化的,到這兒,問題就呼之欲出了:

再來回顧上面我們定義的接口,并沒有指定請求類型(consumes),那么FeignClient組裝的Http請求的類型就是默認的x-www-form-urlencoded類型,但我們的實現類上,卻定義了consumes=MediaType.APPLICATION_JSON_UTF8_VALUE,也就是說,僅接受json類型的請求,這就是為什么415的原因了;

三、解決方法

知道了問題的原因,解決起來就很簡單了,我們可以在FeignClient的接口定義上,指定consumes,這樣,FeignClient在組裝Http請求的時候,就會在header里面設置請求類型為application/json,這樣,問題就完美解決;

Spring cloud踩坑記錄之使用feignclient遠程調用服務404的方法

再來看調用結果:

Spring cloud踩坑記錄之使用feignclient遠程調用服務404的方法

完美返回!!!

四、總結

feignclient接口定義是一個模板化的,其組裝的Http請求完全按照你定義的接口去組裝,如你在參數中,用@RequestHeader去接收一個參數,其組裝請求時,就會將你傳入的參數放至Header中,你指定的consumes為json,其組裝的請求Content-Type就是 application/json類型的,完全不需要調用方感知,就像調用普通方法一樣,不得不說,很強大,只要生成的Http請求正確,服務提供方提供的Rest接口能和FeignClient組裝的Http請求,就能夠完成遠程調用。

五、遺留問題

為什么需要將服務提供方的server.servlet.context-path去掉才能實現調用,今天暫時沒有研究,但一定有解決方案,SpringCloud不會這么low的,解決方案研究出來會補上。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

积石山| 凤山县| 定日县| 荣昌县| 通江县| 广东省| 九龙坡区| 沙洋县| 灯塔市| 佳木斯市| 大化| 绥滨县| 汉川市| 孝感市| 麟游县| 杭锦后旗| 于都县| 綦江县| 罗江县| 琼结县| 广平县| 惠安县| 婺源县| 芜湖县| 望江县| 明溪县| 平湖市| 黄浦区| 高邑县| 平利县| 库尔勒市| 江油市| 固安县| 甘洛县| 乌兰浩特市| 泗洪县| 大足县| 宁夏| 根河市| 惠州市| 乌鲁木齐市|