【狂神说Java】SpringCloud最新教程IDEA版

视频链接

大佬笔记链接

1/22p 这个阶段如何学习?

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

面试题:
1、常见面试题
1.1.什么是微服务?
1.2.微服务之间是如何独立通讯的?| I
1.3. SpringCloud 和Dubbo有哪些区别?
1.4、SpringBoot和SpringCloud, 请你谈谈对他们的理解
1.5、什么是服务熔断?什么是服务降级
1.6.微服务的优缺点是分别是什么?说下你在项目开发中遇到的坑
1.7.你所知道的微服务技术栈有哪些?请列举一二
1.8、eureka和zookeeper都可以提供服务注册 与发现的功能,请说说两个的区别?

在这里插入图片描述

2/22p 回顾微服务架构微服务架构

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3/22p 什么是springcloud

springboot可以构建微服务应用,但是微服务一旦变多了,我们要如何去协调处理这些微服务呢?那就要通过springcloud去管理。
在这里插入图片描述
在这里插入图片描述
springboot和springcloud的关系:
springboot用来构建微服务
springcloud用来协调微服务
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4/22p Rest学习环境搭建:服务提供者

前面部分按照视频教程走
新建项目
导入依赖
新建模块springcloud-api
创建数据表dept,插入数据
创建dept实体类
创建dao层
创建deptMapper,编写sql语句。resources>mybatis>mapper>DeptDao.xml
创建servcice层,
创建controller层
开启服务,在浏览器端访问

链式写法
在这里插入图片描述

在这里插入图片描述

5/22p Rest学习环境搭建:服务消费者

新建项目
导入依赖
配置application.yml
创建config>ConfigBean
创建DeptConsumerController-----通过rest模板去访问服务提供者的服务。
创建主启动类
在这里插入图片描述
在这里插入图片描述

6/22p eureka服务注册与发现

在这里插入图片描述

之前的服务注册与发现使用zookeeper实现。
在这里插入图片描述
在这里插入图片描述
步骤1:新建项目:springcloud-eureka-7001,用于服务注册与发现
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

7/22p eureka 服务注册-信息配置-自我保护机制

在这里插入图片描述
在这里插入图片描述

重新导入了一个项目代码,继续学习

在这里插入图片描述

调试成功

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

有注册中心之后,使用eureak步骤:
1、导入依赖,下面的监控完善依赖,是用来显示下图二信息
在这里插入图片描述
在这里插入图片描述
2、配置文件,下面的instance-id是用来设置图二中内容的
在这里插入图片描述
在这里插入图片描述

3、在启动类中注册服务,通过@EnableEureakClient
在这里插入图片描述
4、团队合作中,通过DiscoveryClient 实现服务发现的机制。

8/22p eureka 集群环境配置

注册中心也要使用集群。【万一一个崩了怎么办,放在一个里面不安全】
在这里插入图片描述
搭建集群之前要在C:windows/System32/drivers/etc/hosts文件中添加映射.目的就是要让我们访问这三个网站的时候识别为127.0.0.1
在这里插入图片描述
修改三台注册中心的配置文件。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

9/22p eureka CAP原则以及对比Zookeeper

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

zookeepoer保证查询到的是最新消息,但是如果挂掉一台之后,重新选举master的时候服务完全不可用
在这里插入图片描述
eureka不能查询到最新的消息,但是可以保证系统的可用性,不会导致注册中心完全瘫痪,
这道题一般是面试题:二面
笔试题:zookeeper和eureka的区别
springcloud和dubbo的区别
http和rpc的区别
在这里插入图片描述

5.5 对比和Zookeeper区别
1. 回顾CAP原则
RDBMS (MySQL\Oracle\sqlServer) ===> ACID

NoSQL (Redis\MongoDB) ===> CAP

2. ACID是什么?
A (Atomicity) 原子性
C (Consistency) 一致性
I (Isolation) 隔离性
D (Durability) 持久性
3. CAP是什么?
C (Consistency) 强一致性
A (Availability) 可用性
P (Partition tolerance) 分区容错性
CAP的三进二:CA、AP、CP

4. CAP理论的核心
一个分布式系统不可能同时很好的满足一致性,可用性和分区容错性这三个需求
根据CAP原理,将NoSQL数据库分成了满足CA原则,满足CP原则和满足AP原则三大类

CA:单点集群,满足一致性,可用性的系统,通常可扩展性较差
CP:满足一致性,分区容错的系统,通常性能不是特别高
AP:满足可用性,分区容错的系统,通常可能对一致性要求低一些
5. 作为分布式服务注册中心,EurekaZookeeper好在哪里?
著名的CAP理论指出,一个分布式系统不可能同时满足C (一致性)A (可用性)P (容错性),由于分区容错性P再分布式系统中是必须要保证的,因此我们只能再AC之间进行权衡。

Zookeeper 保证的是 CP —> 满足一致性,分区容错的系统,通常性能不是特别高
Eureka 保证的是 AP —> 满足可用性,分区容错的系统,通常可能对一致性要求低一些
Zookeeper保证的是CP

当向注册中心查询服务列表时,我们可以容忍注册中心返回的是几分钟以前的注册信息,但不能接收服务直接down掉不可用。也就是说,服务注册功能对可用性的要求要高于一致性。但zookeeper会出现这样一种情况,当master节点因为网络故障与其他节点失去联系时,剩余节点会重新进行leader选举。问题在于,选举leader的时间太长,30-120s,且选举期间整个zookeeper集群是不可用的,这就导致在选举期间注册服务瘫痪。在云部署的环境下,因为网络问题使得zookeeper集群失去master节点是较大概率发生的事件,虽然服务最终能够恢复,但是,漫长的选举时间导致注册长期不可用,是不可容忍的。

Eureka保证的是AP

Eureka看明白了这一点,因此在设计时就优先保证可用性。Eureka各个节点都是平等的,几个节点挂掉不会影响正常节点的工作,剩余的节点依然可以提供注册和查询服务。而Eureka的客户端在向某个Eureka注册时,如果发现连接失败,则会自动切换至其他节点,只要有一台Eureka还在,就能保住注册服务的可用性,只不过查到的信息可能不是最新的,除此之外,Eureka还有之中自我保护机制,如果在15分钟内超过85%的节点都没有正常的心跳,那么Eureka就认为客户端与注册中心出现了网络故障,此时会出现以下几种情况:

Eureka不在从注册列表中移除因为长时间没收到心跳而应该过期的服务
Eureka仍然能够接受新服务的注册和查询请求,但是不会被同步到其他节点上 (即保证当前节点依然可用)
当网络稳定时,当前实例新的注册信息会被同步到其他节点中
因此,Eureka可以很好的应对因网络故障导致部分节点失去联系的情况,而不会像zookeeper那样使整个注册服务瘫痪

10/22p Ribbon 负载均衡及Ribbon

在这里插入图片描述

负载均衡是专门为客户端做的,我们的项目中只有80端口是客户端,只需要对80端口所在的项目进行修改即可.
在这里插入图片描述
面试题:负载均衡是干啥用的?
简单的说就是将用户的请求平摊地分配到多个服务器上,从而达到系统的HA(高可用)
在这里插入图片描述
在这里插入图片描述
实践:
步骤:1、加入ribbon、eureka依赖
在这里插入图片描述
在这里插入图片描述
2、编写配置
在这里插入图片描述
在这里插入图片描述
启动测试,测试成功。

11/22p Ribbon 使用Ribbon实现负载均衡

在这里插入图片描述

再创建3个相同的数据表

# 数据库1
create database db01;
use db01;

create table dept(
                     deptno bigint primary key not null auto_increment,
                     dname varchar(60),
                     db_source varchar(60)
);
alter table dept comment ='部门表';

insert into dept (dname, db_source)  value ('开发部',database());
insert into dept (dname, db_source)  value ('人事部',database());
insert into dept (dname, db_source)  value ('财务部',database());
insert into dept (dname, db_source)  value ('市场部',database());
insert into dept (dname, db_source)  value ('运维部',database());

select * from db01.dept;

# 数据库2
create database db02;
use db02;

create table dept(
                     deptno bigint primary key not null auto_increment,
                     dname varchar(60),
                     db_source varchar(60)
)ENGINE =INNODB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8 COMMENT ='部门表';

insert into dept (dname, db_source)  value ('开发部',database());
insert into dept (dname, db_source)  value ('人事部',database());
insert into dept (dname, db_source)  value ('财务部',database());
insert into dept (dname, db_source)  value ('市场部',database());
insert into dept (dname, db_source)  value ('运维部',database());

select * from db02.dept;

# 数据库3
create database db03;
use db03;

create table dept(
                     deptno bigint primary key not null auto_increment,
                     dname varchar(60),
                     db_source varchar(60)
)ENGINE =INNODB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8 COMMENT ='部门表';

insert into dept (dname, db_source)  value ('开发部',database());
insert into dept (dname, db_source)  value ('人事部',database());
insert into dept (dname, db_source)  value ('财务部',database());
insert into dept (dname, db_source)  value ('市场部',database());
insert into dept (dname, db_source)  value ('运维部',database());

select * from db03.dept;

测试:

在这里插入图片描述

12/22p Ribbon 自定义负载均衡算法

13/22p Feign:使用接口方式调用服务

在这里插入图片描述
在这里插入图片描述

14/22p Hystrix 服务熔断

步骤1、导入Hystrix依赖
2、编写Controller文件中的熔断解决方案
3、在启动器上面开启断路器的支持
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

15/22p Hystrix 服务降级

负载均衡是处理同一个服务
服务降级是处理不同的服务

服务熔断是在服务端
服务降级是在客户端

在这里插入图片描述

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
整理自尚硅谷视频教程springboot高级篇,并增加部分springboot2.x的内容 一、Spring Boot与缓存 一、JSR107 Java Caching定义了5个核心接口,分别是CachingProvider, CacheManager, Cache, Entry 和 Expiry。 • CachingProvider定义了创建、配置、获取、管理和控制多个CacheManager。一个应用可 以在运行 期访问多个CachingProvider。 • CacheManager定义了创建、配置、获取、管理和控制多个唯一命名 的Cache,这些Cache 存在于CacheManager的上下文中。一个CacheManager仅被一个 CachingProvider所拥有。 • Cache是一个类似Map的数据结构并临时存储以Key为索引的值。一个 Cache仅被一个 CacheManager所拥有。 • Entry是一个存储在Cache中的key-value对。 • Expiry 每一 个存储在Cache中的条目有一个定义的有效期。一旦超过这个时间,条目为过期 的状态。一旦过期,条 目将不可访问、更新和删除。缓存有效期可以通过ExpiryPolicy设置。 二、Spring缓存抽象 Spring从3.1开始定义了org.springframework.cache.Cache 和 org.springframework.cache.CacheManager接口来统一不同的缓存技术; 并支持使用JCache(JSR- 107)注解简化我们开发; • Cache接口为缓存的组件规范定义,包含缓存的各种操作集合; • Cache接 口下Spring提供了各种xxxCache的实现;如RedisCache,EhCacheCache , ConcurrentMapCache 等; • 每次调用需要缓存功能的方法时,Spring会检查检查指定参数的指定的目标方法是否 已经被调用 过;如果有就直接从缓存中获取方法调用后的结果,如果没有就调用方法 并缓存结果后返回给用户。下 次调用直接从缓存中获取。 • 使用Spring缓存抽象时我们需要关注以下两点; 1、确定方法需要被缓存 以及他们的缓存策略 2、从缓存中读取之前缓存存储的数据 Cache 缓存接口,定义缓存操作。实现有:RedisCache、EhCacheCache、 ConcurrentMapCache等 CacheManager 缓存管理器,管理各种缓存(Cache)组件 @Cacheable 主要针对方法配置,能够根据方法的请求参数对其结果进行缓存 @CacheEvict 清空缓存 @CachePut 保证方法被调用,又希望结果被缓存。 @EnableCaching 开启基于注解的缓存 keyGenerator 缓存数据时key生成策略 serialize 缓存数据时value序列化策略 @CacheConfig 抽取缓存的公共配置 三、几个重要概念&缓存注解 1、常用注解 2、常用参数 名字 位置 描述 示例 methodName root object 当前被调用的方法名 #root.methodName method root object 当前被调用的方法 #root.method.name target root object 当前被调用的目标对象 #root.target targetClass root object 当前被调用的目标对象类 #root.targetClass args root object 当前被调用的方法的参数列表 #root.args[0] 3、常用参数SPEL明 名字 位置 描述 示例 caches root object 当前方法调用使用的缓存列表(如 @Cacheable(value= {"cache1","cache2"}) ), 则有两 个cache #root.caches[0].name argument name evaluation context 方法参数的名字. 可以直接 #参数 名 ,也可以使用 #p0或#a0 的形 式,0代表参数的索引; #iban 、 #a0 、 #p0 result evaluation context 方法执行后的返回值(仅当方法执 行之后的判断有效,如‘unless’ , ’cache put’的表达式 ’cache evict’的表达式 beforeInvocation=false ) #result 四、代码中使用缓存 1、搭建基本环境 1、导入数据库文件 创建出department和employee表 2、创建javaBean封装数据 3、整合MyBatis操作数据库 1.配置数据源信息 2.使用注解的MyBatis; 1)、@MapperScan指定需要扫描的mapper接口所在的包
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值