feign组件的功能与实现原理

springcloud是使用rest协议进行信息传递,同时在netfix的项目中实现了一个feign组件来简化编写代码的麻烦

feign的使用方式如下

1 定义一个接口interface
public interface helloclient(){
@RequestLine("GET /hello") //定义一个接口并查找服务中的hello方法
public String hello(); //本地接口定义一个hello的方法
@RequestLine("GET  /person/{id}") 
public Person getPerson(I@Param("id")  Interger id);//本地接口定义一个获取Person类的方法(预先实例化一个person类)
}
2 在实现类中调用feign连接服务端
helloclient client = Feign.builder().target (helloclient.class,"http://locahost:8080"); //使用接口定义实现一个远程服务上的服务类
String result = client.hello();//实现服务类上的服务方法


HelloClient client = Feign.builder().decoder(new GsonDecoder()).target(HelloClient.class,"http://localhost:8080");
//中间使用GsonDecoder进行Gson解码
Person p =client.getPerson(2);
其实feign就是从request中获取数据,处理再回传的过程,但是这个过程很重要,基本占据编码过程中的三分之一;

而feign是如何实现的了?

请看如下代码:

Webclient client = webclient.create("http://");//通过rest服务连接服务提供端
Response response = client.get();//获得服务端的返回
InputStream ent = (InputStream)response.getEntity();//将返回元素解析为流
String content = IOUtils.readStringFormStream(ent);//获取返回
return content;

以上是http原始实现过程,feign的实现实际是截取第一段获取到请求后,包装为自己的请求,

处理完后再将输出改写城http的原始输出进行回传,也就是在http的传输外面包了一层而已,

虽然原理不复杂,但是在实际编码中,确实省却了很多复杂繁冗的过程

 

你可能感兴趣的:(开发学习)