Spring cloud Feign 入门demo

spring Feign (服务与服务调用工具)
    添加Feign依赖:
            <dependency>  
                <groupId>org.springframework.cloud</groupId>  
                <artifactId>spring-cloud-starter-feign</artifactId>  
            </dependency>
    
    application.properties中添加配置,超时时间设置和服务提供方的地址和端口号
    #Feign
    ribbon.ConnectTimeout=3000
    ribbon.ReadTimeout=60000
    admin.ribbon.listOfServers=192.16.150.130:8082
    
    启动类上要加@EnableFeignClients注解
    
    注意:如果使用的spring cloud版本比较新,在新版本中Feign对Hystrix的支持是默认关闭的,所以需要通过配置手动打开
          feign.hystrix.enabled=true,这样服务降级等功能才有效果。
    
    启动程序:
        @SpringBootApplication
        @EnableFeignClients
        public class MovCenterBootstrap {
            public static void main(String[] args) {
                SpringApplication.run(MovCenterBootstrap.class, args);
            }
        }
    
    @EnableFeignClients注解的作用:通过@EnableFeignCleints注解开启FeignCleint(在启动项目的时候会检查启动类上有没有@EnableFeignClients注解,如果有该注解,则开启包扫描,扫描被@FeignClient注解的接口并将这些信息注入到ioc容器中)
    
    服务调用方Client代码:
        @Component
        @FeignClient(url = "http://localhost:8010", name = "user")
        public interface UserClient {
        
            @RequestMapping(method = RequestMethod.POST,value="/user/findOne",consumes = MediaType.APPLICATION_JSON_UTF8_VALUE, produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
            Object findOne(@RequestParam("userId") Integer userId);
        }

        @FeignClient注解定义了该接口是一个Feign客户端,name指定了注册到Eureka上的服务名。
        @RequestMapping里指定了请求的相对url和http请求方式,与服务端一一对应。入参里的@RequestParam、@RequestBody、@RequestHeader注解比起服务端多了value属性,这里不能省略,需要显式的告知Feign客户端参数要如何对应
    
    服务调用方Controller代码:
        @RequestMapping("user")
        @RestController
        public class UserController {

            @Autowired
            private UserClient userClient;
    
            @PostMapping("findOne")
            @ApiOperation(value="查找单个用户", notes="根据id查询单个用户")
            @ApiImplicitParam(name="userId",value="userId",required=true,paramType="query")
            public Object findOne(@RequestParam("userId") Integer userId){
                Object result = userClient.findOne(userId);
                return result;
            }
        }
    
    spring cloud Feign 超时问题:默认的请求时间为1秒,超过这个时间便超时异常,在配置文件中添加如下配置可以解决超时问题,即把超时的时间设长
    application.yml服务调用方配置:hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 60000
    
    
    服务提供方Controller代码:
        @RestController
        @RequestMapping("/user")
        public class UserController {

            @Autowired
            UserService userService;
            @PostMapping("/findOne")
            @ApiOperation(value="查询单个用户",notes="根据id查询单个用户信息")
            @ApiImplicitParam(name="userId",value="userId",required=true,paramType="query")
            public ObjectRestResponse<User> findOne(@RequestParam Integer userId){
                ObjectRestResponse<User> result = new ObjectRestResponse<User>();
                User user = userService.selectById(userId);
                result.data(user);
                return result;
            }

        }


总结:Feign的源码实现的过程如下:

  • 首先通过@EnableFeignCleints注解开启FeignCleint
  • 根据Feign的规则实现接口,并加@FeignCleint注解
  • 程序启动后,会进行包扫描,扫描所有的@ FeignCleint的注解的类,并将这些信息注入到ioc容器中。
  • 当接口的方法被调用,通过jdk的代理,来生成具体的RequesTemplate
  • RequesTemplate在生成Request
  • Request交给Client去处理,其中Client可以是HttpUrlConnection、HttpClient也可以是Okhttp
  • 最后Client被封装到LoadBalanceClient类,这个类结合类Ribbon做到了负载均衡。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Spring Boot环境下使用Feign框架,您可以按照以下步骤进行操作: 1. 首先,确保您的项目中已经引入了Feign的核心库。您可以在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>io.github.openfeign</groupId> <artifactId>feign-core</artifactId> <version>11.0</version> </dependency> ``` 引用 2. 接下来,您需要引入FeignSpring Boot集成的依赖项。您可以在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>io.github.openfeign</groupId> <artifactId>feign-spring-boot-starter</artifactId> <version>11.0</version> </dependency> ``` 引用 3. 确保您的Feign客户端接口已经定义好,并且使用了Spring MVC提供的注解,例如@RequestMapping和@RequestParam。这样,您就可以使用Feign实现声明式调用。引用 4. 配置Feign客户端的属性。您可以在application.properties或application.yml文件中添加以下配置项: ```yaml feign.client.config.default.connect-timeout=5000 feign.client.config.default.read-timeout=5000 ``` 这些是示例配置,您可以根据您的需求进行自定义。 5. 最后,在您的代码中使用Feign客户端进行调用。您可以通过@Autowired注解将Feign客户端注入到您的代码中,然后使用它来调用远程服务。例如: ```java @Autowired private UserServiceFeignClient userServiceFeignClient; public void someMethod() { User user = userServiceFeignClient.getUserById(1); // 处理返回的User对象 } ``` 引用 请注意,上述代码示例中的UserServiceFeignClient是您自己定义的Feign客户端接口,getUserById是该接口中的一个方法。 这样,您就可以在Spring Boot环境下使用Feign框架了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Spring Boot 声明式调用 Feign 入门](https://blog.csdn.net/weixin_42073629/article/details/107172240)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值