2016-08-12 3 views
3

현재 내 프로젝트 중 하나에서 선언적 REST 클라이언트로 Feign을 사용하는 방법을 확인하고 있습니다. 다음봄 부팅 feign 클라이언트 HTTP를 받고

척하기 클라이언트입니다

이 인터페이스는 SpringBootApplication에 하나 개의 서비스에

@EnableFeignClients(basePackages = {"com.gp.cabbooking.services.feign"}) 

종속성의 pom.xml

의 부모 등

@Autowired 
SearchCabMsClient restService; 

추가 EnableFeignClients를 autowire가되어

@FeignClient(name = "SEARCHCABMS",configuration = AppFeignConfiguration.class) 
     public interface SearchCabMsClient { 

     @RequestMapping(value = "api/searchcab/locationcabtimedetail/search/getCabForLocationAfterTimeSlot", method = RequestMethod.GET) 
     String searchCabDetails(@PathVariable("fromDate") String fromDate, 
           @PathVariable("locationId") long locationId, 
           @PathVariable("isdeleted") byte isdeleted, 
           @PathVariable("hourforbooking")int hourforbooking); 
    } 

<parent> 
     <groupId>org.springframework.boot</groupId> 
     <artifactId>spring-boot-starter-parent</artifactId> 
     <version>1.3.5.RELEASE</version> 
</parent> 

의존성

<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-web</artifactId> 
</dependency> 

<dependency> 
    <groupId>org.springframework.cloud</groupId> 
    <artifactId>spring-cloud-starter-eureka</artifactId> 
</dependency> 

<dependency> 
    <groupId>org.springframework.cloud</groupId> 
    <artifactId>spring-cloud-starter-ribbon</artifactId> 
</dependency> 

<dependency> 
    <groupId>org.springframework.cloud</groupId> 
    <artifactId>spring-cloud-starter-feign</artifactId> 
</dependency> 

내가 리본의 도움으로이 서비스를 호출하려고 봄 내 체하다 클라이언트 프록시를 만들 디버깅하고 잘 을 작업하는 동안 내가 할 수 볼 수 있습니다하지만 난 방법을 실행할 때 정의 내 거짓말 클라이언트. 내가 feign.FeignException 무엇입니까 :

feign.FeignException: status 404 reading SearchCabMsClient#searchCabDetails(String,long,byte,int) 
    at feign.FeignException.errorStatus(FeignException.java:62) ~[feign-core-8.16.2.jar:8.16.2] 
    at feign.codec.ErrorDecoder$Default.decode(ErrorDecoder.java:91) ~[feign-core-8.16.2.jar:8.16.2] 
    at feign.SynchronousMethodHandler.executeAndDecode(SynchronousMethodHandler.java:134) ~[feign-core-8.16.2.jar:8.16.2] 
    at feign.SynchronousMethodHandler.invoke(SynchronousMethodHandler.java:76) ~[feign-core-8.16.2.jar:8.16.2] 
    at feign.hystrix.HystrixInvocationHandler$1.run(HystrixInvocationHandler.java:97) ~[feign-hystrix-8.16.2.jar:8.16.2] 
    at com.netflix.hystrix.HystrixCommand$1.call(HystrixCommand.java:293) ~[hystrix-core-1.5.3.jar:1.5.3] 
    at com.netflix.hystrix.HystrixCommand$1.call(HystrixCommand.java:289) ~[hystrix-core-1.5.3.jar:1.5.3] 
    at rx.internal.operators.OnSubscribeDefer.call(OnSubscribeDefer.java:46) ~[rxjava-1.1.5.jar:1.1.5] 
    at rx.internal.operators.OnSubscribeDefer.call(OnSubscribeDefer.java:35) ~[rxjava-1.1.5.jar:1.1.5] 
    at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:50) ~[rxjava-1.1.5.jar:1.1.5] 
    at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:30) ~[rxjava-1.1.5.jar:1.1.5] 
    at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:50) ~[rxjava-1.1.5.jar:1.1.5] 
    at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:30) ~[rxjava-1.1.5.jar:1.1.5] 
    at rx.Observable.unsafeSubscribe(Observable.java:8460) ~[rxjava-1.1.5.jar:1.1.5] 
    at rx.internal.operators.OnSubscribeDefer.call(OnSubscribeDefer.java:51) ~[rxjava-1.1.5.jar:1.1.5] 
    at rx.internal.operators.OnSubscribeDefer.call(OnSubscribeDefer.java:35) ~[rxjava-1.1.5.jar:1.1.5] 
    at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:50) ~[rxjava-1.1.5.jar:1.1.5] 

답변

0

당신이이 체하다 클라이언트를 사용하여 도달 서비스의 URL을 정의한 읽기 상태 (404)를? 404 찾을 수없는 문제입니다.

@FeignClient(name = "SEARCHCABMS", url = "${SEARCHCABMS.service.url}", 
    configuration = ClientConfiguration.class) 
    public interface SearchCabMsClient { 

    } 

url에 참조 홀더를두면 URL을 외부화하고 각 환경에 맞게 구성 할 수 있습니다.

URL을 구성한 경우 나머지 끝점을 확인하십시오.