微服务之负载均衡 Feign和Ribbon的使用区别

一、 ribbon和feign都是客户端的提供负载均衡的工具,feign集合了ribbon

二、Ribbon和Feign都是用于调用其他服务的,不过方式不同。

1.启动类使用的注解不同,Ribbon用的是@RibbonClient,Feign用的是@EnableFeignClients。
2.服务的指定位置不同,Ribbon是在@RibbonClient注解上声明,Feign则是在定义抽象方法的接口中使用@FeignClient声明。
3.调用方式不同,Ribbon需要自己构建http请求,模拟http请求然后使用RestTemplate发送给其他服务,步骤相当繁琐。
Feign的优点
  Feign则是在Ribbon的基础上进行了一次改进,采用接口的方式,将需要调用的其他服务的方法定义成抽象方法即可,
 
  不需要自己构建http请求。不过要注意的是抽象方法的注解、方法签名要和提供服务的方法完全一致。

三、Feign整合了Ribbon和Hystrix,优点有以下几点:

1.feign本身里面就包含有了ribbon
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微服务之间的调用,如果需要进行负载均衡,可以使用RibbonFeign的结合。同样需要在Feign的配置中启用HTTPS支持,并且配置Ribbon负载均衡策略。具体步骤如下: 1. 引入RibbonFeign的依赖 ``` <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-ribbon</artifactId> </dependency> ``` 2. 配置FeignRibbon的HTTPS支持和负载均衡策略 ``` @Configuration public class FeignConfig { @Autowired private ObjectFactory<HttpMessageConverters> messageConverters; @Bean public Client feignClient() { return new Client.Default(getSSLSocketFactory(), null); } private SSLSocketFactory getSSLSocketFactory() { try { SSLContext sslContext = SSLContext.getInstance("TLS"); sslContext.init(null, new TrustManager[] { new X509TrustManager() { public void checkClientTrusted(X509Certificate[] x509Certificates, String s) throws CertificateException {} public void checkServerTrusted(X509Certificate[] x509Certificates, String s) throws CertificateException {} public X509Certificate[] getAcceptedIssuers() { return new X509Certificate[0]; } } }, new SecureRandom()); return sslContext.getSocketFactory(); } catch (Exception e) { throw new RuntimeException(e); } } @Bean public Decoder feignDecoder() { return new ResponseEntityDecoder(new SpringDecoder(messageConverters)); } @Bean public IRule ribbonRule() { return new RandomRule(); } @Bean public IPing ribbonPing() { return new PingUrl(false, "/health"); } @Bean public ServerList<Server> ribbonServerList() { return new ConfigurationBasedServerList(); } @Bean public OkHttpClient ribbonOkHttpClient() { return new OkHttpClient.Builder().sslSocketFactory(getSSLSocketFactory(), new X509TrustManager() { public void checkClientTrusted(X509Certificate[] x509Certificates, String s) throws CertificateException { } public void checkServerTrusted(X509Certificate[] x509Certificates, String s) throws CertificateException { } public X509Certificate[] getAcceptedIssuers() { return new X509Certificate[0]; } }).build(); } @Bean public RibbonClientConfiguration ribbonClientConfiguration(IClientConfig config, ILoadBalancer loadBalancer, ServerList<Server> serverList, ServerListFilter<Server> serverListFilter, IRule rule, IPing ping, RetryHandler retryHandler, OkHttpClient ribbonOkHttpClient) { return new RibbonClientConfiguration(config, loadBalancer, serverList, serverListFilter, rule, ping, retryHandler, ribbonOkHttpClient); } } ``` 其中,`ribbonRule`方法配置了Ribbon负载均衡策略,这里采用了随机策略,可以根据实际需求进行调整。 3. 在Feign的接口中使用`https`协议和负载均衡地址 ``` @FeignClient(name = "example", configuration = ExampleConfig.class) public interface ExampleClient { @GetMapping("/api") String get(); } ``` 其中,`configuration`参数指定了配置类,用于配置Ribbon相关的设置。 4. 在配置类中配置Ribbon的信息 ``` @Configuration public class ExampleConfig { @Bean public IRule ribbonRule() { return new RandomRule(); } @Bean public IPing ribbonPing() { return new PingUrl(false, "/health"); } @Bean public ServerList<Server> ribbonServerList(IClientConfig config) { return new ConfigurationBasedServerList(); } } ``` 其中,`ribbonRule`方法和`ribbonPing`方法分别配置了Ribbon负载均衡策略和健康检查的地址,`ribbonServerList`方法返回一个`ServerList`对象,用于配置可用的服务列表。 5. 在微服务使用Feign进行调用 ``` @RestController public class ExampleController { @Autowired private ExampleClient exampleClient; @GetMapping("/example") public String get() { return exampleClient.get(); } } ``` 这样就可以在微服务使用Feign调用HTTPS接口,并且进行负载均衡了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值