首页 > 其他分享 >SpringCloud(二) FeignClient (整理&转发)

SpringCloud(二) FeignClient (整理&转发)

时间:2023-01-29 11:24:46浏览次数:74  
标签:FeignClient 调用 服务 请求 SpringCloud 接口 转发 public

SpringCloud跨服务调用

在一个服务里面调用其他服务的接口,有大概以下几种思路:(此处主要整理Nacos 注册中心调用服务)

  一、.在前台ajax直接请求接口的绝对路径,通过请求参数和返回体完成请求,但是缺点如果请求的接口服务器地址或者域名更换,需要重新替换代码,还可能造成跨域请求接口

  二、.使用springwork自带的RestTemplate或者使用第三方请求工具完成请求,这种方法虽然不会跨域请求,但是请求方的接口地址变化同样也需要改变

  三、.如果请求服务和被请求服务都注册在Nacos server上使用Feign请求。

    @FeignClient()注解就是为了解决这个跨服务调用问题的。
    @FeignClient()注解的源码要求它必须在Interface接口上使用。( FeignClient注解被@Target(ElementType.TYPE)修饰,表示FeignClient注解的作用目标在接口上)

    @FeignClient标签的常用属性如下
      value:服务名,用于服务发现(一般微服务多用)
      name: 指定FeignClient的名称,如果项目使用了Ribbon,name属性会作为微服务的名称,用于服务发现
      url:url一般用于调试,可以手动指定@FeignClient调用的地址
      decode404:当发生http 404错误时,如果该字段位true,会调用decoder进行解码,否则抛出FeignException
      configuration:Feign配置类,可以自定义Feign的Encoder、Decoder、LogLevel、Contract
      fallback:定义容错的处理类,当调用远程接口失败或超时时,会调用对应接口的容错逻辑,fallback指定的类必须实现@FeignClient标记的接口
      fallbackFactory:工厂类,用于生成fallback类示例,通过这个属性我们可以实现每个接口通用的容错逻辑,减少重复的代码
      path:定义当前FeignClient的统一前缀
      此外还要求服务的启动类要有@EnableRyFeignClients 注解才能使Fegin生效。

  示例代码:

/**
 * 日志服务
 * 
 * @author aei
 */
@FeignClient(contextId = "remoteLogService", value = ServiceNameConstants.SYSTEM_SERVICE, fallbackFactory = RemoteLogFallbackFactory.class)
public interface RemoteLogService
{
    /**
     * 保存系统日志
     *
     * @param sysOperLog 日志实体
     * @param source 请求来源
     * @return 结果
     */
    @PostMapping("/operlog")
    public R<Boolean> saveLog(@RequestBody SysOperLog sysOperLog, @RequestHeader(SecurityConstants.FROM_SOURCE) String source);  
}

value=“指定映射到的服务名称,服务需要是注册到nacos之类的注册中心”,注册的服务名称取项目配置spring.application.name

fallbackFactory =RemoteUserFallbackFactory.class指定调用远程地址出错时执行的回调。

回调工厂类的示例如下:

/**
 * 日志服务降级处理
 * 
 * @author aei
 */
@Component
public class RemoteLogFallbackFactory implements FallbackFactory<RemoteLogService>
{
    private static final Logger log = LoggerFactory.getLogger(RemoteLogFallbackFactory.class);
    @Override
    public RemoteLogService create(Throwable throwable)
    {
        log.error("日志服务调用失败:{}", throwable.getMessage());
        return new RemoteLogService()
        {
            @Override
            public R<Boolean> saveLog(SysOperLog sysOperLog, String source)
            {
                return null;
            }
        };

    }
}

 

参考学习网址:

SpringCloud微服务使用FeignClient调用跨服务接口

SpringCloud通过@FeignClient()注解定义调用远程服务

备注:以上信息仅个人学习整理,部分内容摘抄优秀博主

 

标签:FeignClient,调用,服务,请求,SpringCloud,接口,转发,public
From: https://www.cnblogs.com/xibei666/p/17072103.html

相关文章

  • springCloud (一)gateway (整理&转发)
    SpringCloudGateway是基于Spring5.0、SpringBoot2.0和ProjectReactor开发的网关,旨在提供一种简单而有效的方式来对API进行路由,基于过滤器链的方式提供:安全,监......
  • Nginx根据域名转发到不同的服务
    0.背景外网只放开了3955端口,现在根据不同的域名进行转发,例如:aa.test.com:3955->http://10.7.0.1:3009bb.test.com:3955->http://10.7.0.2:13371.Nginx配置1.1配......
  • SpringCloud Alibaba
    前言SpringCloudAlibaba致力于提供微服务开发的一站式解决方案。此项目包含开发分布式应用微服务的必需组件,方便开发者通过SpringCloud编程模型轻松使用这些组件来开......
  • 消息驱动(SpringCloud Stream)
    前言什么是消息驱动?屏蔽底层消息中间件的差异,降低切换成本,统一消息的编程模型官网:​​https://spring.io/projects/spring-cloud-stream#overview​​​​https://cloud.s......
  • 【Javaweb】Servlet八 | 请求转发的代码实现【详解】
    请求的转发什么是请求的转发?请求转发是指,服务器收到请求时,从一次资源转到另一个资源的操作叫做请求转发。 部分代码//获取请求的参数(办事的材料)查看......
  • 路由器分组转发算法
    以下内容参考<<计算机网络第五版>>谢希仁编著p128(1)首先从IP数据报首部提取出目的主机的IP地址D,得出其所在的网络N。(2)若N就是与此路由器直接相连的某个网络,则进行直接交......
  • 路由器功能------BFD (Bidirectional Forwarding Detection)双向转发检测
    原理:1.状态迁移BFD会话建立遵循三次握手,BFD有四种状态:Down:会话处于Down或者刚刚创建Init:已经能够与对端系统通信,本端希望使会话进入Up状态Up:会话已经建立AdminDown:会......
  • SpringCloud网关
    SpringCloud网关目前Cloud主流组件SpringCloudGateway目录一、Gateway简介1、官网2、是什么3、能干嘛4、有Zuul了怎么又出来了gateway5、Gateway特征6、Spring......
  • 集赞转发送大礼 有赞你就来
    集赞转发送大礼有赞你就来PostgreSQL考试认证中心集赞转发奖品大派送活动时间:1.21~2.14  集赞领奖将《PostgreSQL认证考试,2023春节特惠,开始啦!》活动转发至朋......
  • 配置nginx的上游服务器,实现将发送给nginx 的请求转发给网关
    首先需要在nginx的nginx.conf的http模块配置上游服务器  再将nginx中的conf.d中的任意一个配置文件中配置server模块  如果网关是通过host的方式进行匹配,需要......