springCloud(一)注册中心

 1.Eureka

要是user-service服务有多个,order-service该怎么调用?

这就需要用到 注册中心 了 。

1.1 搭建Eureka服务

1. pom引入依赖

<dependencies>
    <!--eureka服务端-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
    </dependency>
</dependencies>

2.yaml增加配置

eureka:
  client:
    service-url:  # eureka的地址信息
      defaultZone: http://127.0.0.1:10086/eureka

3.启动类加注解

@EnableEurekaServer
@SpringBootApplication
public class EurekaApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaApplication.class, args);
    }
}

1.2 服务注册

将user-service服务注册到Eukeka。

1.pom引依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

2.yml加配置

eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:10086/eureka

然后创建多个user-service实例

 1.3 服务发现

将order-service的逻辑修改:向eureka-server拉取user-service的信息,实现服务发现。

1.pom引依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

2.yml加配置

eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:10086/eureka

@Bean 

@LoadBalanced

public RestTemplate restTemplate() { return new RestTemplate(); }

// 2.1.url路径

//String url = "http://localhost:8081/user/" + order.getUserId();

String url = "http://userservice/user/" + order.getUserId();

// 2.2.发送http请求,实现远程调用

User user = restTemplate.getForObject(url, User.class);

上面我们说到了@LoadBlanced 负载均衡。

SpringCloud底层利用了一个Ribbon组件来实现。

1.4Ribbon

为什么我们可以通过 String url = "http://userservice/user/" + order.getUserId();

就能获得userservice的ip和端口呢?

源码中可以发现是 LoadBlanceInterceptor ,会对RestTemplate的请求进行拦截,然后从Eureka获取服务列表,然后利用负载均衡算法获取ip和端口。

1.4.1LoadBalancerIntercepor

  • request.getURI():获取请求uri,本例中就是 http://user-service/user/8

  • originalUri.getHost():获取uri路径的主机名,其实就是服务id,user-service

  • this.loadBalancer.execute():处理服务id,和用户请求。

这里的this.loadBalancerLoadBalancerClient类型,我们继续跟入。

1.4.2LoadBalancerClient

  • getLoadBalancer(serviceId):根据服务id获取ILoadBalancer,而ILoadBalancer会拿着服务id去eureka中获取服务列表并保存起来。

  • getServer(loadBalancer):利用内置的负载均衡算法,从服务列表中选择一个。本例中,可以看到获取了8082端口的服务  

1.4.3负载均衡策略IRule

RibbonLoadBalancerClient
public <T> T execute(String serviceId, LoadBalancerRequest<T> request, Object hint) throws IOException {
    ILoadBalancer loadBalancer = this.getLoadBalancer(serviceId);
    Server server = this.getServer(loadBalancer, hint);
......
protected Server getServer(ILoadBalancer loadBalancer, Object hint) {
    return loadBalancer == null ? null : loadBalancer.chooseServer(hint != null ? hint : "default");
}
BaseLoadBalancer
protected IRule rule;
private static final IRule DEFAULT_RULE = new RoundRobinRule();

public Server chooseServer(Object key) {
......
    if (this.rule == null) {
        return null;
    } else {
        try {
            return this.rule.choose(key);
        } catch (Exception var3) {
            logger.warn("LoadBalancer [{}]:  Error choosing server for key {}", new Object[]{this.name, key, var3});
            return null;
        }
    }
}

 IRule实现类

内置负载均衡规则类规则描述
RoundRobinRule简单轮询服务列表来选择服务器。它是Ribbon默认的负载均衡规则。
AvailabilityFilteringRule对以下两种服务器进行忽略: (1)在默认情况下,这台服务器如果3次连接失败,这台服务器就会被设置为“短路”状态。短路状态将持续30秒,如果再次连接失败,短路的持续时间就会几何级地增加。 (2)并发数过高的服务器。如果一个服务器的并发连接数过高,配置了AvailabilityFilteringRule规则的客户端也会将其忽略。并发连接数的上限,可以由客户端的<clientName>.<clientConfigNameSpace>.ActiveConnectionsLimit属性进行配置。
WeightedResponseTimeRule为每一个服务器赋予一个权重值。服务器响应时间越长,这个服务器的权重就越小。这个规则会随机选择服务器,这个权重值会影响服务器的选择。
ZoneAvoidanceRule以区域可用的服务器为基础进行服务器的选择。使用Zone对服务器进行分类,这个Zone可以理解为一个机房、一个机架等。而后再对Zone内的多个服务做轮询。
BestAvailableRule忽略那些短路的服务器,并选择并发数较低的服务器。
RandomRule随机选择一个可用的服务器。
RetryRule重试机制的选择逻辑

 默认是ZoneAvoidanceRule,一种轮询机制。

1.4.4自定义负载均衡策略

1.yml

userservice: # 给某个微服务配置负载均衡规则,这里是userservice服务
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 负载均衡规则 

2.代码

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

2.Nacos

Nacos是SpringCloudAlibaba的组件。和Eureka没啥太大区别,Nacos能支持一些比较复杂的集群部署。

2.1 服务注册到nacos

父pom(cloud-demo )

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-alibaba-dependencies</artifactId>
    <version>2.2.6.RELEASE</version>
    <type>pom</type>
    <scope>import</scope>
</dependency>

子pom(user-service和order-service ) 

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

yml 配nacos地址

spring:
  cloud:
    nacos:
      server-addr: localhost:8848

2.2 nacos集群

一个服务可以有多个实例

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

NEUMaple

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值