JavaWeb_SpringCloud微服务_Day1-eureka, ribbon, nacos

文章介绍了微服务的基本概念和技术对比,重点讲解了Eureka作为注册中心的原理和搭建,包括服务的注册与发现。接着讨论了Ribbon的负载均衡,特别是如何修改负载均衡策略和实现饥饿加载。此外,还提到了Nacos的快速入门,以及与Eureka的比较,强调了Nacos在负载均衡和服务状态检测上的特性。
摘要由CSDN通过智能技术生成

认识微服务

微服务技术对比

DubboSpringCloudSpringCloudAlibaba
注册中心zookeeper, RedisEureka, ConsulNacos, Eureka
服务远程调用Dubbo协议Feign(http协议)Dubbo, Feign
配置中心SpringCloudConfigSpringCloudConfig, Nacos
服务网关SpringCloudGateway, ZuulSpringCloudGateway, Zuul
服务监控和保护dubbo-admin, 功能弱HystrixSentinel

分布式服务架构案例

远程调用

  1. 注册RestTemplate
    /**
     * 创建RestTemplate并注入Spring容器
     * @return
     */
    @Bean
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
    
  2. 服务远程调用RestTemplate
    @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();
        // 2.2 发送http请求, 实现远程调用
        User user = restTemplate.getForObject(url, User.class);
        // 3 封装user到order
        order.setUser(user);
        // 4.返回
        return order;
    }
    

eureka注册中心

原理

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

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

搭建EurekaServer

  1. 引入eureka-server依赖
    <!-- eureka服务端 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
    </dependency>
    
  2. 添加@EnableEurekaServer注解
    @EnableEurekaServer
    @SpringBootApplication
    public class EurekaApplication {
        public static void main(String[] args) {
            SpringApplication.run(EurekaApplication.class, args);
        }
    }
    
  3. 在application.yml中配置eureka地址
    server:
      port: 10086
    spring:
      application:
        name: eurekaserver
    eureka:
      client:
        service-url:
          defaultZone: http://127.0.0.1:10086/eureka/
    

服务注册

  1. 引入eureka-client依赖
    <!-- eureka客户端 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
    
  2. 在application.yml中配置eureka地址
  3. 启动多个实例: 右键服务copy configuration, 在启动项vm option中修改端口号

服务发现

  1. 给RestTemplate添加@LoadBalanced注解, 负载均衡
    @LoadBalanced
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
    
  2. 用服务提供者的服务名称远程调用
    // String url = "http://localhost:8081/user/"+order.getUserId();
    String url = "http://userserver/user/"+order.getUserId();
    

Ribbon负载均衡

修改负载均衡

  1. 代码方式 (全体)
    /**
     * 更换负载均衡策略为随机
     * @return
     */
    @Bean
    public IRule randomRule()
    {
        return new RandomRule();
    }
    ```erer
    
  2. 配置文件方式 (只针对某个微服务)
    userserver: # 给某个微服务配置负载均衡规则,这里是userserver服务
      ribbon:
        NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 负载均衡规则 
    

饥饿加载

  • Ribbon默认是采用懒加载, 即第一次访问时才会创建LoadBalanceClient, 请求时间很长.
  • 饥饿加载在项目启动时创建, 降低第一次访问的耗时
    ribbon:
      eager-load: # 饥饿加载
        enabled: true
        clients: userserver # 指定服务
    

nacos注册中心

快速入门

  1. 父工程添加spring-cloud-alibaba管理依赖
    <!-- nacos的管理依赖 -->
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-alibaba-dependencies</artifactId>
        <version>2.2.5.RELEASE</version>
        <type>pom</type>
        <scope>import</scope>
    </dependency>
    
  2. nacos客户端依赖
    <!-- nacos客户端依赖 -->
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    </dependency>
    
  3. 配置文件
    spring:
      cloud:
        nacos:
            server-addr: localhost:8848 # nacos服务地址
    
  4. 集群配置
    spring:
      cloud:
        nacos:
            server-addr: localhost:8848 # nacos服务地址
            discovery:
                cluster-name: SH # 集群地址
    
  5. NacosRule负载均衡策略
    userserver: # 给某个微服务配置负载均衡规则,这里是userservice服务
        ribbon:
            # NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 负载均衡规则
            NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则
    
    • 优先选择同集群服务实例列表
    • 本地集群找不到提供者, 才去其他集群寻找, 并且会报警告
    • 确定了可用实例列表后, 再采用随机负载均衡挑选实例
  6. 命名空间
    spring:
      cloud:
        nacos:
          discovery:
            namespace: xxx # 命令空间
    
    • namespace用来做环境隔离
    • 每个namespace都有唯一id
    • 不同namespace下的服务不可见

eureka和nacos对比

  1. nacos非临时实例
    spring:
      cloud:
        nacos:
          discovery:
            ephemeral: false # 设置为非临时实例
    
  2. nacos与eureka的共同点
    • 都支持服务注册和服务拉取
    • 都支持服务提供者心跳方式做健康检测
  3. nacos与eureka的区别
    • nacos支持服务端主动检测提供者状态: 临时实例采用心跳模式, 非临时实例采用主动检测模式
    • 临时实例心跳不正常会被剔除, 非临时实例则不会被剔除
    • nacos支持服务列表变更的消息推送模式, 服务列表更新更及时
    • nacos集群默认采用ap方式(强调数据的可用性), 当集群中存在非临时实例时, 采用cp模式(强调数据的可靠性和一致性); eureka采用ap方式

来源

黑马程序员. SpringCloud微服务

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套针对Java开发的微服务框架,该框架提供了一系列功能和组件,用于帮助开发者更轻松地构建和管理微服务架构。 该框架的源码是指该框架的具体实现代码,通过阅读源码,开发者可以深入了解框架的设计思想和实现细节,有助于更好地理解和使用该框架。 javaweb_cloud_elevue_pro微服务框架旗舰版源码的特点主要包括以下几点: 1. 模块化设计:源码采用模块化设计,将整个框架拆分成多个独立的模块,每个模块负责不同的功能,有利于代码的组织和维护。 2. 弹性扩展:框架采用了微服务架构,可以很方便地进行系统扩展,支持动态添加和移除服务实例,以适应不同的业务需求。 3. 高可用性:框架提供了集群和负载均衡的支持,可以提高系统的可用性和性能。 4. 分布式事务管理:源码包含了分布式事务管理的实现,可以保证系统在多节点环境下的数据一致性。 5. 可靠消息传递:框架提供了消息队列和分布式任务调度的功能,可以确保消息的可靠传递和任务的可靠执行。 6. 监控和管理:框架提供了丰富的监控和管理功能,可以对系统进行实时监控和管理,方便开发者进行故障排查和性能调优。 总之,javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套成熟的微服务框架实现代码,通过研究源码,开发者可以更好地理解和使用该框架,提高开发效率和系统稳定性。 ### 回答2: javaweb_cloud_elevue_pro微服务框架是一款功能强大的微服务开发框架,是javaweb_cloud_elevue_pro产品家族中的旗舰版。 该框架的源码提供了一套完整的微服务解决方案,包含了丰富的功能模块和技术组件,可用于构建高性能、稳定可靠的分布式系统。 源码中包含了一系列核心组件,如服务注册与发现、负载均衡、熔断降级、分布式配置中心等,这些组件可以快速搭建起一个具有高可用性和可伸缩性的微服务架构。 此外,框架的源码还提供了一套易用的开发工具和开发规范,使开发者能够快速上手并高效地开发微服务应用。开发者可以根据自己的业务需求,选择合适的组件和模块进行使用,从而实现个性化的定制和扩展。 与其他微服务框架相比,javaweb_cloud_elevue_pro微服务框架的源码具有以下特点: 1. 高性能:框架使用了一系列优化的算法和技术,能够实现高效的请求处理和资源利用,保证系统的稳定和可靠。 2. 可扩展:源码提供了丰富的扩展接口和插件机制,开发者可以根据自己的需求进行个性化的扩展和定制。 3. 易用性:框架的源码结构清晰,文档详细,附带了示例和教程,使开发者能够快速理解和掌握框架的使用方法。 4. 社区支持:javaweb_cloud_elevue_pro框架拥有一个活跃的社区,开发者可以在社区中获取帮助、交流经验,并参与框架的改进和贡献。 总之,javaweb_cloud_elevue_pro微服务框架旗舰版源码提供了一个完整的微服务解决方案和一套易用的开发工具,可帮助开发者快速构建高性能、稳定可靠的分布式系统。它是微服务领域中的佼佼者,值得开发者深入研究和使用。 ### 回答3: javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套用于构建微服务架构的开源代码。该框架旨在提供一种简单、高效的方式来搭建和管理分布式系统。 该框架基于Java语言,采用了云计算、分布式计算和微服务架构的设计理念,提供了一套完整的解决方案来构建和管理分布式应用。 该框架具有以下特点: 1. 架构灵活:框架提供了一套灵活的架构设计,可以根据业务需求进行扩展和定制。 2. 模块化设计:框架采用模块化设计,各个微服务模块之间可以独立部署和调用,实现了高内聚、低耦合的分布式系统。 3. 高可用性:框架支持负载均衡、容错和故障恢复等机制,保证了系统的高可用性和容错性。 4. 弹性扩展:框架支持水平扩展,可以根据需求动态增加或减少服务实例,实现了系统的弹性扩展和负载均衡。 5. 服务治理:框架提供了服务注册与发现、负载均衡、熔断器等功能,实现了对微服务的有效治理和管理。 6. 高性能:框架采用了高性能、高并发的设计和优化策略,提升了系统的性能和扩展能力。 总体而言,javaweb_cloud_elevue_pro微服务框架旗舰版源码是一套功能强大、灵活可扩展的微服务架构代码,可帮助开发人员快速构建和管理分布式系统。无论是在企业级应用程序还是在云计算环境中,该框架都能提供优秀的支持,并具有较高的性能和可靠性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Y_cen

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

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

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

打赏作者

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

抵扣说明:

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

余额充值