分布式(8)

目录

36.什么是TCC?

37.分布式系统中常用的缓存方案有哪些?

38.分布式系统缓存的更新模式?

39.分布式缓存的淘汰策略?

40.Java中定时任务有哪些?如何演化的?


36.什么是TCC?

TCC(Try  Confirm  Cancel)又被称补偿事务,TCC与2PC的思想很相似,事务处理流程也很相似,但2pc是应用在DB层面,TCC则可以理解为在应用层面的2PC,是需要我们编写业务逻辑来实现。

TCC他的核心思想是:针对每个操作都要注册一个与其对应的确认(Try)和补偿(Cancel)。

还拿下单扣库存解释他的三个操作:

Try阶段:下单时通过Try操作区扣库存预留资源。

Confirm阶段:确认执行业务操作,在只预留的资源基础上,发起购买请求。

Cancel阶段:只要涉及到相关业务中,有一个业务方预留资源未成功,则取消所有业务资源的预留请求。

TCC的缺点:

应用侵入性强:TCC由于基于在业务层面,至使每个操作都需要有try,Confirm,Cancel三个接口。

开发难度大:代码开发量很大,要保证数据一致性Confirm和cancel接口还必须实现幂等性。

37.分布式系统中常用的缓存方案有哪些?

客户端缓存:页面和浏览器缓存,APP缓存,H5缓存,localStorage和sessionStorage

CDN缓存:

内存存储:数据的缓存

内容分发:负载均衡

Nginx缓存:本地缓存,外部缓存

数据库缓存:持久层缓存(Mybatis,hibernate多级缓存),MySQL查询缓存

操作系统缓存:Page  Cache,Buffer   Cache

38.分布式系统缓存的更新模式?

Cache  Aside模式

1.读取失效:Cache数据没有命中,查询DB,成功后把数据写入缓存

2.读取命中:读取Cache数据

3.更新:把数据更新到DB,失效缓存

Read/Write  Througn模式

缓存代理了DB读取,写入的逻辑,可以把缓存看成唯一的存储

Write   Back模式

这种模式下所有的操作都走缓存,缓存里的数据再通过异步的方式同步到数据库里面。所以系统的写性能能够大大提升了。

分布式系统缓存淘汰策略

缓存淘汰,又成为缓存逐出,是指在存储空间不足的情况下,缓存系统主动释放一些缓存对象获取更多的存储空间。一般LRU用的比较多,可以重点了解一下。

FIFO  先进先出是一种简单的淘汰策略,缓存对象以队列的形式存在,如果空间不足,就是放队列头部的对象。一般是链表实现。

LRU  最近最久未使用,这种策略是根据访问的时间先后来进行淘汰的,如果空间不足,会释放最久没有访问的对象(上次访问时间最早的对象)。比较常见的是通过有线队列来实现。

LFU  最近最少使用,这种策略根据最近访问的频率来进行淘汰,如果空间不足,会释放最近访问频率最低的对象。这个算法也是用优先队列实现的比较常见。

更进一步的谈谈Redis缓存淘汰的8个模式,可以参考上文Redis问答部分。

39.分布式缓存的淘汰策略?

分布式系统缓存淘汰策略

缓存淘汰,又成为缓存逐出,是指在存储空间不足的情况下,缓存系统主动释放一些缓存对象获取更多的存储空间。一般LRU用的比较多,可以重点了解一下。

FIFO  先进先出是一种简单的淘汰策略,缓存对象以队列的形式存在,如果空间不足,就是放队列头部的对象。一般是链表实现。

LRU  最近最久未使用,这种策略是根据访问的时间先后来进行淘汰的,如果空间不足,会释放最久没有访问的对象(上次访问时间最早的对象)。比较常见的是通过有线队列来实现。

LFU  最近最少使用,这种策略根据最近访问的频率来进行淘汰,如果空间不足,会释放最近访问频率最低的对象。这个算法也是用优先队列实现的比较常见。

更进一步的谈谈Redis缓存淘汰的8个模式,可以参考上文Redis问答部分。

40.Java中定时任务有哪些?如何演化的?

Timer

解释:1000ms是延迟启动时间,2000ms是定时任务周期,每2s执行一次

ScheduledExecutorService

解释:延迟1秒启动,每隔1秒执行一次,是前一个任务开始时就开始时间间隔,但是会等上一个任务结束再开始下一个

SpringTask

解释:

1.task1是隔5秒执行一次,{秒}{分}{时}{日期}{月}{星期}

2.task2是延迟1秒,每隔1秒执行一次

Quartz

quartz是一个开源的分布式调度库,他基于Java实现

1.Job表示一个任务,要执行的具体内容。

2.JobDetail表示一个具体的可执行的调度程序,Job是这个可执行调度程序索要执行的内容,另外JobDetail还包含了这个任务调度的方案和策略。

3.Trigger代表一个调度参数的配置,什么时候去调。

4.Scheduler代表一个调度容器,一个调度容器中可以注册多个JobDetail和Trigger。当Trigger与JobDetail组合,就可以被Scheduler容器调度了。

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

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

相关文章

数据库云平台新数科技完成B轮融资,打造全链路智能化数据库云平台

数据库云平台软件厂商「北京新数科技有限公司」(以下简称「新数科技」)已于2023年完成B1轮和B2轮融资,分别由渤海创富和彬复资本投资;义柏资本担任本轮融资独家财务顾问。 新数科技成立于2014年,当前产品矩阵包括数据库…

使用宝塔在Linux面板搭建网站,并实现公网远程访问

文章目录 前言1. 环境安装2. 安装cpolar内网穿透3. 内网穿透4. 固定http地址5. 配置二级子域名6. 创建一个测试页面 前言 宝塔面板作为简单好用的服务器运维管理面板,它支持Linux/Windows系统,我们可用它来一键配置LAMP/LNMP环境、网站、数据库、FTP等&…

【MPC学习笔记】01:MPC简介(Lecture 1_1 Unconstrained MPC)

本笔记来自北航诸兵老师的课程 课程地址:模型预测控制(2022春)lecture 1-1 Unconstrained MPC 文章目录 0 MPC 简介0.1 案例引入0.2 系统模型0.3 MPC的优点0.4 MPC的缺点0.5 MPC的未来 1 详细介绍 0 MPC 简介 0.1 案例引入 MPC(…

Linux进程以及计划任务

一.程序和进程以及线程 内核功用:进程管理、内存管理、文件系统、网络功能、驱动程序、安全功能等 对于所有的操作系统,都有基本的功能 1.程序 保存在硬盘、光盘等介质中的可执行代码和数据(硬盘上躺着) 静态保存的代码 执行…

x-cmd-pkg | JavaScript 运行时环境:node

目录 介绍首次用户技术特点竞品进一步阅读 介绍 Node.js 是一个开源、跨平台、异步事件驱动,基于 V8 引擎的 JavaScript 运行时环境,于 2009 年由 Ryan Dahl 创造,目的是为了实现高性能的网络应用开发。 性能表现良好:使用事件驱…

CMake入门教程【核心篇】宏模板(macro)

😈「CSDN主页」:传送门 😈「Bilibil首页」:传送门 😈「本文的内容」:CMake入门教程 😈「动动你的小手」:点赞👍收藏⭐️评论📝 文章目录 1. 定义宏1.1 基本语…

图像分割-漫水填充法 floodFill

版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。 本文的C#版本请访问:图像分割-漫水填充法 floodFill (C#)-CSDN博客 FloodFill方法是一种图像处理算法&#…

微服务注册到Zookeeper注册中心

jar包&#xff1a; <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-zookeeper-discovery</artifactId></dependency>启动类上面加入&#xff1a;EnableDiscoveryClient注解 application.ym…

AI计算,为什么要用GPU?

今天这篇文章&#xff0c;我们继续来聊聊芯片。 在之前的文章里&#xff0c;小枣君说过&#xff0c;行业里通常会把半导体芯片分为数字芯片和模拟芯片。其中&#xff0c;数字芯片的市场规模占比较大&#xff0c;达到70%左右。 数字芯片&#xff0c;还可以进一步细分&#xff0…

2024年报考软考中级时间什么时候?报考软考培训多少钱?

想在2024年报考软控中级的小伙伴一定对报考软考的时间、费用等都有所疑问&#xff0c;下面我就详细为大家说明关于软考报名的相关信息。 一、2024年软考中级考试安排在几月份啊 2024年软考中级考试时间安排暂未公布&#xff0c;参考往年软考考试时间的安排&#xff0c;2024年软…

​如何把图片里背景的路人P掉?教你四种方法消除路人

在日常生活中&#xff0c;我们经常会遇到需要将图片中背景的路人P掉的情况。有时候&#xff0c;这些路人会破坏图片的整体美感&#xff0c;或者我们只想要图片中的某些元素&#xff0c;而路人的出现会分散注意力。那么&#xff0c;如何才能有效地将图片中的背景路人P掉呢&#…

【基础篇】十、JVM堆 直接内存

文章目录 一、堆1、堆heap2、堆溢出3、used、total、max4、设置堆内存大小 二、直接内存 运行时数据区域&#xff0c;还有两组成部分&#xff1a;堆和方法区&#xff0c;和栈、程序计数器不同&#xff0c;它们是线程共享的 一、堆 1、堆heap 堆内存是线程共享的创建出来的对象…