SpringCloud-高级篇(十四)

news2025/1/16 20:02:06

缓存的作用是其实就是为了减轻对数据库的压力,缩短服务响应的时间,从而提高整个服务的并发能力,Redis单节点并发其实已经很高了,但是它依然有自己的上限,随着互联网的发展,用户低量越来越大,想淘宝、京东、12306这样的网站,它们的并发量,往往能达到亿级一上的并发量,这个时候仅仅使用Redis是不能够满足高的并发需求的。

下面学习的多级缓存正是为了应对亿级流量的并发

(1)多级缓存的架构

浏览器可以把服务器返回的静态资源缓存在本地的,下次再去访问静态资源的时候服务器只要检查一下,数据有没有变化,没有变化返回304状态码,不用返回数据了,浏览器看返回的是304说明本地有,直接把本地的数据渲染,用户直接可以看到,这样就可以减少数据的传输,从而提高渲染和响应的速度。对于一个页面来讲90%的请求都是静态资源请求都可以被缓存起来,那么这样来看响应速度就大大提升了,这就是第一级缓存

对于非静态的数据,不得不访问服务器端了,请求到达了nginx,原来nginx服务器是做反向代理的,在这里要形成第二级的缓存(nginx本地缓存),nginx也是可以去做编程的,想tomcat一样做业务逻辑的编写,我们可以把数据缓存在nginx本地,用户请求来了之后呢,我想看本地有没有呢,有的话直接返回,请求都不到tomcat,响应速度就会快很多

如果没有直接查Redis,注意Redis以前是在tomcat后查现在是在Nginx查,压根不需要到tomcat,tomacat压力就大大减轻了,查Redis就形成了第三级缓存,Redis命中了直接返回,未命中采用到达tomcat

到tomcat以后,不是直接访问数据库的,会形成第四级缓存,叫做tomcat进程缓存,会在服务器的内部类似map(更高级的东西)的形式形成一个进程缓存,这样的缓存呢保存在tomat本地,请求到达以后呢先去读本地缓存,进程缓存啊,命中了直接就返回了,也就不会去访问数据库了,可以解决之前的一个问题,当Redis缓存失效时它就不会直接打到数据库了,它会先到tomcat读本地进程缓存,而后在没命中的情况下,才会到达数据

通过层层的缓存,解决了之前的两个问题了请求大多数情况下都由nginx处理了,不会tomcat,tomcat压力大大减轻了,tomcat就不会称为整个服务器的瓶颈了。第二个当Redis缓存失效时,还会有tomcat进程缓存,做一个缓冲,从而不会直接打到数据库,避免了对数据库的冲击,前面有好几层缓存,压力都集中到了nginx,我们需要在nginx内部去实现对Redis的访问,对tomcat的访问等等的业务编写,此时他就不是一个反向代理服务器了,就变成一个真正的Web服务了在里面去写业务逻辑了将来nginx将来要部署成一个集群,去应对更高的一个并发,准备一个单独的nginx,做反向代理,请求先到它,然后再反向代理到多个本地的本地缓存编写业务的nginx服务器,然后再往后去访问Redis,tomcat按照这样的流程去走,当然Redis也好,tomacat,Mysql也都可以去做群,这样呢多级缓存完整架构方案

 

我们需要在tomcat内部去学习编写进程缓存,称为JVM进程缓存

需要在nginx内部做编程,需要学习一门新的语言Lua,学习会了之后,就可以去实现nginx本地缓存,Redis缓存,tomcat缓存等等的多级缓存方案

最后数据库需要跟缓存做同步,就是缓存同步策略

(2)JVM进程缓存

这里主要实现多级缓存中的tomcat进程缓存部分,在tomcat内部去添加缓存,业务进来以后呢优先查进程缓存,缓存没有命中在去查数据库 

(1)导入商品案例

 

重启mysql:

 

 

查询商品: 

查询库存: 

将来的查询接口是要加缓存业务的

这个nginx是Windows版本的 

item.html就是商品查询页 

页面中的数据是写死的,将来想要去服务器中查询

1001这个发送的请求没有加端口,默认请求到80端口了,到了反向代理服务器 

 

nginx.conf配置反向代理 

(2)初识Caffeine

我们下面可以给商品查询添加缓存了,我们添加的是JVM的本地缓存,我们先了解一下进程的缓存跟传统的分布式缓存之间的差异,了解一个缓存技术Caffeine

        

一直往缓存中存入数据是不行的需要一种清除策略 

驱逐需要时间,运行完jvm就退出了 

前面的key就被清理了 

(3)实现进程缓存

创建缓存对象 

在Controller中注入缓存对象:

改: 

查商品 

产生日志,第一次查询走的数据库  

清空日志: 

重新刷新一次浏览器:没有日志,则证明这次查询没有走数据库,走了缓存

查库存:

产生日志,第一次查询走的数据库 

刷新页面:没有日志,走的缓存

第一次查询走的是数据库,把数据库放到缓存中,第二次直接走缓存,不再查询数据库了,则证明JVM进程缓存就实现了

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

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

相关文章

list列表可编辑状态

有时候list需要修改或选择属性,mfc自带的只能显示内容,基本上是不可以修改,为了实现这个功能需求,需要完成一下步骤转换. 第一步记录选择的单元格. 第二步创建一个编辑框CComboBox对象, 设置字体,窗口属性. 第三步获取选中单元格的位置信息. 第四步获取单元格内容信息. 第五步…

C++ STL容器详解

string容器 string的基本概念 本质 string是C风格的字符串,而string本质上是一个类 string与char* 的区别 char * 是一个指针 string是一个类,类内部封装了char*,管理这个字符串,是一个char*型的容器。 string的构造函数 构造函…

数据库性能优化的解决方案

目录​​​​​​​ 1、什么是数据库性能优化 1.1 数据库性能优化的概念 1.2 为何需要进行数据库性能优化 1.3 数据库性能优化的好处 2、数据库性能优化的基本原理 2.1 数据库查询优化 2.2 数据库索引优化 2.3 数据库表结构优化 2.4 数据库硬件优化 3、数据库查询优化…

机床导轨误差对机械加工品质的影响

机床导轨是确定机床各部件相对位置关系的基准,也是相对运动的基准,其精度直接决定了机械加工产品的精度,机床导轨要确保精准,才能保证机械加工产品的良好,否则,会影响加工品质,主要体现在以下几方面&#x…

力扣刷MySQL-第六弹(详细讲解)

🎉欢迎您来到我的MySQL基础复习专栏 ☆* o(≧▽≦)o *☆哈喽~我是小小恶斯法克🍹 ✨博客主页:小小恶斯法克的博客 🎈该系列文章专栏:力扣刷题讲解-MySQL 🍹文章作者技术和水平很有限,如果文中出…

C++——函数的定义

1,概述 作用:将一段经常使用的代码封装起来,减少重复代码 一个较大的程序,一般分为若干个程序块,每个模块实现特定的功能。 2,函数的定义 函数的定义一般主要有五个步骤: 1,返回…

C++ 学习系列 -- std::function 与 std::bind

一 std::function 与 std::bind 的介绍 1. std::function std::function 是 c 11 的新特性 &#xff0c;包含在头文件<functional>中&#xff0c;为了更方便的调用函数而引入。 std::function 是一个函数包装器&#xff08;function wrapper&#xff09;&#xff0c;…

英国金融时报关注TRX登陆Mercado Bitcoin交易所:波场TRON强化南美洲布局,国际化进程持续加速

近日,波场TRON网络原生代币TRX正式上线巴西最大的合规加密交易所Mercado Bitcoin。英国金融时报、Decrypt、Blockworks等财经及加密行业权威媒体对该话题进行了报道,表示此次合作是波场TRON全球业务增长的有力证明,也表明该平台力求处于数字经济前沿的坚定决心。 据悉,Mercado…

小白快速上手maven【基础篇】

Maven的概念和作用 Maven是什么&#xff1f;POM的概念 Maven的作用&#xff1f; 提供自动化构建项目的方式&#xff0c;并且统一了项目的结构管理项目中的依赖 Maven基础概念-仓库&#xff0c;坐标&#xff0c;仓库配置 仓库&#xff1a;用于存储各种jar包资源 根据功能的不…

【微信小程序开发】环境介绍和基本使用

文章目录 前言1. 项目的基本组成结构1.1 JSON 配置文件的作用1.2 如何新建小程序页面1.3 修改项目首页1.4 WXML 模板1.5 WXSS 样式1.6 JS 逻辑交互 2. 宿主环境2.1 什么是宿主环境2.2 通信模型2.3 运行机制2.4 组件2.4.1 view 组件的基本使用&#xff1a;2.4.2 scroll-view 组件…

专业137总分439东南大学920专业基础综合考研经验电子信息与通信电路系统芯片

我本科是南京信息工程大学&#xff0c;今年报考东南大学信息学院&#xff0c;成功逆袭&#xff0c;专业137&#xff0c;政治69&#xff0c;英语86&#xff0c;数一147&#xff0c;总分439。以下总结了自己的复习心得和经验&#xff0c;希望对大家复习有一点帮助。啰嗦一句&…

OpenAI CEO称“AGI时代”即将来临,下一个风口或为能源领域

原创 | 文 BFT机器人 在最近的达沃斯论坛上&#xff0c;Sam Altman以其深邃的见解和前瞻性的思考&#xff0c;再次成为了全场关注的焦点。他以一场激情四溢的演讲&#xff0c;深入剖析了人工智能技术的未来发展趋势&#xff0c;以及它可能对社会和工作领域产生的深远影响。 Al…

HTTP 协议和 TCP/IP 协议之间有什么区别?

HTTP&#xff08;超文本传输协议&#xff09;和TCP/IP&#xff08;传输控制协议/互联网协议&#xff09;是两种在互联网通信中广泛使用的协议&#xff0c;它们之间的区别和联系对许多人来说可能还不是很清晰&#xff0c;今天我们就带大家来一起了解一下HTTP和TCP/IP协议这2者之…

JAVAEE初阶 封装与分用

封装和分用 一.封装1.1 应用层1.2 传输层1.3 网络层1.4 数据链路层1.5 物理层 二.分用2.1 物理层2.2 数据链路层2.3 网络层2.4 传输层2.5 应用层 三. 交换机的封装分用四.路由器的封装分用五. 网络中数据传输的单位 在讲解封装与分用前&#xff0c;我们需要先说明一个例子。 例…

【Qt】ubuntu环境下使用命令行安装Qt

起因是我上一篇文章说的&#xff0c;官网下的安装包卡死在第一步安装界面了。 于是我就问GPT有没有纯命令行的安装方式&#xff0c;果然是有的。 在Ubuntu上安装Qt可以使用以下命令&#xff1a; 1. 首先&#xff0c;添加Qt的官方存储库到系统中&#xff1a; sudo add-apt-rep…

如何进行产品的人机交互设计?

产品的人机交互设计是指通过用户界面和用户体验设计来优化产品与用户之间的交互过程&#xff0c;从而提高产品的易用性、可用性和用户满意度。人机交互设计需要考虑用户的需求、行为模式、心理感受以及技术实现&#xff0c;下面我将介绍如何进行产品的人机交互设计。 首先&…

汇川PLC如何连接电脑进行数据通信和远程上下载

准备工作 一台可联网操作的电脑一台单网口的远程透传网关及博达远程透传配置工具网线一条&#xff0c;用于实现网络连接和连接PLC一台汇川PLC及其编程软件InoPrShop一张4G卡或WIFI天线实现通讯(使用4G联网则插入4G SIM卡&#xff0c;WIFI联网则将WIFI天线插入USB口&#xff09…

国科大模式识别与机器学习2015-2019、2021、2023仅考题

2015 &#xff08;8&#xff09;试描述线性判别函数的基本概念&#xff0c;并说明既然有线性判别函&#xff0c;为什么还需要非线性判别函数&#xff1f;假设有两种模式&#xff0c;每类包括6个4维不同的模式&#xff0c;且良好分布。如果他们是线性可分的。问权向量至少需要几…

phpmyadmin 创建服务器

phpmyadmin默认的服务器是localhost 访问setup&#xff0c;创建新的服务器 添加服务器信息 点击应用&#xff0c;服务器创建成功 下载配置文件config.inc.php&#xff0c;放到WWW目录下 可再次访问setup&#xff0c;发现已配置过了 访问登录页面&#xff0c;发现可选…

Python利用Excel读取和存储测试数据完成接口自动化教程

http_request2.py用于发起http请求 #读取多条测试用例#1、导入requests模块import requests#从 class_12_19.do_excel1导入read_data函数from do_excel2 import read_datafrom do_excel2 import write_datafrom do_excel2 import count_case#定义http请求函数COOKIENonedef ht…