SpringCloud之认识微服务

news/2024/5/7 10:24:48/文章来源:https://blog.csdn.net/qq15035899256/article/details/129323114

文章目录

  • 一、传统项目转型
  • 二、走进 SpringCloud
  • 三、微服务项目搭建
    • 3.1 创建一个 SpringBoot 项目
    • 3.2 创建三个 Maven 子工程
    • 3.3 为子工程创建 application.yml
    • 3.4 引入依赖
    • 3.5 数据库 建库建表
    • 3.6 编写业务


提示:以下是本篇文章正文内容,SpringCloud系列学习将会持续更新

在这里插入图片描述
注意: 此阶段学习推荐的电脑配置,至少配备4核心CPU(主频3.0Ghz以上)+16GB内存,否则卡到你怀疑人生。

前面我们讲解了 SpringBoot 框架,通过使用 SpringBoot 框架,我们的项目开发速度可以说是得到了质的提升。同时,我们对于项目的维护和理解,也会更加的轻松。可见,SpringBoot 为我们的开发带来了巨大便捷。而这一部分,我们将基于 SpringBoot,继续深入到企业实际场景,探讨微服务架构下的 SpringCloud。这个部分我们会更加注重于架构设计上的讲解,弱化实现原理方面的研究。

一、传统项目转型

要说近几年最火热的话题,那还得是微服务,那么 什么是微服务 呢?

我们可以先从技术的演变开始看起: 在我们学习 JavaWeb 之后,一般的网站开发模式为 Servlet + JSP。后来我们在学习了 SSM 之后,进行了前后端分离。通过使用 SpringBoot,我们几乎可以很快速地开发一个高性能的单体应用,只需要启动一个服务端,我们整个项目就开始运行了,各项功能融于一体,开发起来也更加轻松。

但是随着我们项目的不断扩大,单体应用似乎显得有点乏力了。

随着越来越多的功能不断地加入到一个 SpringBoot 项目中,随着接口不断增加,整个系统就要在同一时间内响应更多类型的请求,显然,这种扩展方式是不可能无限使用下去的,总有一天,这个 SpringBoot 项目会庞大到运行缓慢。并且所有的功能如果都集成在单端上,那么所有的请求都会全部汇集到一台服务器上,对此服务器造成巨大压力。
在这里插入图片描述
传统单体架构应用随着项目规模的扩大,实际上会暴露越来越多的问题,尤其是一台服务器无法承受庞大的单体应用部署,并且单体应用的维护也会越来越困难,我们得寻找一种新的开发架构来解决这些问题了。

Martin Fowler 在2014年提出了“微服务”架构,它是一种全新的架构风格。

  • 微服务把一个庞大的单体应用拆分为一个个的小型服务。比如我们原来的图书管理项目中,有登录、注册、添加、删除、搜索等功能,那么我们可以将这些功能单独做成一个个小型的 SpringBoot 项目,独立运行。
  • 每个小型的微服务都可以独立部署和升级。这样就算整个系统崩溃,那么也只会影响一个服务的运行。
  • 微服务之间使用 HTTP 进行数据交互,不再是单体应用内部交互了。虽然这样会显得更麻烦,但是带来的好处也是很直接的,甚至能突破语言限制,使用不同的编程语言进行微服务开发,只需要使用 HTTP 进行数据交互即可。
  • 我们可以同时购买多台主机来分别部署这些微服务。这样单机的压力就被分散到多台机器,并且每台机器的配置不一定需要太高,这样就能节省大量的成本,同时安全性也得到很大的保证。
    甚至同一个微服务可以同时存在多个,这样当其中一个服务器出现问题时,其他服务器也在运行同样的微服务,这样就可以保证一个微服务的 高可用

在这里插入图片描述
可见,采用微服务架构,更加能够应对当今时代下的种种考验,传统项目的开发模式,需要进行架构上的升级。

回到目录…

二、走进 SpringCloud

前面我们介绍了微服务架构的优点,那么同样也存在着诸多的问题:

  • 要实现微服务并不是说只需要简单地将项目进行拆分,我们还需要考虑对各个微服务进行管理、监控等,这样我们才能够及时地寻找和排查问题。因此微服务往往需要的是一整套解决方案,包括服务注册和发现容灾处理负载均衡配置管理等。
  • 它不像单体架构那种方便维护,由于部署在多个服务器,我们不得不去保证各个微服务能够稳定运行,在管理难度上肯定是高于传统单体应用的。
  • 在分布式的环境下,单体应用的某些功能可能会变得比较麻烦,比如 分布式事务

所以,为了更好地解决这些问题,SpringCloud 正式登场。

SpringCloud 是 Spring 提供的一套分布式解决方案,集合了一些大型互联网公司的开源产品,包括诸多组件,共同组成 SpringCloud 框架。并且,它利用 Spring Boot 的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册配置中心消息总线负载均衡熔断机制数据监控等,都可以用 Spring Boot 的开发风格做到一键启动和部署

由于中小型公司没有独立开发自己的分布式基础设施的能力,使用 SpringCloud 解决方案能够以最低的成本应对当前时代的业务发展。
在这里插入图片描述

可以看到,SpringCloud 整体架构的亮点是非常明显的,分布式架构下的各个场景,都有对应的组件来处理,比如基于 Netflix(奈飞)的开源分布式解决方案提供的组件:

  • Eureka - 实现服务治理(服务注册与发现),我们可以对所有的微服务进行集中管理,包括他们的运行状态、信息等。
  • Ribbon - 提供客户端的软件负载均衡算法(现在被SpringCloudLoadBalancer取代)。
  • Hystrix - 断路器,保护系统,控制故障范围。暂时可以跟家里电闸的保险丝类比,当触电危险发生时能够防止进一步的发展。
  • Zuul - 具有api网关,路由,负载均衡等多种作用。就像我们的路由器,可能有很多个设备都连接了路由器,但是数据包要转发给谁则是由路由器在进行(已经被SpringCloudGateway取代)。
  • Config - 配置管理,可以实现配置文件集中管理。

当然,这里只是进行简单的了解即可,实际上微服务的玩法非常多,我们后面的学习中将会逐步进行探索。

回到目录…

三、微服务项目搭建

现在我们重新设计一下图书管理系统项目,将原有的大型进行拆分 。一定要尽可能保证单一职责,相同的业务不要在多个微服务中重复出现。如果出现需要借助其他业务完成的服务,那么可以使用服务之间相互调用的形式来实现:

  • 验证服务:用于处理用户注册、登录、密码重置等,反正就是一切与账户相关的内容,包括用户信息获取等。
  • 图书管理服务:用于进行图书添加、删除、更新等操作,图书管理相关的服务,包括图书的存储等和信息获取。
  • 图书借阅服务:交互性比较强的服务,需要和登陆验证服务和图书管理服务进行交互。

3.1 创建一个 SpringBoot 项目

①我们首先创建一个普通的SpringBoot项目:
请添加图片描述

②然后不需要勾选任何依赖,直接创建即可,项目创建完成并初始化后,我们删除父工程的无用文件,只保留必要文件,像下面这样:在这里插入图片描述

3.2 创建三个 Maven 子工程

①接着我们就可以按照我们划分的服务,创建子工程了,创建一个新的 Maven 项目,注意父项目要指定为我们一开始创建的项目,子项目命名随意:
在这里插入图片描述

②子项目创建好之后,接着我们在子项目中创建 SpringBoot 的启动主类
在这里插入图片描述

③接着我们点击运行,即可启动子项目了,实际上这个子项目就一个最简单的 SpringBoot web 项目,注意启动之后最下方有弹窗,我们点击 “Use service”,这样我们就可以在控制台的services项实时查看大项目中的微服务了:
在这里插入图片描述

3.3 为子工程创建 application.yml

①接着我们以同样的方法,创建其他的子项目,注意我们最好将其他子项目的端口设置的不一样,不然会导致端口占用,我们分别为它们创建application.yml文件:
在这里插入图片描述

②接着我们来尝试启动一下这三个服务,正常情况下都是可以直接启动的:
在这里插入图片描述
可以看到它们分别运行在不同的端口上,这样,就方便不同的程序员编写不同的服务了,提交当前项目代码时的冲突率也会降低。

③后续用需要连接数据库,添加数据源信息

spring:datasource:driver-class-name: com.mysql.jdbc.Driverurl: jdbc:mysql://127.0.0.1:3306/library?characterEncoding=utf8&useSSL=false&serverTimezone=Asia/Shanghaiusername: rootpassword: 123456

回到目录…

3.4 引入依赖

父项目 pom.xml:

首先在父项目中添加 MySQL 驱动和 Lombok 依赖,因为这两个几乎所有项目都会用到。

<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.24</version>
</dependency>
<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.47</version>
</dependency>

由于不是所有的子项目都需要用到 Mybatis,我们在父项目中只进行版本管理即可:

<dependencyManagement><dependencies><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.2.2</version></dependency></dependencies>
</dependencyManagement>

子项目 pom.xml:
我们在子项目中添加 web 和 mybatis 的依赖:(每个子项目各自添加自己需要的依赖)

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId>
</dependency>

回到目录…

3.5 数据库 建库建表

①user 表:
在这里插入图片描述

②book 表:
在这里插入图片描述

③borrow 表:
在这里插入图片描述

添加外键:
在这里插入图片描述

添加唯一索引:
在这里插入图片描述

可以直接执行 sql 语句:

CREATE SCHEMA `library` DEFAULT CHARACTER SET utf8mb4 ;CREATE TABLE `library`.`user` (`uid` INT NOT NULL AUTO_INCREMENT,`name` VARCHAR(45) NOT NULL,`age` INT NOT NULL,`sex` ENUM('男', '女') NOT NULL,PRIMARY KEY (`uid`));CREATE TABLE `library`.`book` (`bid` INT NOT NULL AUTO_INCREMENT,`title` VARCHAR(45) NOT NULL,`desc` VARCHAR(45) NOT NULL,PRIMARY KEY (`bid`));CREATE TABLE `library`.`borrow` (`id` INT NOT NULL AUTO_INCREMENT,`uid` INT NOT NULL,`bid` INT NOT NULL,PRIMARY KEY (`id`),INDEX `f_uid_idx` (`uid` ASC) COMMENT '外键连接user表中的uid',INDEX `f_bid_idx` (`bid` ASC) COMMENT '外键连接book表中的bid',UNIQUE INDEX `unique_bid_uid` (`uid` ASC, `bid` ASC) COMMENT '唯一索引:uid和bid的组合不重复',CONSTRAINT `f_uid`FOREIGN KEY (`uid`)REFERENCES `library`.`user` (`uid`)ON DELETE NO ACTIONON UPDATE NO ACTION,CONSTRAINT `f_bid`FOREIGN KEY (`bid`)REFERENCES `library`.`book` (`bid`)ON DELETE NO ACTIONON UPDATE NO ACTION);

回到目录…

3.6 编写业务

我们来写用户查询相关的业务:

实体类:

@Data
public class User {private int uid;private String name;private int age;private String sex;
}

持久层: mapper 接口

@Repository
@Mapper
public interface UserMapper {@Select("select * from user where uid = #{uid}")User getUserById(int uid);
}

service 业务层: 具体业务逻辑

public interface UserService {User getUserById(int uid);
}
@Service
public class UserServiceImpl implements UserService {@Resourceprivate UserMapper userMapper;@Overridepublic User getUserById(int uid) {return userMapper.getUserById(uid);}
}

Controller 控制层: 请求和响应

@RestController
public class UserController {@Resourceprivate UserService userService;@GetMapping("/user/{uid}")public User findUserById(@PathVariable("uid") int uid) {return userService.getUserById(uid);}
}

现在我们访问即可拿到数据:
在这里插入图片描述

其它子工程也是同样的逻辑编写业务。这样,我们一个完整项目的就拆分成了多个微服务,不同微服务之间是独立进行开发和部署的。

回到目录…


总结:
提示:这里对文章进行总结:
本文是对SpringCloud的学习,认识什么是微服务、它的优缺点,并且认识了微服务架构SpringCloud,介绍了它的五大组件,还有微服务项目搭建的过程。之后的学习内容将持续更新!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_77104.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何校招进BAT做产品经理

嗨&#xff0c;很高兴&#xff0c;以文字的形式和你见面。在校招中&#xff0c;我拿到了百度、京东、爱奇艺、新浪和去哪儿的产品经理校招offer&#xff0c;其中百度是special offer。在找实习的过程中&#xff0c;也拿到了爱奇艺、微信电影票、搜狐畅游、艺龙等公司的产品经理…

欢迎来到 BharatBox,这是一个以来自印度的知名艺术家和品牌为特色的文化元宇宙中心

通过 Brinc 的客户 Heftyverse 娱乐公司&#xff0c;将印度艺术家、电影制片厂、体育品牌和音乐公司聚集在这个全新虚拟中心。 The Sandbox 与 Brinc 的联营公司推出 BharatBox&#xff0c;这是一个全新的文化中心&#xff0c;由来自印度的娱乐、艺术和体育范畴的主要合作伙伴组…

知识图谱的介绍

知识图谱的由来 谷歌在2012年提出了知识图谱的概念&#xff0c;当时目的在于优化搜索引擎的返回结构&#xff0c;为用户提供更精确的结果。 知识图谱的定义 为了理解知识图谱&#xff0c;我们首先要明白信息与知识的概念。首先&#xff0c;信息表示的是外部的客观事实&#…

hadoop调优

hadoop调优 1 HDFS核心参数 1.1 NameNode内存生产配置 1.1.1 NameNode内存计算 每个文件块大概占用150byte&#xff0c;如果一台服务器128G&#xff0c;能存储的文件块如下 128 (G)* 1024(MB) * 1024(KB) * 1024(Byte) / 150 Byte 9.1 亿 1.1.2 Hadoop2.x 在Hadoop2.x中…

MVVM模式下如何正确【视图绑定+数据】

概述 我如何&#xff08;不在后面的代码中使用代码&#xff09;自动绑定到我想要的视图&#xff1f;据我了解&#xff0c;如果正确完成&#xff0c;这就是模式应该如何工作。我可以使用主窗口 xaml 中的代码实现这一切&#xff0c;我甚至正确创建了一个资源字典&#xff08;因…

linux下nm,objdump和ldd三大工具使用

linux下进行C/C开发时经常需要使用nm&#xff0c;objdump&#xff0c;ldd工具来分析定位问题&#xff0c;本篇文章就对其做个总结&#xff1a; 1.测试程序 TestSo.h #pragma once #include <iostream>extern "C" int CTypeAdd(int x, int y); extern "…

Python 之网络式编程

一 客户端/服务器架构 即C/S架构&#xff0c;包括 1、硬件C/S架构&#xff08;打印机&#xff09; 2、软件B/S架构&#xff08;web服务&#xff09; C/S架构与Socket的关系&#xff1a; 我们学习Socket就是为了完成C/S的开发 二 OSI七层 引子&#xff1a;   计算机组成…

云HIS系统源码 医院his源码 云his源码

大型医院his系统源码 SaaS运维平台多医院入驻强大的电子病历完整文档 &#xff0c;有演示 一、系统概述&#xff1a; 基层卫生健康云是一款满足基层医疗机构各类业务需要的健康云产品。该产品能帮助基层医疗机构完成日常各类业务&#xff0c;提供病患挂号支持、病患问诊、电子…

python学习——【第一弹】

前言 Python是一种跨平台的计算机程序设计语言&#xff0c;是ABC语言的替代品&#xff0c;属于面向对象的动态类型语言&#xff0c;最初被设计用于编写自动化脚本&#xff0c;随着版本的不断更新和语言新功能的添加&#xff0c;越来越多被用于独立的、大型项目的开发。 从这篇…

轮盘赌选择法

轮盘赌选择原理 轮盘赌选择法&#xff08;roulette wheel selection&#xff09;是最简单也是最常用的选择方法&#xff0c;在该方法中&#xff0c;各个个体的选择概率和其适应度值成比例&#xff0c;适应度越大&#xff0c;选中概率也越大。 从图中可以看出一等奖、二等奖、…

【Java集合框架】篇六:Collections工具类

Collections 是一个操作 Set、List 和 Map 等集合的工具类。 1。 常用方法 Collections 中提供了一系列静态的方法对集合元素进行排序、查询和修改等操作&#xff0c;还提供了对集合对象设置不可变、对集合对象实现同步控制等方法&#xff08;均为static方法&#xff09;&…

【Python学习笔记】第二十六节 Python PyMySQL

一、什么是 PyMySQL&#xff1f;PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库。可以用它来连接Python和MySQL。如果你追求速度&#xff0c;这是一个很好的选择&#xff0c;因为它比mysql-connector-python快。PyMySQL 遵循 Python 数据库 API v2.0 规范&#x…

AntDB“超融合+流式实时数仓”,谈传统数据库与流计算的有机融合

&#xff08;一&#xff09; 前言 据统计&#xff0c;在信息化时代的今天&#xff0c;人们一天所接触到的信息量&#xff0c;是古人一辈子所能接收到的信息量的总和。当今社会中除了信息量“多”以外&#xff0c;人们对信息处理的“效率”和“速度”的要求也越来越高。譬如&am…

浅谈一下mysql8.0与5.7的字符集

修改字符集 修改步骤 在MySQL8.0版本之前&#xff0c;默认字符集为1atin1,utf8字符集指向的是utf8mb3。网站开发人员在数据库设计的时候往往会将编码修改为ut8字符集。如果遗忘修改默认的编码&#xff0c;就会出现乱码的问题。从MySQL8.0开始&#xff0c;数据库的默认编码将改…

王道C语言督学营OJ练习全解【24考研最新版】

前言 本篇博客是在博主参加王道408专业课前置课程-----C语言督学营的学习笔记&#xff0c;包含了从第一节课到最后一节课的所有OJ习题题解&#xff0c;文章中每一题都给出了详尽的代码&#xff0c;并在每一题的关键部位加上了注释&#xff0c;记录下来的目的是方便自己以后进行…

maven镜像源及代理配置

在公司使用网络一般需要设置代理&#xff0c; 我在idea中创建springboot工程时&#xff0c;发现依赖下载不了&#xff0c;原以为只要浏览器设置代理&#xff0c;其他的网络访问都会走代理&#xff0c;经过查资料设置了以下几个地方后工程创建正常&#xff0c;在此记录给大家参考…

Python中Opencv和PIL.Image读取图片的差异对比

近日&#xff0c;在进行深度学习进行推理的时候&#xff0c;发现不管怎么样都得不出正确的结果&#xff0c;再仔细和正确的代码进行对比了后发现原来是Python中不同的库读取的图片数组是有差异的。 image np.array(Image.open(image_file).convert(RGB)) image cv2.imread(…

SpringBoot实现Excel导入导出,简单好用

EasyPoi简介 POI是Java操作MicroOffice&#xff08;如对Excel的导入导出&#xff09;的一个插件。POI的全称是&#xff08;Poor Obfuscation Implementation&#xff09;&#xff0c;POI官网地址是 http://poi.achache.org/index.html 。 EasyPoi对POI进行了优化&#xff0c;…

Navicat 现已支持 OceanBase 全线数据库产品

Navicat 作为 OceanBase 生态工具的合作伙伴&#xff0c;这是双方产品适配第三个里程碑。2022 年 7 月的首个里程碑&#xff0c;Navicat 实现了 OceanBase 社区版的功能性兼容。同年10 月&#xff0c;进一步实现了针对 OceanBase 企业版&#xff08; 兼容 MySQL 模式&#xff0…

嵌入式学习笔记——STM32单片机开发前的准备

STM32单片机开发前的准备1.集成开发环境的选取STM32 CubeIDEKEIL_MDK2.KEIL_MDK环境搭建安装包获取及安装芯片包下载及安装工程建立(STM32F407VET6为例)1.新建工程文件夹2.新建工程3.安装ST-LINK以及CH340的驱动4.设置KEIL&#xff0c;并烧录本文重点1.集成开发环境的选取 前面…