• (二)Ribbon(负载均衡的客户端)+Rest


    前面讲了服务的注册与发现,微服务项目会把项目的各个业务需求划分成几个模块来单独提供服务,各服务间的调用都是采用Http Restful来实现,但是在SpringClound中服务间的调用有两种方式:一种是ribbon+ restTemplate;另一种是feign;

     Ribbon:在SpringClound中是作为一个负载均衡的客户端,控制访问入口,定制访问策略等功能; Feign组件同时也是集成了ribbon的

    打开前面准备的服务client

    在Idea里,新建项目,选择Spring initializer.

    勾选组件

    下面的pom

    	<dependencies>
    		<dependency>
    			<groupId>org.springframework.cloud</groupId>
    			<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    			<version>1.4.4.RELEASE</version>
    		</dependency>
    		<dependency>
    			<groupId>org.springframework.cloud</groupId>
    			<artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-web</artifactId>
    		</dependency>
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-test</artifactId>
    			<scope>test</scope>
    		</dependency>
    	</dependencies>

      

    配置properties文件参数;

    #服务端口
    server.port=8885
    #注册服务中心地址
    eureka.client.service-url.defaultZone=http://localhost:8882/eureka/
    #注册服务端name
    spring.application.name=service-ribbon
    #调用连接时间
    eureka.client.eureka-server-read-timeout-seconds=6000
    #调用连接时间
    eureka.client.eureka-server-connect-timeout-seconds=6000
    hystrix.metrics.polling-interval-ms=6000

      

    在启动类上添加注解@EnableDiscoveryClient

    @EnableDiscoveryClient
    @SpringBootApplication
    public class SpringCloundRibbonExampleApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(SpringCloundRibbonExampleApplication.class, args);
        }
    
        /**
         * ioc注入一个bean: restTemplate;并通过@LoadBalanced注解表明这个restRemplate开启负载均衡的功能
         *
         * @return
         */
        @Bean
        @LoadBalanced
        RestTemplate restTemplate() {
            return new RestTemplate();
        }
    }
    

      

    创建conroller、service

    @RestController
    public class HelloController {
    
        @Autowired
        IHelloService helloService;
    
        @RequestMapping(value = "/index")
        public String index() {
            return helloService.index();
        }
    
    }

      

    @Service
    public class HelloServiceImpl implements IHelloService {
    
        @Autowired
        RestTemplate restTemplate;
    
        @Override
        public String index() {
            return restTemplate.getForObject("http://SERVICE-HELLO/index",String.class);
        }
    }
    

      

    启动项目,然后再看服务中心,已经注册成功

    回到浏览器,输入http://localhost:8885/index

    刷新:

     

    Ribbon本身提供了下面几种负载均衡策略:

    核心组件IRule

    • RoundRobinRule: 轮询策略,Ribbon以轮询的方式选择服务器,这个是默认值。所以示例中所启动的两个服务会被循环访问;
    • RandomRule: 随机选择,也就是说Ribbon会随机从服务器列表中选择一个进行访问;
    • BestAvailableRule: 最大可用策略,即先过滤出故障服务器后,选择一个当前并发请求数最小的;
    • WeightedResponseTimeRule: 带有加权的轮询策略,对各个服务器响应时间进行加权处理,然后在采用轮询的方式来获取相应的服务器;
    • AvailabilityFilteringRule: 可用过滤策略,先过滤出故障的或并发请求大于阈值一部分服务实例,然后再以线性轮询的方式从过滤后的实例清单中选出一个;
    • ZoneAvoidanceRule: 区域感知策略,先使用主过滤条件(区域负载器,选择最优区域)对所有实例过滤并返回过滤后的实例清单,依次使用次过滤条件列表中的过滤条件对主过滤条件的结果进行过滤,判断最小过滤数(默认1)和最小过滤百分比(默认0),最后对满足条件的服务器则使用RoundRobinRule(轮询方式)选择一个服务器实例。
    @Configuration
    public class RibbonConfiguration {

    @Bean
    public IRule ribbonRule() {
    return new RandomRule();
    }
    }

    我们可以通过继承ClientConfigEnabledRoundRobinRule,来实现自己负载均衡策略。
  • 相关阅读:
    Sametime SDK
    final,finally和 finalize的区别
    静态工厂方法
    LinkedTransferQueue原理
    SynchronousQueue和LinkedBlockingQueue区别
    SynchronousQueue中TransferStack原理详解
    SynchronousQueue中TransferQueue原理详解
    jdk Queue
    netty NioEventLoopGroup 分析
    Netty Server 启动时序图
  • 原文地址:https://www.cnblogs.com/skyLogin/p/10002662.html
Copyright © 2020-2023  润新知