Ribbon

Ribbon 是 Netflix开源的基于HTTP和TCP等协议负载均衡组件

Ribbon 可以用来做客户端负载均衡,调用注册中心的服务

Ribbon的使用需要代码里手动调用目标服务,请参考官方示例:https://github.com/Netflix/ribbon

Feign

Feign是Spring Cloud组件中的一个轻量级RESTfulHTTP服务客户端

Feign内置了Ribbon,用来做客户端负载均衡,去调用服务注册中心的服务。

Feign的使用方式是:使用Feign的注解定义接口,调用这个接口,就可以调用服务注册中心的服务

Feign支持的注解和用法请参考官方文档:https://github.com/OpenFeign/feign

Feign本身不支持Spring MVC的注解,它有一套自己的注解

OpenFeign

OpenFeign是Spring Cloud 在Feign的基础上支持了Spring MVC的注解,如@RequesMapping等等。
OpenFeign的@FeignClient可以解析SpringMVC的@RequestMapping注解下的接口,
并通过动态代理的方式产生实现类,实现类中做负载均衡并调用其他服务。

// user-api 子项目
public interface SysUserResource {
	@GetMapping("/test")
	Object getUser();
}

// user-client 子项目 , 依赖了user-api 子项目
// 其他业务模块可以直接依赖此模块,通过调用接口即可完成服务的远程调用,open-feign会对此类做动态代理
// name = "user-center" 是被调用的服务实例名称
@FeignClient(name = "user-center")
public interface SysUserResourceClient extends SysUserResource {
}

// user-impl 子项目
@RestController
public class SysUserResourceImpl implements SysUserResource  {
	@Override
	Object getUser(){
		// do something
	}
}

// role-impl 子项目 , 依赖了 user-client 子项目
@RestController
public class SysRoleResourceImpl implements SysRoleResource  {
	@Resource
	private SysUserResource  sysUserResource;
	
	@Override
	Object test(){
		sysUserResource.getUser();
	}
}

在这里插入图片描述

需要注意,@RequesMapping不能在类名上与@FeignClient同时使用

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐