亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

springcloud本地調(diào)試feign調(diào)用出現(xiàn)的詭異404問題及解決

 更新時(shí)間:2022年03月09日 11:59:41   作者:差不多程序員  
這篇文章主要介紹了springcloud本地調(diào)試feign調(diào)用出現(xiàn)的詭異404問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

本地調(diào)試feign調(diào)用出現(xiàn)的詭異404問題

問題產(chǎn)生

最近在給公司準(zhǔn)備做分布式事務(wù)框架seata的調(diào)研,準(zhǔn)備搭建一套demo,根據(jù)阿里云官網(wǎng)的案例,我準(zhǔn)備搭建一套微服務(wù)架子,分別含有business、order、storage三個(gè)微服務(wù)組成,其中第一個(gè)微服務(wù)實(shí)現(xiàn)業(yè)務(wù)聚合,調(diào)用后面兩個(gè)微服務(wù),后面兩個(gè)微服務(wù)只需要暴露接口,操作相關(guān)的數(shù)據(jù)庫,我再利用seata來做分布式的場(chǎng)景演示!

技術(shù)框架

SpringCloud eureka mybatis-plus feign ribbon seata

核心代碼

business調(diào)用方,在一個(gè)接口中通過feign調(diào)用其他2個(gè)服務(wù)

package com.blue.seata.business.service;
import com.blue.seata.order.api.remote.RemoteOrderService;
import com.blue.seata.storage.api.remote.RemoteStorageService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
/**
 * @author liulei
 * @version 1.0
 */
@Service
public class BusinessService {
    private static final Logger logger = LoggerFactory.getLogger(BusinessService.class);
    @Autowired
    RemoteOrderService orderService;
    @Autowired
    RemoteStorageService storageService;
    public boolean buy(String userId, String code, Integer count) throws InterruptedException {
        logger.info("用戶購買商品[{}],[{}]", code, count);
        orderService.create(userId, code, count);
        logger.info("調(diào)用訂單中心服務(wù)成功");
        Thread.sleep(2000);
        storageService.minus(code, count);
        logger.info("調(diào)用庫存中心服務(wù)成功");
        return true;
    }
}

Eureka客戶端配置,我使用的是網(wǎng)上公益注冊(cè)中心

eureka:
  instance:
    prefer-ip-address: true #以IP地址注冊(cè)到服務(wù)中心,相互注冊(cè)使用IP地址
  client:
    service-url:
      defaultZone: http://eurekdsa.springclouddsds.cn/edsdureka/
    registry-fetch-interval-seconds: 5

詭異的404

問題描述:在保證Feign接口暴露的配置沒有錯(cuò)誤的前提下【一定沒問題】,我使用postman調(diào)用business的測(cè)試接口,第一次調(diào)用成功,但是再點(diǎn)擊同樣的接口,出現(xiàn)了以下報(bào)錯(cuò),我貼一下postman

第一次:

第二次:

心態(tài)

很絕望,但是沒辦法,還是得埋頭進(jìn)去看看是哪個(gè)錯(cuò)誤,看控制臺(tái)的錯(cuò)誤提示,發(fā)現(xiàn)這個(gè)地方對(duì)于服務(wù)最終解析的URL與我預(yù)期有出入

business中,第二次再調(diào)用接口的時(shí)候出現(xiàn)的,為什么是個(gè)問題,我解釋一下,我的business端口是6000,order端口是7000,storage是8000,大家反應(yīng)過來沒有,這塊解析出來的order接口調(diào)用怎么都不應(yīng)該是8000的端口,很明顯,解析出了問題,也就是說Feign解析出問題了,再往下想,F(xiàn)eign的組成由Ribbon+HttpClient組成,即服務(wù)路由+http訪問兩部分組件組成,這樣,我就基本可以確定,Ribbon的配置,出了問題,很遺憾我自己沒有解決,而且花費(fèi)了大量時(shí)間去查詢資料,但是沒有一個(gè)匹配上,大多說的都是常規(guī)配置,比如context-path,和consume、produce等格式配置的問題,最后問了一個(gè)小伙伴,他就調(diào)整了我business服務(wù)一個(gè)地方的代碼,看圖

小結(jié):

我到現(xiàn)在都不知道@RibbonClient這個(gè)注解,小伙伴解釋說這是服務(wù)級(jí)別的負(fù)載均衡,而注入Bean的方式的負(fù)載是全局負(fù)載,這可能和我本地的調(diào)試環(huán)境有關(guān)系,我再描述一下我的測(cè)試環(huán)境:

1.本地三個(gè)服務(wù),基本上代碼都一樣,使用同一個(gè)Eureka注冊(cè)中心

2.Ribbon和Feign的代碼符合日常咱們開發(fā)所見的代碼

3.自己近期狀態(tài)不好,過分相信百度,各種嘗試,發(fā)現(xiàn)問題定位的太晚,找到問題也不知道如何去描述,尷尬

4.關(guān)于這一塊的解釋,我后續(xù)需要翻閱資料才能給出,抱歉啦!

springcloud在本地調(diào)試的踩坑記錄

1、在本地調(diào)試的時(shí)候

可以專門配置一個(gè)application-local.yml。這個(gè)yml只在本地調(diào)試的時(shí)候使用。我覺得這個(gè)還是很有必要的,可以只在本地保存,不提交到Git。

2、修改配置文件中關(guān)于eureka的配置

之前自己一直沒有注意到這個(gè)問題,導(dǎo)致在服務(wù)本地運(yùn)行起來之后,一直不能再eureka的控制臺(tái)看到本地的服務(wù)。后來才注意到時(shí)自己沒有修改eureka中關(guān)于instance_id的配置。由于運(yùn)行了兩個(gè)相同id的服務(wù),所以會(huì)沖突。解決的辦法可以在eureka的instant_id的配置后面添加:{random.value},通過添加隨機(jī)數(shù)使得服務(wù)可以注冊(cè)兩次。

3、還是關(guān)于eureka的配置

在本地服務(wù)調(diào)用其他服務(wù)的時(shí)候,我發(fā)現(xiàn)一直是報(bào)超時(shí)的??戳撕笈_(tái)服務(wù)的運(yùn)行情況,用postman試一試,用swagger試一試,結(jié)果都沒有超時(shí),我一度以為是我的網(wǎng)絡(luò)有問題。后來突然想到服務(wù)的eureka配置。

我們的配置文件是這樣的:

prefer-ip-address: true
ip-address: 1**.***.***.49 # 訪問的路徑變?yōu)镮P地址

上面代碼中的ip是阿里云的內(nèi)網(wǎng)地址,外部是無法直接訪問的,于是我把第二行代碼注釋掉,換成相應(yīng)的外網(wǎng)地址。問題就這樣解決了。 

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • java寫的偽微信紅包功能示例代碼

    java寫的偽微信紅包功能示例代碼

    這篇文章主要介紹了java寫的偽微信紅包功能示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • Java中Thread和Runnable創(chuàng)建線程的方式對(duì)比

    Java中Thread和Runnable創(chuàng)建線程的方式對(duì)比

    本文主要介紹了Java中Thread和Runnable創(chuàng)建線程的方式對(duì)比,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • mybatis-plus批量更新太慢該如何解決詳解

    mybatis-plus批量更新太慢該如何解決詳解

    這篇文章主要給大家介紹了關(guān)于mybatis-plus批量更新太慢該如何解決的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-03-03
  • Spring MVC 學(xué)習(xí) 之 - URL參數(shù)傳遞詳解

    Spring MVC 學(xué)習(xí) 之 - URL參數(shù)傳遞詳解

    本篇文章主要介紹了SpringMVC-URL參數(shù)傳遞,在學(xué)習(xí) Spring Mvc 過程中,有必要來先了解幾個(gè)關(guān)鍵參數(shù),有興趣的可以了解一下。
    2017-01-01
  • Spring AOP有多少個(gè)通知以及它們的執(zhí)行順序介紹

    Spring AOP有多少個(gè)通知以及它們的執(zhí)行順序介紹

    這篇文章主要介紹了Spring AOP有多少個(gè)通知以及它們的執(zhí)行順序,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • java開發(fā)ServiceLoader實(shí)現(xiàn)機(jī)制及SPI應(yīng)用

    java開發(fā)ServiceLoader實(shí)現(xiàn)機(jī)制及SPI應(yīng)用

    這篇文章主要為大家介紹了java開發(fā)ServiceLoader實(shí)現(xiàn)機(jī)制及SPI應(yīng)用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • Sentinel源碼解析入口類和SlotChain構(gòu)建過程詳解

    Sentinel源碼解析入口類和SlotChain構(gòu)建過程詳解

    這篇文章主要為大家介紹了Sentinel源碼解析入口類和SlotChain構(gòu)建過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • Java源碼解析阻塞隊(duì)列ArrayBlockingQueue常用方法

    Java源碼解析阻塞隊(duì)列ArrayBlockingQueue常用方法

    今天小編就為大家分享一篇關(guān)于Java源碼解析阻塞隊(duì)列ArrayBlockingQueue常用方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • java運(yùn)算符實(shí)例用法總結(jié)

    java運(yùn)算符實(shí)例用法總結(jié)

    在本篇文章里,我們給大家分享的是關(guān)于java運(yùn)算符實(shí)例用法及實(shí)例代碼,需要的朋友們參考下。
    2020-02-02
  • Spring和SpringMVC父子容器關(guān)系初窺(小結(jié))

    Spring和SpringMVC父子容器關(guān)系初窺(小結(jié))

    這篇文章主要介紹了Spring和SpringMVC父子容器關(guān)系初窺(小結(jié)),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01

最新評(píng)論