spring-cloud 基础实战

本文介绍了微服务架构的概念、优缺点,以及Spring Cloud作为微服务治理框架的角色。通过实战项目,详细展示了如何使用Spring Boot和Spring Cloud构建分布式微服务,包括服务提供者和服务消费者的创建与配置,涉及Maven分模块管理、数据库连接、RESTful API等关键步骤。
摘要由CSDN通过智能技术生成

微服务是一种架构风格,是以开发一组小型服务的方式来作为一个独立的应用系统,每个服务都运行在自己的进程中,服务之间采用轻量级的http通信机制(通常是采用http的restful api)进行通信,这些服务都是围绕具体业务进行构建的,并且可以独立部署到生产环境上。这些服务可以用不同的变成语言编写,并且可以使用不同的数据存储技术。对这些微服务我们只需要使用一个非常轻量级的集中式管理来进行协调。

1. 1.2单体应用架构

- 单体应用架构概念
一个应用中包含了应用程序的所有功能(比如:页面,代码,配置),把应用打成一个war或jar包部署到tomcat中,通常成为单体应用架构。

  • 单体架构图

在这里插入图片描述

  • 单体应用架构的优缺点

    • 优点易于开发&测试:单个应用包含所有功能,不涉及多个应用的互联互调,便于在团队之间开发与测试。 易于部署:只需将单个应用打成war或jar包,进行部署到tomcat即可,运维起来比较方便。 易于整体扩展:当应用负载压力大时,将这个应用复制几份,分别部署在不同的服务器上,再通过负载均衡即可提高应用的并发能力。
      - 缺点 复杂性高:由于是单个应用,所以整个项目文件包含的模块非常多,导致模块的边界模糊,依赖关系不清晰,代码的质量参差不齐,混乱的堆在一起,使得整个项目非常复杂。以至每次修代码,都非常小心,可能添加一个简单的功能,或者修改一个bug都会带来隐藏的缺陷。技术债务:随着时间的推移,需求的变更和技术人员的更替,会逐渐形成应用程序的技术债务,并且越积越多。阻碍技术创新:对于单体应用来说,技术是在开发之前经过慎重评估后选定,每个团队成员都必须使用相同的开发语言,持久层存储及消息系统。

3 1.3微服务架构

- 微服务架构图
在这里插入图片描述
在这里插入图片描述

- 微服务架构的优缺点

- 优点
1. 易于开发和维护 :一个微服务只会关注一个特定的业务功能,所以业务清晰、代码量较少。开发和 维护单个微服务相对简单。
2. 单个微服务启动较快
3. 局部修改容易部署:单一应用只要有修改,就得重新部署整个应用。微服务解决了这样的问题。一
般来说,对某个微服务进行修改,只需要重新部署这个服务即可。
4. 技术栈不受限制:在微服务架构中,可以结合项目业务及团队的特点,合理的选择技术栈。
5. 按需伸缩:可根据需求,实现细粒度的扩展。

缺点
1. 运维要求高:更多的服务意味着要投入更多的运维。
2. 分布式固有的复杂性:使用微服务构建的是分布式系统。对于一个分布式系统,系统容错、网络延
迟、分布式事务等都会带来巨大的问题。
3. 接口调整成本高:微服务之间通过接口进行通信。如果修改某一个微服务的API,可能所有用到这个接口的微服务都需要进行调整。

微服务架构总结:
微服务的核心就是将传统的单一应用,根据业务拆分成一个一个的服务,彻底地去耦合,每一个微服务提 供单个业务功能的服务,一个服务做一件事。
在 IDEA 工具中使用Maven构建的一个个独立的 Module ,也就是使用Spring Boot 开发的一个个小模块 就是一个个微服务,将专业的事交给专业的模块来做。比如一个大型项目可能有上百个微服务,将这些 微服务集中起来构成一个大的系统,对外暴露服务进行调用与使用。 从技术角度看就是一种小而独立的处理过程,类似进程概念,能够自行单独启动或销毁,拥有自己独立 的数据库。

4. 1.4 介绍微服务架构技术栈

搭建分布式微服务架构的技术栈
在这里插入图片描述

第二章 Spring Cloud概要

2.1 什么是 Spring Cloud

  • Spring Cloud,基于 Spring Boot 提供了一套微服务解决方案,包括服务注册与发现,配置中心,全链路监 控,服务网关,负载均衡,熔断器等组件,除了基于NetFlix的开源组件做高度抽象封装之外,还有一些选型 中立的开源组件。

  • 官方译文:构建分布式系统不用特别的复杂且避免容易出现的错误。Spring Cloud为最常见的分布式系统模式 提供了一个简单和可访问的编程模型,帮助开发人员构建弹性、可靠和协调的应用程序。SpringCloud构建在 SpringBoot之上,使开发人员很容易开始工作并迅速提高生产力。
    在这里插入图片描述
    - Spring Boot 快速构建一个个微服务,多个微服务之间如何互通互调等呢?

    • 使用Spring Cloud进行管理协调服务间正常互联互调, 从而实现分布式微服务架构。
      - 说明:

      - spring Cloud 使用 RESTful API 实现服务之间通信
      - Dubbo 使用 RPC (远程过程调用) 实现服务之间通信

2.2 SpringBoot和SpringCloud的关系

  • Spring Boot 可以离开 Spring Cloud 单独使用开发项目,但是Spring Cloud离不开SpringBoot,属于依赖的 关系。
  • Spring Boot 专注于快速方便的开发单个个体微服务,Spring Cloud 关注全局的服务治理框架。
  • Spring Cloud 是关注全局的微服务协调整理治理框架,它将 Spring Boot 开发的一个个单体微服务整合并管 理起来,为各个微服务之间提供,配置管理、服务发现、断路器、路由、微代理、事件总线、全局锁、决策 竞选、分布式会话等等集成服务。

第三章 Rest 构建分布式微服务架构实战项目

3.1 开发环境要求

在这里插入图片描述

  • jdk1.8 (Spring Boot 推荐jdk1.8及以上): java version “1.8.0_151” Maven 3.x (maven 3.2 以上版本):Apache Maven 3.3.9
  • IntelliJ IDEA :IntelliJ IDEA 2018.2.1 x64
  • Spring Boot :Spring Boot 2.0.7
  • Spring Cloud 使用当前最新稳定版本:Finchley SR2 , 搭配 Spring Boot 2.0.7 稳定版

3.2 微服务架构实战项目介绍

- 需求
- 以 学生管理模块 做一个微服务架构通用案例,消费者Consumer(Client)通过REST调用 提供者 Provider(Server)提供的学生管理服务。
在这里插入图片描述
- Maven的分包分模块架构
- 一个Project父工程下有多个Module 子模块
- studentservice-cloud-01 父工程(Project)下初始化3个子模块(Module):
- studentservice-cloud-02-api 封装的整体Entity/interface/public配置
- studentservice-cloud-03-provider-product-8001 微服务的服务提供者Provider
- studentservice-cloud-04-sonsumer-product-80 微服务的服务消费者Consumer
浏览器发送URL请求服务默认端口号是80,因此只需要输IP或域名即可,可省略:80

3.3构建Project父工程(studentservice-cloud-01)

创建一个空工程

在这里插入图片描述

1. 创建父工程 studentservice-cloud-01
在这里插入图片描述

2. 删除 src目录及子目录,在pom.xml中手动加入pom类型,如下所示:
在这里插入图片描述

3. 在pom.xml中定义公共依赖,并各个子模块聚合进来

  <!-- 相关依赖-->
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值