特点:
优点:
缺点:
优点:
缺点:
特征:
以上四个关于微服务的特征能够进一步降低服务之间的耦合度,提供服务的独立性和灵活性。做到高内聚,低耦合。
SpringCloud是目前国内使用最广泛的微服务框架,官网地址: https://spring.io/projects/spring-cloud
SpringCloud集成了各种微服务功能组件,并基于SpringBoot实现了组件的自动装配。
常见的组件包括:
基于Spring Cloud分布式微服务的优点主要包括:
弹性和可扩展性:Spring Cloud提供了各种解决方案,如服务注册与发现、负载均衡、断路器、限流等,使得微服务架构更加弹性和可扩展。可以根据实际需求动态增加或减少微服务实例,根据流量和负载情况自动调整服务的规模。
高可用性:通过使用分布式架构,将应用程序拆分为多个小型服务,每个服务都有自己的独立部署和运行环境。当一个服务发生故障时,其他服务仍然可以继续运行,确保整个系统的高可用性。
增强开发效率:Spring Cloud提供了一系列的开发工具和解决方案,如服务注册与发现(Eureka)、配置中心(Config)、服务网关(Zuul)等。这些工具能够简化分布式系统的开发和部署过程,提高开发效率。
系统解耦:采用微服务架构可以将一个大型复杂系统拆分为多个小型服务,每个服务只关注自己的业务逻辑,降低了系统的复杂性,并使得各个服务之间的开发、测试和维护更加独立和灵活。
技术栈灵活性:Spring Cloud是一个开放的框架,可以与各种技术组件和平台集成,如Netflix的Eureka、Ribbon、Hystrix等,使得开发团队可以根据具体需求选择合适的技术栈来搭建分布式系统。
总的来说,基于Spring Cloud分布式微服务可以提供弹性和可扩展性、高可用性、增强开发效率、系统解耦和技术栈灵活性等优点,使得开发和维护分布式系统更加方便和可靠。
原则:
Nacos官方地址:https://nacos.io/zh-cn/docs/quick-start.html
具体安装教程可参考: 阿里Nacos系列——Nacos安装教程(带图–手把手教学
1)引入依赖
在父工程的pom文件中的中引入SpringCloudAlibaba的依赖:
com.alibaba.cloud spring-cloud-alibaba-dependencies 2.2.6.RELEASE pom import
在子工程的pom文件中引入nacos-discovery依赖:
com.alibaba.cloud spring-cloud-starter-alibaba-nacos-discovery 4.0.2
2)配置nacos地址
在上图标注的application.yml中添加nacos地址:
spring: cloud: nacos: discovery: server-addr: localhost:8848 username: nacos password: nacos
Feign是一个声明式的http客户端,官方地址:
https://github.com/OpenFeign/feign
1)引入依赖
org.springframework.cloud spring-cloud-starter-openfeign 4.0.2 org.springframework.cloud spring-cloud-starter-loadbalancer 4.0.2
2)在启动类上添加注解
@EnableFeignClients // 开启fegin调用
3)编写Feign的客户端
新建一个interface
@FeignClient("type-service") // 被调用者服务的配置文件里面的名字 public interface TypeFeign { @RequestMapping("type/findTypeAll") // 注意:路径补全 List findTypeAll(); }
4)优化
将Feign接口抽取到统一的模块中,这样可以降低服务之间的耦合性
5)小结
使用Feign的步骤:
① 引入依赖
② 添加@EnableFeignClients注解
③ 编写FeignClient接口