前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >微服务:Eureka原理实践:@EnableEurekaServer、@LoadBalanced

微服务:Eureka原理实践:@EnableEurekaServer、@LoadBalanced

作者头像
.29.
发布2024-04-25 20:22:33
750
发布2024-04-25 20:22:33
举报
文章被收录于专栏:个人技术博客个人技术博客
微服务:Eureka原理实践:@EnableEurekaServer、@LoadBalanced
  • 一、Eureka架构概述
  • Eureka的作用
  • 三、搭建EurekaServer(服务端)
    • 1.创建项目,引入依赖
    • 2.编写启动类
    • 3.添加配置信息
    • 4.访问Eureka管理界面
  • 四、搭建EurekaClient(客户端)
    • 1.信息注册:Provider(服务提供者)
      • ①引入依赖
      • ②添加配置信息
    • 2.信息注册:Consumer(服务消费者)
      • ①引入依赖
      • ②添加配置信息
  • 五、Eureka服务拉取(服务发现)
  • 六、小结

一、Eureka架构概述

Eureka架构中,有两类微服务角色:

  • EurekaServer —— 服务端,注册中心。
    • 记录服务;
    • 心跳监控;
  • EurekaClient —— 客户端。
    • Provider:服务提供者。
      • 注册自己的信息到EurekaServer;
      • 每隔30秒向EurekaServer发送心跳请求;
    • Consumer:服务消费者。
      • 根据服务名称从EurekaServer拉取服务列表。
      • 基于服务列表做负载均衡,选中一个微服务后发起远程调用。

Eureka的作用

  • 服务消费者该如何获取服务提供者的具体信息?
    • 服务提供者会在启动时向Erueka注册自己的信息。
    • Erueka保存这些注册的信息。
    • 服务消费者根据服务名称,向Erueka拉取服务提供者的信息。
  • 如果有多个服务提供者,服务消费者该如何选择?
    • 服务消费者利用负载均衡算法,从服务列表中挑选一个。
  • 服务消费者如何感知服务提供者的健康状态?
    • 服务提供者会每隔30秒向EurekaServer发送心跳请求,报告健康状态。
    • Erueka会更新记录服务列表信息,心跳不正常会被剔除。
    • Erueka更新服务列表后,服务消费者就可以拉取到最新的信息。

三、搭建EurekaServer(服务端)

1.创建项目,引入依赖

创建项目,pom.xml文件中导入spring-cloud-starter-netflix-eureka-server依赖。

代码语言:javascript
复制
    <dependencies>
        <!--eureka服务端-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
    </dependencies>

2.编写启动类

编写SpringBoot工程的启动类,添加上注解@EnableEurekaServer,以此开启Eureka服务。

代码语言:javascript
复制
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

@EnableEurekaServer//重点,开启Eureka服务。
@SpringBootApplication
public class EurekaApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaApplication.class, args);
    }
}

3.添加配置信息

在SpringBoot工程的application.yml配置文件中,添加以下配置信息。

代码语言:javascript
复制
server:
  port: 10086 # 服务端口
spring:
  application:
    name: eurekaserver # eureka的服务名称
eureka:
  client:
    service-url:  # eureka的地址信息
      defaultZone: http://127.0.0.1:10086/eureka

4.访问Eureka管理界面

浏览器访问我们上一步配置的eureka的地址信息链接:http://127.0.0.1:10086/eureka,就能打开spring Eureka管理界面,查看EurekaServer的一些基本信息。

在这里插入图片描述
在这里插入图片描述

四、搭建EurekaClient(客户端)

1.信息注册:Provider(服务提供者)
①引入依赖

在服务提供者微服务的pom.xml文件中引入spring-cloud-starter-netflix-eureka-client依赖

代码语言:javascript
复制
        <!--eureka客户端依赖-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
②添加配置信息

在服务提供者微服务的SpringBoot工程配置文件application.yml配置文件中,添加下述配置信息。

代码语言:javascript
复制
spring:
  application:  #eureka客户端 —— 服务提供者Provider的服务名称
    name: userservice

eureka:
  client:
    service-url:  # eureka的地址信息
      defaultZone: http://127.0.0.1:10086/eureka
2.信息注册:Consumer(服务消费者)
①引入依赖

在服务消费者微服务的pom.xml文件中引入spring-cloud-starter-netflix-eureka-client依赖

代码语言:javascript
复制
        <!--eureka客户端依赖-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
②添加配置信息

在服务消费者微服务的SpringBoot工程配置文件application.yml配置文件中,添加下述配置信息。

代码语言:javascript
复制
spring:
  application:  #eureka客户端 —— 服务消费者Consumer的服务名称
      name: orderservice

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

服务消费者与服务提供者的信息注册步骤基本一致… 即:无论是消费者还是提供者,只要引入eureka-client依赖,配置了eureka地址信息后,都可以完成注册。


五、Eureka服务拉取(服务发现)

  • 服务拉取:基于服务名称,获取服务列表,然后对服务列表做负载均衡,挑选一个服务进行使用。
  1. 修改服务消费者(order-service)的业务层组件,即:远程调用功能的组件代码中,修改访问的url地址,使用服务名来代替ip、端口
代码语言:javascript
复制
@Service
public class OrderService {

    @Autowired
    private OrderMapper orderMapper;

    @Autowired
    private RestTemplate restTemplate;

    public Order queryOrderById(Long orderId) {
        // 1.查询订单
        Order order = orderMapper.findById(orderId);
        // 2.利用RestTemplate发起http请求,查询用户
        // 2.1.url路径
        //String url = "http://localhost:8081/user/" + order.getUserId();
        //使用服务提供者的服务名userservice代替ip、端口:
        String url = "http://userservice/user/" + order.getUserId();
        // 2.2.发送http请求,实现远程调用
        User user = restTemplate.getForObject(url, User.class);
        // 3.封装user到Order
        order.setUser(user);
        // 4.返回
        return order;
    }
}

重点在这里

代码语言:javascript
复制
        // 2.1.url路径
        //String url = "http://localhost:8081/user/" + order.getUserId();
        //使用服务提供者的服务名userservice代替ip、端口:
        String url = "http://userservice/user/" + order.getUserId();
  1. 在服务消费者(order-service)的启动类OrderApplication中,为Spring容器中的RestTemplate实例使用负载均衡算法,即:添加注解@LoadBalanced
代码语言:javascript
复制
@MapperScan("cn.itcast.order.mapper")
@SpringBootApplication
@EnableFeignClients(clients = UserClient.class,defaultConfiguration = DefaultFeignConfiguration.class)
public class OrderApplication {

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

    /**
     * 创建RestTemplate并注入Spring容器
     */
    @Bean
    @LoadBalanced//@LoadBalanced注解,实现负载均衡
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }

}
  1. 完成上述两部,就能做到根据服务名称从EurekaServer拉取服务列表,并做负载均衡算法,从列表中挑选一个服务使用!

六、小结

  • @EnableEurekaServer —— 使用在SpringBoot工程启动类上,可开启Eureka服务。
  • @LoadBalanced —— 使用在@Bean方法注入的RestTemplate实例上,用于实现负载均衡算法。

在这里插入图片描述
在这里插入图片描述
本文参与?腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2024-04-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客?前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 微服务:Eureka原理实践:@EnableEurekaServer、@LoadBalanced
  • 一、Eureka架构概述
  • Eureka的作用
  • 三、搭建EurekaServer(服务端)
    • 1.创建项目,引入依赖
      • 2.编写启动类
        • 3.添加配置信息
          • 4.访问Eureka管理界面
          • 四、搭建EurekaClient(客户端)
            • 1.信息注册:Provider(服务提供者)
              • ①引入依赖
              • ②添加配置信息
            • 2.信息注册:Consumer(服务消费者)
              • ①引入依赖
              • ②添加配置信息
          • 五、Eureka服务拉取(服务发现)
          • 六、小结
          相关产品与服务
          负载均衡
          负载均衡(Cloud Load Balancer,CLB)提供安全快捷的流量分发服务,访问流量经由 CLB 可以自动分配到云中的多台后端服务器上,扩展系统的服务能力并消除单点故障。负载均衡支持亿级连接和千万级并发,可轻松应对大流量访问,满足业务需求。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
          http://www.vxiaotou.com