温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么使用FeignClient设置动态Url

发布时间:2022-06-28 13:58:11 来源:亿速云 阅读:2361 作者:iii 栏目:开发技术

本文小编为大家详细介绍“怎么使用FeignClient设置动态Url”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么使用FeignClient设置动态Url”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

    FeignClient设置动态Url

    1. 需求描述

    一般情况下,微服务内部调用都是通过注册中心,eureka,zookeeper,nacos等实现动态调用,但是对于一些外部http调用,对于不在同一微服务内,不在同一注册中心的服务调用,可以考虑SpringCloudOpenFeign,而且可以实现动态URL,通过参数动态控制。

    2. 实现方案

    服务端正常springboot项目,也不一定是springboot项目,只要正常提供RESTFul接口就可以,本次测试以springboot为例。主要是客户端调用。

    1.服务端:

    /**
     * (Category)控制层
     *
     * @author makejava
     * @since 2021-06-03 07:20:41
     */
    @RestController
    @RequestMapping("/category")
    public class CategoryController {
        /**
         * 服务对象
         */
        @Resource
        private CategoryService categoryService;
        /**
         * 测试服务
         */
        @GetMapping("/test")
        public Response test() {
            return Response.createSuccessResponse("查询成功", "我是测试服务");
        }
    }

    2.客户端:

    maven依赖

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

    客户端代码

    /**
     * 测试
     * @author zrj
     * @since 2021-07-25
     */
    @Api(value = "微盟鉴权测试")
    @RestController
    @RequestMapping("/weimob")
    public class ActivityController {
        @Resource
        private CategoryService categoryService;
        @GetMapping("/test")
        @ApiOperation(value = "微盟获取Code")
        public Response test() throws URISyntaxException {
            System.out.println("-----测试-----");
            URI uri = new URI("http://localhost:8080/category/test");
            Response response = categoryService.test(uri);
            return Response.createSuccessResponse("查询成功", response);
        }
    }

    调用接口

    /**
     * 测试接口Openfeign
     * @author zrj
     * @since 2021/7/25
     **/
    @Service("WeimobAuthorize")
    @FeignClient(url = "http://localhost:8080/category", name = "CategoryService")
    public interface CategoryService {
        @GetMapping
        Response test(URI uri);
    }

    3. 细节分析

    1.接口使用SpringMVC注解

    接口方法的定义使用了SpringMVC的注解 @GetMapping、@RequestParam,其实SpringMVC的其他注解在此处都是支持的。(有其他文章提到也支持OpenFeign原有的注解@RequestLine、@Param等,但博主实测是不支持的,相关解析类为 feign.Contract,这个存疑)。

    2.springcloud openfeign自动构建实现类

    在使用方式上,OpenFeign需要手动构建代理对象,Spring Cloud OpenFeign 不同于 OpenFeign, Spring Cloud OpenFeign 帮我们自动生成了接口的代理对象(即实现类),并且注册到Spring中,我们可以很方便的使用 @Autowired 注入代理对象然后使用。

    其默认的代理对象是 LoadBalancerFeignClient。还有一个代理对象是 feign.Client.Default。

    两者区别在于:LoadBalancerFeignClient 通过服务名(下文提到)从Eureka查找相关的节点地址url,发起调用。feign.Client.Default 仅是简单的直接调用。

    3.FeignClient属性name与URL一定要指定

    @FeignClient(url = “http://localhost:8080/category”, name = “CategoryService”)

    name 属性,是@FeignClient 注解必要的,不定义时会报错其默认指代Eureka上的服务名。

    url 属性,一定要指定,这是重点了! url属性指定什么值其实不重要,因为最终都会被方法的URI参数值替换掉,它在这里另一个重要的作用,就是将接口的代理对象变成feign.Client.Default(上文提到默认是LoadBalancerFeignClient),这样就绕过了从Eureka取节点地址这一步,毕竟第三方的地址不可能注册到我们的Eureka上。(相关细节可自行debug FeignClientFactoryBean.getTarget())

    FeignClient注解配置url属性实现指定服务方

    某天,跟同学聊天,同学说起之前面试的时候面试官提的一个问题:使用spring cloud,现在某个服务有一个新的接口需要验证。该接口目前只上线了一台机器,如何指定调用方只调用这台机器。问题大致如此,可能有些出入。总结起来,就是希望能够指定访问某台机器。这样的情况,在我们平时也可能经常遇到。比如甲乙两人需要调试新接口,但注册中心只有一个。可能上面有丙丁戊己庚辛注册的服务。如果我们按照默认的轮询的负载均衡规则去调用,七次调用才能轮到乙的服务,根本没有办法调试。所以这时候就需要我们能够指定调用的服务方。

    FeignClient注解通过配置url属性可以指定调用的服务方。我们按照上面的例子,假设乙的IP为192.168.1.2,在端口8080上启动的服务,那我们就可以把我们的url配置成http://192.168.1.2:8080。这样调用的就一直是乙的服务了。

    那我们配置了url和不配置url到底产生了哪些不同呢?

    feign,或者说open-feign底层是使用,我以为默认是httpclient,但是我debug的结果是HttpURLConnection。知道为什么的可以留言告诉我。feign会基于配置,生成URI。当我们不配置url的时候,URI是这样的http://service-name/path。使用FeignClien是LoadBalancerFeignClient,该类在处理该URI的时候会对服务名进行解析,也就是从注册中心查询该服务名下已经注册的服务器信息,包括IP和端口。然后将服务名替换成真实的链接。而当我们不配置url的时候,使用的FeignClient是Client的默认实现Default,该类就没有解析的这一步而是直接通过HttpURLConnection进行请求。

    读到这里,这篇“怎么使用FeignClient设置动态Url”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注亿速云行业资讯频道。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI