赞
踩
Spring Cloud是一个用于构建分布式系统的开源框架。它为开发人员提供了一套丰富的工具和库,用于快速构建云原生应用程序以及实现微服务架构。
Spring Cloud基于Spring Framework,通过各种可插拔的模块和组件,提供了配置管理、服务发现、服务网关、负载均衡、断路器、消息总线等功能,使得构建和管理大规模分布式系统变得更加容易。
优点:
简化分布式系统开发:Spring Cloud提供了一套完整的工具和组件,能够快速构建和管理分布式系统。它提供了集成式的解决方案,使开发人员能够专注于业务逻辑,而不必关注底层的分布式系统架构和复杂性。
微服务支持:Spring Cloud为微服务架构提供了丰富的支持,包括服务注册与发现、负载均衡、断路器、配置管理等。它提供了一种轻量级且灵活的方式来构建和管理微服务,在实现业务需求的同时提供了高可用性、弹性和可扩展性。
可插拔组件:Spring Cloud的各个组件都是可插拔的,可以根据需求进行选择和集成。它与Spring生态系统紧密结合,充分利用了Spring的核心功能和特性,如依赖注入、面向切面编程等。
社区活跃:Spring Cloud拥有一个活跃的社区,提供了大量的文档、教程和示例代码。开发人员可以从社区获取支持和解决方案,也可以积极参与社区的讨论和贡献,推动框架的发展和改进。
缺点:
配置复杂:由于分布式系统的复杂性,使用Spring Cloud构建和管理分布式系统时,配置可能会变得复杂。需要仔细设计和管理各个组件之间的依赖关系和配置项,以确保系统的正常运行。
学习曲线较陡:Spring Cloud是一个庞大而复杂的框架,对于初学者来说,学习曲线可能较陡峭。需要掌握Spring的核心概念和基础知识,并熟悉Spring Boot和各个Spring Cloud组件的使用方法。
运维压力:构建和运维分布式系统需要更多的工作和资源,包括服务部署、容器编排、监控和调试等。这可能增加了运维的复杂性和成本。
微服务架构和单体应用架构是两种不同的软件架构模式,它们有以下区别:
架构复杂性:在单体应用架构中,所有的功能和模块都集中在一个单一的应用程序中,而在微服务架构中,应用程序被拆分成多个小而自治的服务。微服务架构的复杂性更高,因为需要设计和管理多个独立的服务,并确保它们之间的协作和通信。
可伸缩性:微服务架构可以更容易地实现水平扩展,因为每个微服务可以独立部署和扩展。而在单体应用架构中,整个应用程序需要作为一个整体进行扩展,可能会面临一些限制。
独立部署和灵活性:微服务架构允许每个服务独立部署,并使用适合其需求的技术栈和语言。这为团队带来了更大的灵活性和自主权。而在单体应用架构中,整个应用程序需要作为一个整体进行部署和升级。
可维护性:微服务架构在某种程度上提高了可维护性。由于每个微服务都是相对较小的,易于理解和维护,更容易进行快速修复和功能更新。然而,在单体应用架构中,较大和复杂的应用程序可能更难以维护。
团队组织和协作:微服务架构通常可以更容易地实现团队的分工和独立开发。不同的团队可以独立负责不同的微服务,并与其他团队合作。这样可以提高开发效率和灵活性。单体应用架构下的开发可能要求更紧密的协作和代码管理。
服务间通信和网络延迟:在微服务架构中,服务之间的通信通过网络进行,可能会引入一定的网络延迟。而在单体应用架构中,模块间的通信是通过函数调用等方式完成的,通常不会受到网络延迟的影响。
综上所述,微服务架构和单体应用架构在架构复杂性、可伸缩性、独立部署、灵活性、可维护性以及团队组织和协作等方面存在显著的区别。选择哪种架构取决于具体的需求、项目规模和团队组织等因素。
由上图可知:微服务是N个项目打成N个包部署到N台服务器
将传统单体应用架构拆分为多微服务项目,每个微服务可以相互通信,部署到各自的服务器
- package com.blb.common.entity;
-
- import com.baomidou.mybatisplus.annotation.TableField;
- import lombok.AllArgsConstructor;
- import lombok.Data;
- import lombok.NoArgsConstructor;
-
- import java.util.Date;
-
- @Data
- @AllArgsConstructor
- @NoArgsConstructor
- public class SysOrder {
-
- private long id;
- private long productId;
- private long count;
- private long userId;
- private Date time;
- @TableField(exist = false)
- private SysProduct product;
-
- }

这是一个订单实体类,里面包含有订单。
- @GetMapping("product/{id}")
- public SysProduct getByOrderId(@PathVariable String id){
- SysProduct byOrderId = orderService.getByOrderId(Long.valueOf(id));
- return byOrderId;
- }
在product微服务中定义的接口
server.port=8001
在product配置文件中定义端口为8001
- package com.blb.order.service.impl;
-
- import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
- import com.blb.common.entity.SysOrder;
- import com.blb.common.entity.SysProduct;
- import com.blb.order.mapper.OrderMapper;
- import com.blb.order.service.OrderService;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Service;
- import org.springframework.web.client.RestTemplate;
-
- @Service
- public class OrderServiceImpl extends ServiceImpl<OrderMapper, SysOrder> implements OrderService {
-
- @Autowired
- private OrderMapper orderMapper;
-
- @Autowired
- private RestTemplate restTemplate;
-
-
- @Override
- public SysOrder getByOrderId(Long id) {
- SysOrder sysOrder = orderMapper.selectById(id);
- SysProduct template = restTemplate.getForObject("http://localhost:8001/product/"+sysOrder.getId(), SysProduct.class);
- sysOrder.setProduct(template);
- return sysOrder;
- }
- }

在order微服务模组中调用product的接口,实现模组调用模组;以上就是简单的微服务案例;
Spring Cloud 封装了 Netflix
公司开发的 Eureka 模块来实现服务治理
服务治理就是提供了微服务架构中各微服务实例的快速上线或下线且保持各服务能正常通信的能力的方案总称。
Eureka是Netflix开源的一个服务注册和发现组件,用于构建和管理分布式系统中的微服务架构。
Eureka 的核心功能是服务注册和发现。在微服务架构中,每个服务都需要将自己注册到 Eureka 服务器,以便其他服务可以发现和调用它。Eureka 服务器充当服务注册中心,维护着所有可用的服务实例的信息,包括它们的网络地址、健康状态等。这使得服务实例可以动态地加入或退出系统,同时也支持服务实例的负载均衡和故障转移。
以下是 Eureka 的一些关键特性:
服务注册和发现:Eureka 提供了简单易用的 API,使服务实例能够方便地自我注册到 Eureka 服务器,并能够查询其他服务实例的信息。服务实例定期向 Eureka 服务器发送心跳来表明自己的健康状态。
高可用性:Eureka 支持多个 Eureka 服务器实例的高可用部署,每个实例之间相互注册并相互跟踪。当一个 Eureka 服务器不可用时,其他实例可以继续提供服务注册和发现功能,保证系统的可用性。
负载均衡:Eureka 客户端中集成了负载均衡的功能,能够根据一定的策略从多个可用的服务实例中选择一个来处理请求,从而实现请求的分发和调度。
自我保护机制:Eureka 支持自我保护机制,当检测到与 Eureka 服务器的连接故障时,服务实例仍可以通过本地缓存继续提供服务注册和发现功能,避免由于过度保护导致系统的不可用。
Eureka提供两大组件:
Eureka Server提供注册服务功能
各个微服务节点通过配置启动后,会在EurekaServer中进行注册,这样EurekaServer中的服务注册表中将会存储所有可用服务节点的信息,服务节点的信息可以在界面中直观看到。
相关依赖
- <dependency>
- <groupId>org.springframework.cloud</groupId>
- <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
- </dependency>
EurekaClient通过注册中心进行访问
EurekaClient可以分为提供者和消费者,他们都是一个Java客户端,客户端同时也具备一个内置的、使用轮询(round-robin)负载算法的负载均衡器。在应用启动后,将会向Eureka Server发送心跳(默认周期为30秒)。如果Eureka Server在多个心跳周期内没有接收到某个节点的心跳,EurekaServer将会从服务注册表中把这个服务节点移除(默认90秒)
相关依赖
- <dependency>
- <groupId>org.springframework.cloud</groupId>
- <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
- </dependency>
什么时候使用Eureka
准确来说是什么场景需要使用注册中心:
大并发量的应用情况下就需要搭建集群(这里的集群指的不是Eureka注册中心集群,而是指的微服务各个模块的集群),搭建集群我们就需要通过注册中心来实时掌握每个应用的情况,如果根本没有大并发场景,项目虽然也拆分了服务,但是用不到集群,那我们大可不必使用注册中心,使用注册中心从某种意义上来讲,增加了程序的复杂度,而且还得时刻维护注册中心,有点大材小用了。
由上述案例继续搭建一个Eureka-Server模组,将依赖导入
- <dependency>
- <groupId>org.springframework.cloud</groupId>
- <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
- </dependency>
修改配置文件
- spring.application.name=eureka-server
- server.port=8888
- # 注册中心的地址
- eureka.instance.hostname=127.0.0.1
- # 是否拉取服务清单
- eureka.client.fetch-registry=true
- # 是否注册到eureka
- eureka.client.register-with-eureka=true
- # 定义注册中的服务地址
- eureka.client.serviceUrl.defaultZone=http://127.0.0.1:8822/eureka,http://127.0.0.1:8833/eureka
启动类添加@EnableEurekaServer注解
-
- @EnableEurekaServer
- @SpringBootApplication
- public class EurekaServerApplication {
-
- public static void main(String[] args) {
- SpringApplication.run(EurekaServerApplication.class, args);
- }
-
- }
修改上面order、product的pom文件,加上依赖
- <dependency>
- <groupId>org.springframework.cloud</groupId>
- <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
- </dependency>
修改配置文件:
Order
- #加上以下代码:
-
- spring.application.name=order-service
- #配置eureka客户端是否注册到eureka
- eureka.client.register-with-eureka=true
- #拉取服务清单
- eureka.client.fetch-registry=true
- # 注册中心地址
- eureka.client.serviceUrl.defaultZone=http://127.0.0.1:8888/eureka
Product
- spring.application.name=product-service
- #配置eureka客户端是否注册到eureka
- eureka.client.register-with-eureka=true
- #拉取服务清单
- eureka.client.fetch-registry=true
- # 注册中心地址
- eureka.client.serviceUrl.defaultZone=http://127.0.0.1:8888/eureka
在Order、Product的启动类上添加@EnableEurekaClient注解
修改order的service实现类
- @Service
- public class OrderServiceImpl extends ServiceImpl<OrderMapper, SysOrder> implements OrderService {
-
- @Autowired
- private OrderMapper orderMapper;
-
- @Autowired
- private RestTemplate restTemplate;
-
-
- @Override
- public SysOrder getByOrderId(Long id) {
- SysOrder sysOrder = orderMapper.selectById(id);
- SysProduct template = restTemplate.getForObject("http://product-service/product/"+sysOrder.getId(), SysProduct.class);
- sysOrder.setProduct(template);
- return sysOrder;
- }
- }

然后启动服务器eureka-server和两个客户端order、product
输入地址localhost:8888
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。