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

2、搭建EurekaServer
搭建EurekaServer很简单,三步即可:
1、创建项目,引入spring-cloud-starter-netflix-eureka-server的依赖
org.springframework.cloud spring-cloud-starter-netflix-eureka-server
2、编写启动类,添加@EnableEurekaServer注解
@SpringBootApplication
@EnableEurekaServer
public class EurekaApplication {public static void main(String[] args) {SpringApplication.run(EurekaApplication.class, args);}
}
3、添加application.yml文件,编写下面的配置:
server:port: 10086
spring:application:name: eurekaServer
eureka:client:service-url:defaultZone: http://127.0.0.1:10086/eureka
搭建完成之后打开路径即可查看如下图所示:

3、服务注册
服务注册分为两步:
1、引入spring-cloud-starter-netflix-eureka-client的依赖
<dependency><groupId>org.springframework.cloudgroupId><artifactId>spring-cloud-starter-netflix-eureka-clientartifactId>
dependency>
2、在application.yml文件,编写下面的配置:
eureka:
client:service-url:defaultZone: http://127.0.0.1:10086/eureka
这里我服务名称为userservice,启动之后,刷新Eureka界面查看如下:

4、服务调用
1、调用方同样需要使用第四步所描述,注册到Eureka中,注册并启动成功如下:

2、修改OrderService的代码,修改访问的url路径,用服务名代替ip、端口:
这里RestTemplate的使用需要配置,具体不在此赘述
@Service
public class OrderService {@Autowiredprivate OrderMapper orderMapper;// 这里RestTemplate的使用需要配置,具体不在此赘述@Autowiredprivate 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;}
}
5、负载均衡详解
1、整体的流程如下:

2、Eureka的负载均衡策略:

3、负载均衡如何配置:
默认是轮询策略,如果要手动修改,如下所示:
在application.yml文件中,添加如下配置:
userservice: #指定被调用时候要使用此策略的服务名称ribbon:NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 负载均衡规则
6、小技巧
部署多台验证,可以使用idea自带的如下功能:

这里可以复制配置,之后如下:

如此可以启动多个相同服务用来验证负载均衡策略。

本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
