当前位置:   article > 正文

Eureka简介及使用

eureka

1、Eureka的作用

Eureka的功能主要有以下几点:
1、注册服务信息
服务提供者启动时候向Eureka注册自己的信息,Eureka保存这些信息。
2、拉取服务
Eureka可以根据服务名称来查询保存的信息,拉取服务。
这里为了保证拉取的服务都是可用的,Eureka有一个检测心跳的功能,服务提供者每30s向EurekaServer发送心跳请求,报告健康状态。如果超时则会剔除掉这个服务的信息。
3、负载均衡
如果同一个服务被提供了多份,Eureka提供了几种负载均衡的策略来选择使用。
4、远程调用
整体如图所示:
Eureka作用

2、搭建EurekaServer

搭建EurekaServer很简单,三步即可:
1、创建项目,引入spring-cloud-starter-netflix-eureka-server的依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
	<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
  • 1
  • 2
  • 3
  • 4

2、编写启动类,添加@EnableEurekaServer注解

@SpringBootApplication
@EnableEurekaServer
public class EurekaApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaApplication.class, args);
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

3、添加application.yml文件,编写下面的配置:

server:
  port: 10086
spring:
  application:
    name: eurekaServer
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:10086/eureka
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

搭建完成之后打开路径即可查看如下图所示:
Eureka可视化界面

3、服务注册

服务注册分为两步:
1、引入spring-cloud-starter-netflix-eureka-client的依赖

<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
  • 1
  • 2
  • 3
  • 4

2、在application.yml文件,编写下面的配置:

eureka:
client:
  service-url:
    defaultZone: http://127.0.0.1:10086/eureka
  • 1
  • 2
  • 3
  • 4

这里我服务名称为userservice,启动之后,刷新Eureka界面查看如下:
在这里插入图片描述

4、服务调用

1、调用方同样需要使用第四步所描述,注册到Eureka中,注册并启动成功如下:
服务注册发现
2、修改OrderService的代码,修改访问的url路径,用服务名代替ip、端口:
这里RestTemplate的使用需要配置,具体不在此赘述

@Service
public class OrderService {

    @Autowired
    private OrderMapper orderMapper;

	// 这里RestTemplate的使用需要配置,具体不在此赘述
    @Autowired
    private RestTemplate restTemplate;

    public Order queryOrderById(Long orderId) {
        // 1.查询订单
        Order order = orderMapper.findById(orderId);

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

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

        order.setUser(user);

        // 4.返回
        return order;
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25

5、负载均衡详解

1、整体的流程如下:
负载均衡流程
2、Eureka的负载均衡策略:
负载均衡策略
3、负载均衡如何配置:
默认是轮询策略,如果要手动修改,如下所示:
在application.yml文件中,添加如下配置:

userservice: #指定被调用时候要使用此策略的服务名称
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 负载均衡规则
  • 1
  • 2
  • 3

6、小技巧
部署多台验证,可以使用idea自带的如下功能:
idea技巧
这里可以复制配置,之后如下:
切换端口号
如此可以启动多个相同服务用来验证负载均衡策略。
多个服务

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/代码探险家/article/detail/734658
推荐阅读
相关标签
  

闽ICP备14008679号