欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

使用Spring Cloud Feign远程调用的方法示例

程序员文章站 2024-02-26 20:10:58
在spring cloud netflix栈中,各个微服务都是以http接口的形式暴露自身服务的,因此在调用远程服务时就必须使用http客户端。我们可以使用jdk原生的ur...

在spring cloud netflix栈中,各个微服务都是以http接口的形式暴露自身服务的,因此在调用远程服务时就必须使用http客户端。我们可以使用jdk原生的urlconnection、apache的http client、netty的异步http client, spring的resttemplate。但是,用起来最方便、最优雅的还是要属feign了。

feign简介

feign是一个声明式的web服务客户端,使用feign可使得web服务客户端的写入更加方便。
它具有可插拔注释支持,包括feign注解和jax-rs注解、feign还支持可插拔编码器和解码器、spring cloud增加了对spring mvc注释的支持,并httpmessageconverters在spring web中使用了默认使用的相同方式。spring cloud集成了ribbon和eureka,在使用feign时提供负载平衡的http客户端。

spring cloud feign简介参考:

根据专家学者提供的账号密码,要在用户表注册一个专家学者账号(用户和专家学者不同的数据库)

在usercontorller.java写一个方法:注册专家学者账号

/**
 * 专家学者注册
 * 
 * @param username
 * @param password
 * @return
 */
 @apioperation(value = "专家学者注册")
 @requestmapping(value = "/registexpert", method = requestmethod.post)
 public long registexpert(@requestparam("username") string username, @requestparam("password") string password) {
 user user = new user();
 user.setusername(username);
 user.setpassword(password);
 userservice.insertselective(user);
 long userid = user.getuserid();
 return userid;
 }

userclient.java(这里的接口和要远程调用的controller方法声明一样(此处是usercontroller.java),可直接复制过来,如下所示)

package com.lgsc.cjbd.expert.remote.client;
 
import org.springframework.cloud.netflix.feign.feignclient;
import org.springframework.web.bind.annotation.requestmapping;
import org.springframework.web.bind.annotation.requestmethod;
import org.springframework.web.bind.annotation.requestparam;
 
import com.lgsc.cjbd.vo.response;
 
@feignclient(name = "cjbd-user", fallback = userclientfallback.class)
public interface userclient {
 
 /**
 * 注册专家学者
 */
 @requestmapping(value = "/user/user/registexpert", method = requestmethod.post)
 long registexpert(@requestparam("username") string username, @requestparam("password") string password);
}

以及失败回调用userclientfallback.java

package com.lgsc.cjbd.expert.remote.client;
 
import org.apache.logging.log4j.logmanager;
import org.apache.logging.log4j.logger;
import org.springframework.stereotype.component;
 
import com.lgsc.cjbd.vo.response;
 
/**
 * 失败回调
 * 
 * @author yeqj
 */
@component
public class userclientfallback implements userclient {
 private static logger log = logmanager.getlogger(userclientfallback.class);
 
 @override
 public long registexpert(string username, string password, string realname) {
 log.error("远程调用失败,注册专家学者失败,参数:[username=" + username + ",password=" + password + "]");
 return 0;
 }
}

之后再专家学者service层传递专家学者用户名和密码过去,在用户表新增专家学者注册记录

userclient.registexpert(username, password);

即可完成远程调用

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。