Java之 Spring Cloud 微服务搭建(第一个阶段)【一】【SpringBoot项目实现商品服务器端是调用】

  • (二)引入依赖

  • (三)创建DAO相关接口和子类

    • 01)创建Product(商品实体类)
  • 02)创建ProductDao接口

  • (四)创建Service相关接口和子类

    • 01)创建接口ProductService
  • 02)创建接口实现类

  • 03)创建Controller

  • 2)配置启动类(`ProductApplication`)

  • 3)配置配置文件

  • 4)运行测试

  • 2)创建order_service子模块

    • (一)工程搭建
  • (二)添加依赖

  • (三)完善配置文件

  • (四)创建启动类

  • (五) 编写Controller

  • (六)创建entity.Product

  • 三、微服务的调用

    • 1、RestTemplate介绍
  • 2、RestTemplate方法介绍

  • 3、通过RestTemplate调用微服务

    • (1)如何调用商品服务?
    • 01)完善`OrderApplication`
  • 02)完善`OrderController`

  • 03)启动订单微服务

一、 Spring cloud微服务概述

===============================================================================

1、微服务中的相关概念


(1)服务注册与发现

服务注册:服务实例将自身服务信息注册到注册中心。

这部分服务信息包括服务所在主机IP和提供服务的Port,以及暴露服务自身状态以及访问协议等信息。

服务发现:服务实例请求注册中心获取所依赖服务信息。

服务实例通过注册中心,获取到注册到其中的服务实例的信息,通过这些信息去请求它们提供的服务。

在这里插入图片描述

(2)负载均衡

负载均衡是高可用网络基础架构的关键组件,通常用于将工作负载分布到多个服务器来提高网站、应用、数据库或其他服务的性能和可靠性。

在这里插入图片描述

(3) 熔断

熔断这一概念来源于电子工程中的断路器(Circuit Breaker)。

在互联网系统中,当下游服务因访问压力过大而响应变慢或失败,上游服务为了保护系统整体的可用性,可以暂时切断对下游服务的调用。

这种牺牲局部,保全整体的措施就叫做熔断。

在这里插入图片描述

(4) 链路追踪

随着微服务架构的流行,服务按照不同的维度进行拆分,一次请求往往需要涉及到多个服务。

互联网应用构建在不同的软件模块集上,这些软件模块,有可能是由不同的团队开发、可能使用不同的编程语言来实现、有可能布在了几千台服务器,横跨多个不同的数据中心。

因此,就需要对一次请求涉及的多个服务链路进行日志记录,性能监控即链路追踪

在这里插入图片描述

(5)API网关

随着微服务的不断增多,不同的微服务一般会有不同的网络地址,而外部客户端可能需要调用多个服务的接口才能完成一个业务需求,如果让客户端直接与各个微服务通信可能出现:

  • 客户端需要调用不同的url地址,增加难度

  • 再一定的场景下,存在跨域请求的问题

  • 每个微服务都需要进行单独的身份认证

针对这些问题,API网关顺势而生。

API网关直面意思是将所有API调用统一接入到API网关层,由网关层统一接入和输出。一个网关的基本功能有:统一接入、安全防护、协议适配、流量管控、长短链接支持、容错能力。

有了网关之后,各个API服务提供团队可以专注于自己的的业务逻辑处理,而API网关更专注于安全、流量、路由等问题。

在这里插入图片描述

2、SpringCloud的介绍


在这里插入图片描述

Spring Cloud是一系列框架的有序集合。

它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用Spring Boot的开发风格做到一键启动和部署。

Spring Cloud并没有重复制造轮子,它只是将目前各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。

3、SpringCloud的架构


(1) SpringCloud中的核心组件

Spring Cloud的本质是在 Spring Boot 的基础上,增加了一堆微服务相关的规范,并对应用上下文 (Application Context)进行了功能增强。

既然 Spring Cloud 是规范,那么就需要去实现,目前Spring Cloud 规范已有 Spring官方,Spring Cloud Netflix,Spring Cloud Alibaba等实现。

通过组件化的方式,Spring Cloud将这些实现整合到一起构成全家桶式的微服务技术栈。

Spring Cloud Netflix组件

在这里插入图片描述

Spring Cloud Alibaba组件

在这里插入图片描述

Spring Cloud原生及其他组件

  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: 一些关于 Java Spring Cloud 微服务搭建教程网站包括: - Spring Cloud 官网: https://spring.io/projects/spring-cloud - 慕课网: https://www.imooc.com/topic/spring-cloud - 博客园: https://www.cnblogs.com/search/label/Spring%20Cloud - 极客学院: https://www.jikexueyuan.com/course/springcloud/ - 洛谷博客: https://www.luogu.com.cn/blog/categories/spring-cloud 你可以根据自己的需要选择合适的教程网站学习. ### 回答2: Java Spring Cloud 微服务搭建教程网站有很多。以下是一些比较知名的网站: 1. Spring官方文档:Spring官方提供了很多关于Spring Cloud的文档和教程,包括如何搭建和使用微服务。这是最可靠和权威的参考资料之一。 2. Spring Cloud官方网站:Spring Cloud官方网站提供了大量有关微服务架构和Spring Cloud框架的文章、教程和示例代码,非常适合初学者学习。 3. CSDN:CSDN是国内最大的IT技术社区,上面有很多关于Java Spring Cloud微服务搭建的教程。你可以在搜索栏中输入相关的关键词,如"Java Spring Cloud 微服务搭建",就能找到一些网友分享的经验和教程。 4. 掘金:掘金是一个开发者社区,上面有很多关于Java Spring Cloud微服务搭建的教程和实践经验。你可以在搜索栏中输入相关的关键词,如"Java Spring Cloud 微服务搭建",就能找到一些优质的文章。 5. 知乎:知乎是一个知识分享平台,上面也有很多关于Java Spring Cloud微服务搭建的问题和回答。你可以在搜索栏中输入相关的关键词,如"Java Spring Cloud 微服务搭建",就能找到一些专业人士的回答和指导。 总之,Java Spring Cloud 微服务搭建教程网站比较丰富,你可以根据自己的需求和学习风格选择适合自己的网站进行学习。 ### 回答3: 目前有很多Java Spring Cloud微服务搭建教程的网站,以下是一些比较受欢迎的网站: 1. Spring官方文档(https://spring.io/):Spring官方网站提供了详细的文档和教程,涵盖了Spring框架以及Spring Cloud的各个模块和组件的使用方法,是学习和搭建微服务的首选之一。 2. Spring Cloud官方文档(https://spring.io/projects/spring-cloud):Spring Cloud官方网站提供了关于Spring Cloud各个组件和模块的详细文档和示例代码,可以帮助开发者了解和使用Spring Cloud的各种功能。 3. CSDN(https://www.csdn.net/):CSDN是一个IT技术社区,里面有很多开发者分享的关于Java Spring Cloud微服务搭建教程的博客和文章,可以从中获取一些实战经验和技巧。 4. 简书(https://www.jianshu.com/):简书是一个写作平台,很多开发者会在上面分享关于Java Spring Cloud微服务搭建的经验和教程,可以在简书上搜索相关的文章学习。 5. GitHub(https://github.com/):GitHub是一个开源代码托管平台,很多开发者会在上面分享自己的微服务项目,可以通过搜索一些开源的Java Spring Cloud项目来学习和参考。 除了上面提到的网站,还有很多其他的在线教程、视频教程等资源可供参考。在学习Java Spring Cloud微服务搭建的过程中,不仅需要掌握基本的Spring框架知识,还需要了解Spring Cloud的各个组件的用法和原理。通过多方面的学习和实践,可以快速熟悉和掌握Java Spring Cloud微服务搭建的技能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值