SpringCloud的认识和初步搭建

目录

一.认识SpringCloud

二.SpringCloud的部署

2.1开发环境

2.2数据库的建立

2.3SpringCloud的部署

第一步: 创建Maven项目

第二步:完善pom文件

第三步:创建两个子项目

第四步:声明项目依赖以及构建插件

第五步:完善子项目的代码

第六步:测试

2.4远程调用

三.总结RestTemplate


学习专栏:http://t.csdnimg.cn/tntwg

一.认识SpringCloud

        现在在Java当中最需要的技术就是SpringCloud,但是又该怎么学习呢? 我们先从它的定义入手!

        Spring Cloud 是一个用于构建分布式系统的开源框架,它提供了多种服务治理工具和组件,简化了基于 Spring Boot 的应用开发、部署、测试等方面的复杂性。

总结:SpringCloud把一个单体项目,拆分为多个微服务,每个微服务可以独立技术选型,独立开发,独立部署,独立运维.并且多个服务相互协调,相互配合。并且主要学习它的部署。以及各个组件!

组件:Eureka、LoadBalance、Nacos、OpenFeign、Gateway等

二.SpringCloud的部署

2.1开发环境

        我们需要JDK17以上的版本,MySQL也是需要8版本的,因此老版本需要淘汰了!

Linux安装JDK17和MySQL8教程:http://t.csdnimg.cn/0RxW9

2.2数据库的建立

        我们以数据的获取作为实例,来让我们部署SpringCloud更有依据性!

创建学校库:

create database if not exists cloud_teacher charset utf8mb4;
create database if not exists cloud_student charset utf8mb4;

cloud_teacher库下Teacher表:

create table teacher_detail (id int  COMMENT '工号',name varchar(8) NOT NULL COMMENT '姓名',sex varchar(4) NOT NULL,classroom varchar(20) NOT NULL,check (sex = 'boy' or sex = 'gril')
);
---插入数据
insert into teacher_detail values (2001,"TQ01","boy","21班"),(2002,"TQ02","gril","22班"),(2003,"TQ03","boy","23班"),(2004,"TQ04","gril","24班"),(2005,"TQ05","boy","25班");

cloud_student库下的Student表:

create table student_detail (id int  COMMENT '学号',name varchar(10) NOT NULL COMMENT '姓名',sex varchar(10) NOT NULL,classroom varchar(20) NOT NULL
);
---插入数据
insert into student_detail values (1,"zhangsan","boy","21班"),(2,"lisi","gril","21班"),(3,"wnagwu","boy","22班"),(4,"TQ04","gril","24班"),(5,"TQ05","gril","25班");

可自定义插入一些数据!

2.3SpringCloud的部署

第一步: 创建Maven项目

打开电脑的IDEA,选择创建Maven项目,然后删除src文件夹,保留pom.xml

目录结构:

第二步:完善pom文件

      使⽤properties来进⾏版本号的统⼀管理, 使⽤dependencyManagement来管理依赖, 声明⽗⼯程的打包⽅式为pom

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>org.example</groupId><artifactId>Build</artifactId><packaging>pom</packaging><version>1.0-SNAPSHOT</version><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><!--   SpringBoot的版本号     --><version>3.1.6</version><relativePath/><!-- lookup parent from repository --></parent><properties><maven.compiler.source>17</maven.compiler.source><maven.compiler.target>17</maven.compiler.target><java.version>17</java.version><mybatis.version>3.0.3</mybatis.version><mysql.version>8.0.33</mysql.version><!--  Cloud版本      --><spring-cloud.version>2022.0.3</spring-cloud.version></properties><dependencies><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency></dependencies><dependencyManagement><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>${spring-cloud.version}</version><type>pom</type><scope>import</scope></dependency><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>${mybatis.version}</version></dependency><dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId><version>${mysql.version}</version></dependency><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter-test</artifactId><version>${mybatis.version}</version><scope>test</scope></dependency></dependencies></dependencyManagement>
</project>

注:

1.DependencyManagement 和 Dependencies的区别:

  1. <dependencyManagement> 用于集中管理依赖的版本号,可以在父项目中定义,子项目可以继承并直接引用,避免重复指定版本号。
  2. <dependencies> 用于实际声明项目中所需的依赖,包括详细的依赖信息,如 groupId、artifactId 和特定的版本号(如果需要覆盖 <dependencyManagement> 中的版本号)。

2.在Spring官网里,明确规定了SpringBoot和SpringCloud的对应版本:

第三步:创建两个子项目

        创建2个子项目,分别为学生服务和老师服务

第四步:声明项目依赖以及构建插件

        在子项目的pom.xml当中插入这段代码! 定义依赖项

<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId></dependency><!--mybatis--><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId></dependency>
</dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins>
</build>

        通过在父项目的 <dependencyManagement> 中定义这些依赖项,子项目可以简单地引用这些依赖,而无需重复指定版本号,只需指定 <groupId><artifactId> 即可。

第五步:完善子项目的代码

        目前创建成功,但是我们需要完善其中的代码:

 1.启动类   2.model层实体类   3.Controller层、.mapper层接口、.server层     4.配置文件

1.项目结构完善及启动类完善:

2.model层完善:

        和数据库的字段保持一致即可!

3.配置文件完善:

代码:

server:port: 8081
Spring:datasource:url: jdbc:mysql://127.0.0.1:3306/数据库名?characterEncoding=utf8&useSSL=falseusername: rootpassword: 密码driver-class-name: com.mysql.cj.jdbc.Driver# 设置 Mybatis 的 xml 保存路径
mybatis:configuration: # 配置打印 MyBatis 执行的 SQLlog-impl: org.apache.ibatis.logging.stdout.StdOutImplmap-underscore-to-camel-case: true  #自动驼峰转换

4.包下完善

        这个完善,我是指写一个例子可以运行而已!

Student服务根据ID查找学生信息,

Teacher我根据教室查找老师的信息

Controller层:

@RequestMapping("/Student")
@RestController
public class StudentController {@AutowiredStudentService studentService;@RequestMapping("/{studentId}")public StudentInfo getId(@PathVariable int studentId){return studentService.getId(id);}
}
@RestController
@RequestMapping("/Teacher")
public class TeacherController {@AutowiredTeacherService teacherService;@RequestMapping({"/{classroom}"})public TeacherInfo getTeacherId(@PathVariable("classroom")String classroom){return teacherService.getclassroom(classroom);}
}

service层:

@Service
public class StudentService {@AutowiredStudentMapper studentMapper;public StudentInfo getId(int id){return studentMapper.getId(id);}
}
@Service
public class TeacherService {@AutowiredTeacherMapper teacherMapper;public TeacherInfo getclassroom(String classroom){return teacherMapper.getClassroom(classroom);}
}

mapper层:

@Mapper
public interface StudentMapper {@Select("select * from studentDetail where id = #{id}")StudentInfo getId(int id);
}
@Mapper
public interface TeacherMapper {@Select("select * from teacher_detail where classroom = #{classroom}")TeacherInfo getClassroom(String classroom);
}

第六步:测试

如图,返回成功!注意端口号之分 

2.4远程调用

        在上面,我们可以发现,这还是单机运行,各个项目运行自身的服务,获取信息,而SpringCloud体现在何处呢?接下来我们将在Student调用Teacher的Controller,并且获取到数据

我们先修改一下Student类,并且复制Teacher类添加到在Student-service的Model包中!

实现思路: Student-service服务向Teacher-service服务发送⼀个http请求, 把得到的返回结果, 和订单结
果融合在⼀起, 返回给调⽤⽅.
实现⽅式: 采⽤Spring 提供的RestTemplate

第一步:创建一个config包,添加BeanConfig 

@Configuration
public class BeanConfig {@Beanpublic RestTemplate restTemplate(){return new RestTemplate();}
}

第二步:修改Service包下的类

@Service
public class StudentService {@AutowiredStudentMapper studentMapper;@AutowiredRestTemplate restTemplate;public StudentInfo getId(int id){StudentInfo studentInfo = studentMapper.getId(id);String url = "http:127.0.0.1:8081/Teacher/"+studentInfo.getClassroom();TeacherInfo teacherInfo = restTemplate.getForObject(url, TeacherInfo.class);studentInfo.setTeacherInfo(teacherInfo);return studentInfo;}
}

测试结果:

三.总结RestTemplate

        在本次实验中,我们可以发现项目和项目之间的http请求完全依靠于RestTemplate   那么是否可以说学会了这个RestTemplate,SpringCloud就掌握了呢?

不不不,SpringCloud是各个组件的学习,你只是初步认识到了SpringCloud的知识!

本次项目存在的问题:

  1. 远程调用时,URL的IP和端口号是写死的,想更换ip需要修改代码!
  2. 所有服务都可以调用该接口,这安全吗?
  3. RestTemplate被阻塞导致性能下降,怎么办呢?

前面两个都可以使用注册中心解决,但最后一个需要从自身上解决问题!

因阻塞而性能下降 :

方法一:

        RestTemplate 默认使用 SimpleClientHttpRequestFactory,可以配置连接池参数如最大连接数、连接超时、读取超时等,以优化连接管理,减少瓶颈。

RestTemplate restTemplate = new RestTemplate();
restTemplate.setRequestFactory(new HttpComponentsClientHttpRequestFactory(HttpClientBuilder.create().setMaxConnPerRoute(20).setMaxConnTotal(50).build()));

方法二:

        使用微服务网关(如 Spring Cloud Gateway)的方式!

当然也许有其他方法,但是我目前知识有限,以后学到了再补充吧

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

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

相关文章

cocos2d-x安装和项目

首先多方查找资料发现教程很简洁&#xff0c;发现对自己的操作方面没多大帮助&#xff0c;后来干脆去官网&#xff0c;好像也很简洁。基于这样一个原因&#xff0c;加上我首次碰cocos2d-x&#xff0c;决定记录一下整个流程&#xff0c;解决实际操作上的疑惑。 涉及的方面&…

爬虫的深度爬取

爬虫的深度爬取和爬取视频的方式 深度爬取豆瓣读书 import time import fake_useragent import requests from lxml import etree head {"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 …

Docker核心技术:Docker的基本使用

云原生学习路线导航页&#xff08;持续更新中&#xff09; 本文是 Docker核心技术 系列文章&#xff1a;Docker的基本使用&#xff0c;其他文章快捷链接如下&#xff1a; 应用架构演进容器技术要解决哪些问题Docker的基本使用&#xff08;本文&#xff09;Docker是如何实现的 3…

MongoDB自学笔记(四)

一、前文回顾 上一篇文章中我们学习了MongoDB中的更新方法&#xff0c;也学了一部分操作符。今天我们将学习最后一个操作“删除”。 二、删除 原始数据如下&#xff1a; 1、deleteOne 语法&#xff1a;db.collection.deleteOne(< query >,< options >) 具体参…

【SD】 Stable Diffusion(SD)原理详解与ComfyUI使用 2

Stable Diffusion&#xff08;SD&#xff09;原理详解与ComfyUI使用 Stable Diffusion&#xff08;SD&#xff09;原理详解与ComfyUI使用1. SD整体结构2. Clip&#xff08;文本编码器&#xff09;3. Unit&#xff08;生成模型&#xff09;4. VAE&#xff08;变分自编码器&#…

Electron 结合 Selenium + chromedriver 驱动服务实现浏览器多开

背景 在调研浏览器多开的过程中&#xff0c;electron 有自带的 browserview&#xff0c;webview&#xff0c;但是上面两个受制于 electron 内核版本限制&#xff0c;升级不够灵活&#xff0c;对新版的网页支持可能不及时&#xff0c;甚至不兼容&#xff0c;必须通过发布新的客…

redis的学习(一):下载安装启动连接

简介 redis的下载&#xff0c;安装&#xff0c;启动&#xff0c;连接使用 nosql nosql&#xff0c;即非关系型数据库&#xff0c;和传统的关系型数据库的对比&#xff1a; sqlnosql数据结构结构化非结构化数据关联关联的非关联的查询方式sql查询非sql查询事务特性acidbase存…

新版SpringSecurity5.x使用与配置

目录 一、了解SpringSecurity 1.1 什么是Spring Security&#xff1f; 1.2 Spring Security功能 1.3 Spring Security原理 1.4 RABC (Role-Based Access Control) 二、SpringSecurity简单案例 2.1 引入SpringSecurity依赖 2.2 创建一个简单的Controller 三、SpringSecu…

8.持久化

队列和消息都可以持久化。 持久化的目的就是让消息不丢失。 RabbitMQ本身退出&#xff0c;或者由于某种原因崩溃时造成的消息丢失。 RabbitMQ一旦宕机&#xff0c;就会造成队列和消息都丢失了。 RabbitMQ重启之后&#xff0c;非持久化的队列和消息都不存在了。 队列持久化…

数据结构 —— B树

数据结构 —— B树 B树B树的插入操作分裂孩子分裂父亲分裂 我们之前学过了各种各样的树&#xff0c;二叉树&#xff0c;搜索二叉树&#xff0c;平衡二叉树&#xff0c;红黑树等等等等&#xff0c;其中平衡二叉树和红黑树都是控制树的高度来控制查找次数。 但是&#xff0c;这都…

C语言:数组-学习笔记(万字笔记)——翻新版

目录 前言&#xff1a; 1、 数组的概念 1.1 什么是数组 1.2 为什么学习数组&#xff1f; 2. ⼀维数组的创建和初始化 2.1 数组创建 2.2 数组的初始化 2.3 数组的类型 2.3.1 什么是数组类型&#xff1f; 2.3.2 数组类型的作用 3、 一维数组的使用 3.1 数组下标 3.2 数…

LC-617-合并二叉树

文章目录 1 题目描述2 思路优化代码完整输入输出 参考 1 题目描述 https://leetcode.cn/problems/merge-two-binary-trees/description/ 给你两棵二叉树&#xff1a; root1 和 root2 。 将其中一棵覆盖到另一棵之上时&#xff0c;两棵树上的一些节点将会重叠&#xff08;而另…

用ComfyUI安装可图Kolors大模型做手机壁纸

一、Kolors简介 国内科技公司快手在人工智能领域取得了显著进展&#xff0c;特别推出了「可图 Kolors」这一开源模型&#xff0c;它在图像生成质量上超越了SD3&#xff0c;与Midjourney v6模型相媲美&#xff0c;并支持中文提示词识别与生成中文字符&#xff0c;成为国产AI绘画…

XMl基本操作

引言 使⽤Mybatis的注解⽅式&#xff0c;主要是来完成⼀些简单的增删改查功能. 如果需要实现复杂的SQL功能&#xff0c;建议使⽤XML来配置映射语句&#xff0c;也就是将SQL语句写在XML配置⽂件中. 之前&#xff0c;我们学习了&#xff0c;用注解的方式来实现MyBatis 接下来我们…

四、 简单工厂模式

文章目录 1 基本介绍2 案例2.1 Drink 抽象类2.2 Tea 类2.3 Coffee 类2.4 DrinkFactory 类2.5 Client 类2.6 Client 类运行结果2.7 总结 3 各角色之间的关系3.1 角色3.1.1 Product ( 抽象产品 )3.1.2 ConcreteProduct ( 具体产品 )3.1.3 Factory ( 工厂 )3.1.4 Client ( 客户端 …

[译] Rust项目的基础设施

本篇是对 RustConf 2023中的Infrastructure for Rust这一视频的翻译与整理, 过程中为符合中文惯用表达有适当删改, 版权归原作者所有. 我今天要和大家讨论支持Rust及Rust项目的基础设施。Rust是一门令人惊叹的语言,我非常喜欢它,看到它的普及度和社区的成长令人非常满意。但从项…

CSA笔记4-包/源管理命令以及本地光盘仓库搭建

包/源管理命令 1.rpm是最基础的rmp包的安装命令&#xff0c;需要提前下载相关安装包和依赖包 2.yum/dnf是基于rpm包的自动安装命令&#xff0c;可以自动在仓库中匹配安装软件和依赖包 注意:以上是安装命令&#xff0c;以下是安装源 3.光盘源&#xff1a;是指安装系统时后的…

JAVA零基础学习2(算术逻辑三元运算符、原码反码补码、标准的类如何描写)

JAVA零基础学习2&#xff08;算术逻辑三元运算符、原码反码补码、标准的类如何描写&#xff09; 算术运算符算术运算符自增和自减运算符算术运算符的优先级示例代码 逻辑运算符三元运算符示例代码示例1&#xff1a;简单的条件判断示例2&#xff1a;嵌套的三元运算符 原码反码补…

【Elasticsearch7.11】集合字段 数量大小查询

需求&#xff1a; 有个字符串集合字段&#xff0c;需要查询出 集合大小 大于等于2 的数据 1、字段mapping "belong_account": {"type": "text","analyzer": "ik_max_word","search_analyzer": "ik_smart&qu…

ClusterIP、NodePort、LoadBalancer 和 ExternalName

Service 定义 在 Kubernetes 中&#xff0c;由于Pod 是有生命周期的&#xff0c;如果 Pod 重启它的 IP 可能会发生变化以及升级的时候会重建 Pod&#xff0c;我们需要 Service 服务去动态的关联这些 Pod 的 IP 和端口&#xff0c;从而使我们前端用户访问不受后端变更的干扰。 …