SpringCloud:ribbon项目搭建(Gradle项目)

Posted bensonlim

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringCloud:ribbon项目搭建(Gradle项目)相关的知识,希望对你有一定的参考价值。

我们在前面创建了EreukaClient ,注解为@EnableEurekaClient

现在我们将这个client引入ribbon变成负载均衡,首先把它变为可发现的,@EnableDiscoveryClient

关于两者的区别:

SpringCLoud中的“Discovery Service”有多种实现,比如:eureka, consul, zookeeper。

1,@EnableDiscoveryClient注解是基于spring-cloud-commons依赖,并且在classpath中实现; 

2,@EnableEurekaClient注解是基于spring-cloud-netflix依赖,只能为eureka作用;

如果你的classpath中添加了eureka,则它们的作用是一样的。

 

其实用更简单的话来说,就是如果选用的注册中心是eureka,那么就推荐@EnableEurekaClient,如果是其他的注册中心,那么推荐使用@EnableDiscoveryClient。

 

为了让它变成负载均衡,先创建一个兄弟服务。两者端口号,分别为8762和8763,并拥有同一个应用名称:cloud-service。

eureka:
    client:
        serviceUrl:
            defaultZone: http://localhost:8761/eureka/
server:
    port: 8762
spring:
    application:
        name: cloud-service

两者都提供一个请求接口,返回的字符串显示各自的端口号。

@RestController
	@RequestMapping(value = "/ribbon")
	public class RibbonTestApi {

		/**
		 * 获取博客名称API
		 *
		 * @return 相关信息
		 */
		@RequestMapping(value = "name", method = RequestMethod.GET)
		public String getMyBlogNameApi() {
			return "111111111111111"+"该服务器端口号:8762"; // or 8763
		}
	}

  

Another Client:8092

 接下来创建一个服务端,调用这个/ribbon/name请求。

@SpringBootApplication
@EnableDiscoveryClient
public class CloudRibbonApplication {

	private static final Logger logger  = LogManager.getLogger(CloudRibbonApplication.class.getName());

	public static void main(String[] args) {
		SpringApplication.run(CloudRibbonApplication.class, args);
	}


	/**
	 * Spring提供的用于访问Rest服务的客户端
	 * @return
	 */
	@Bean
	@LoadBalanced
	RestTemplate restTemplate() {
		logger.info("LoadBalanced restTemplate from ribbon client");
		return new RestTemplate();
	}
}

  

创建一个TestRibbonApi类:

@RestController
@RequestMapping(value = "/test")
public class TestRibbonApi {
    /**
     * 注入RestTemplate
     */
    @Autowired
    RestTemplate restTemplate;

    @RequestMapping(value = "/name" ,method = RequestMethod.GET)
    public String testGetNameOfBlog(){
        String url="http://CLOUD-SERVICE/ribbon/name";
        return restTemplate.getForObject(url,String.class);
    }
}

  

 将它们分别启动可以看到:

 技术分享图片

访问8092这台服务器的端口可以看到

技术分享图片

刷新一下:

技术分享图片

1.第一次使用服务器名调用。 

http://CLOUD-SERVICE/ribbon/name

2.ribbon没有特殊的gradle或maven包引入。没有spring-cloud-starter-ribbon这样子的引入,和普通client一样。重点全在 RestTemplate类 和 @LoadBalanced

RestTemplate是Spring提供的用于访问Rest服务的客户端。RestTemplate提供了多种便捷访问远程Http服务的方法,能够大大提高客户端的编写效率。
调用RestTemplate的默认构造函数,RestTemplate对象在底层通过使用java.net包下的实现创建HTTP 请求,可以通过使用ClientHttpRequestFactory指定不同的HTTP请求方式。

ClientHttpRequestFactory接口主要提供了两种实现方式,一种是SimpleClientHttpRequestFactory,
使用J2SE提供的方式(既java.net包提供的方式)创建底层的Http请求连接,
还有一种方式是使用HttpComponentsClientHttpRequestFactory方式,
底层使用HttpClient访问远程的Http服务,使用HttpClient可以配置连接池和证书等信息。

@LoadBalanced 注解加在RestTemplate上面,这个注解会自动构造LoadBalancerClient接口的实现类并注册到Spring容器中。








以上是关于SpringCloud:ribbon项目搭建(Gradle项目)的主要内容,如果未能解决你的问题,请参考以下文章

SpringCloud Ribbon 部分源码

SpringCloud--Ribbon--源码解析--Ribbon入口实现

springCloud:Ribbon实现客户端侧负载均衡-自定义Ribbon配置

springCloud:Ribbon实现客户端侧负载均衡-消费者整合Ribbon

SpringCloud---Ribbon服务调用,源码分析

SpringCloud Ribbon组成和负载均衡规则