有趣的小知识(三)提升网站速度的秘诀:掌握缓存基础,让你的网站秒开

news2024/12/23 15:16:19

 像MySql等传统的关系型数据库已经不能适用于所有的业务场景,比如电商系统的秒杀场景,APP首页的访问流量高峰场景,很容易造成关系型数据库的瘫痪,随着缓存技术的出现很好的解决了这个问题。

一、缓存的概念(什么是缓存)

缓存是计算机系统中用于提高数据访问速度的技术。缓存通常是一种高速存储器,用于把访问量较高的热点数据从传统的关系型数据库中加载到内存中,当用户再次访问热点数据时是从内存中加载,减少了对数据库的访问量,解决了高并发场景下容易造成数据库宕机的问题。

缓存工作原理

在缓存中存储数据的副本,当需要访问这些数据时,首先在缓存中查找,如果缓存中有这些数据的副本,则直接从缓存中取出,从而避免了从较慢的主存中读取数据的时间延迟。如果缓存中没有需要的数据,则需要从主存中读取,但读取的数据会被缓存,以便下次访问时更快地获取。

二、为什么要用缓存(为什么要用redis作为缓存)

原因

1.提高访问速度:缓存通常是一种高速存储器,能够更快地访问数据,因为它们通常比主存或者磁盘更接近处理器,可以更快地传输数据,从而可以提高计算机系统的响应速度。

2.减轻负载:缓存可以减轻计算机系统的负载,因为数据不需要每次都从主存或者磁盘读取。如果数据可以从缓存中获取,那么就可以减少系统访问主存或磁盘的次数,从而减少对系统的负载,提高系统的可扩展性。

3.降低能耗:缓存可以降低能耗,因为从缓存中读取数据比从主存或磁盘中读取数据更快,可以更快地完成任务,从而减少了处理器的工作时间,节省了能耗。

4.提高性能:通过使用缓存,可以将热点数据存储在更快的存储器中,从而减少了访问这些数据的时间延迟,提高了计算机系统的性能和效率。

5.高并发场景下:操作缓存能够承受的并发访问量是远远大于访问数据库的,比如redis,它的读的速度是110000次/s,写的速度是81000次/s。所以说将数据库中访问量高的数据存储到缓存中,用户请求的时候直接访问数据库,不必访问数据库,提高应用程序的并发量。

综上所述,使用缓存可以显著提高计算机系统的性能、减轻负载、降低能耗和提高可扩展性。


redis

Redis是一种开源的高性能键值存储系统可以在内存中存储数据,并通过网络访问。Redis支持多种数据结构,包括字符串、哈希、列表、集合、有序集合等,而且它提供了丰富的命令,可以对这些数据结构进行灵活的操作。除此之外,Redis还支持事务、持久化、复制、脚本执行、订阅与发布等高级功能。

Redis最初由Salvatore Sanfilippo开发,并且被广泛用于缓存、队列、计数器、排行榜、实时分析等场景。Redis的高性能和灵活性使得它成为流行的解决方案,被广泛应用于Web应用程序、移动应用程序、物联网等领域。同时,Redis的主从复制和集群模式可以扩展到多台服务器上,并具有良好的可扩展性和高可用性。

三、缓存的分类有哪些

根据缓存的位置和作用,可以将缓存分为以下几类:

1.浏览器缓存:浏览器缓存是指浏览器将之前访问过的网页、图片、脚本等资源保存到本地磁盘中,下次访问同样的资源时可以从本地磁盘中读取,从而加快页面加载速度。

2.代理服务器缓存:代理服务器缓存是指代理服务器将之前请求过的资源缓存到本地磁盘或内存中,下次请求同样的资源时可以从本地磁盘或内存中读取,从而减少网络带宽的消耗和请求的响应时间。

3.应用服务器缓存:应用服务器缓存是指应用服务器将之前查询过的数据或计算过的结果缓存到内存中,下次请求同样的数据或计算结果时可以直接从缓存中读取,从而加快响应时间。

4.数据库缓存:数据库缓存是指数据库将之前查询过的数据缓存到内存中,下次查询同样的数据时可以直接从内存中读取,从而加快查询速度。

5.分布式缓存:分布式缓存是指将缓存数据分散到多台服务器上,从而可以扩展缓存的容量和性能,提高缓存的可靠性和可扩展性。

6.本地缓存是指将数据缓存在客户端本地的存储介质中,例如浏览器中的本地存储(Local Storage)、Session Storage、IndexedDB、Web SQL等。本地缓存能够在浏览器关闭后依然保留,也可以在下次用户访问时快速加载。

相对于服务器端的缓存,本地缓存的优点是可以减少服务器端的压力,提高网站或应用程序的性能和响应速度。当用户再次访问同样的页面或数据时,可以直接从本地缓存中读取数据,而不必再次向服务器发送请求。

在Web开发中,本地缓存通常被用于存储一些静态的、不经常变化的数据,例如网站的Logo、样式表、JavaScript库、用户偏好设置等。同时,本地缓存也可以用于离线应用程序的开发,使得应用程序能够在没有网络连接的情况下继续工作,提高用户体验。

需要注意的是,本地缓存虽然能够提高网站或应用程序的性能和响应速度,但是缓存数据可能会过期或失效,因此需要在合适的时机清除缓存数据,以保证数据的正确性和一致性。

7.多级缓存

基于本地缓存和分布式缓存的优缺点,多级缓存应运而生,在实际的业务开发中一般也是采用多级缓存。注意:本地缓存一般存储更新频率低,访问频率高数据,分布式缓存一般存储更新频率很高的数据。

多级缓存的请求流程:本地缓存作为一级缓存,分布式缓存作为二级缓存;当用户获取数据时,先从一级缓存中获取数据,如果一级缓存有数据则返回数据,否则从二级缓存中获取数据。如果二级缓存中有数据则更新一级缓存,然后将数据返回客户端。如果二级缓存没有数据则去数据库查询数据,然后更新二级缓存,接着再更新一级缓存,最后将数据返回给客户端。

以上是常见的缓存分类,不同的缓存类型适用于不同的应用场景,可以根据具体需求选择合适的缓存方案。

 四、通过缓存,提升网站速度

通过缓存可以提升网站的速度和性能,以下是一些常用的缓存技术和方法:

1.浏览器缓存:使用浏览器缓存可以加快网页的加载速度。可以通过设置HTTP响应头的Cache-Control和Expires字段,控制浏览器缓存的时间和内容。对于不经常更新的静态资源,例如图片、样式表、JavaScript库等,可以设置较长的缓存时间,减少浏览器的请求次数。

2.CDN缓存:使用CDN可以将网站的静态资源分布到全球各个节点上,从而加速资源的加载速度。CDN节点会缓存网站的静态资源,当用户访问网站时,会从距离最近的CDN节点获取资源,从而减少网络延迟和带宽消耗。

3.服务器端缓存:使用服务器端缓存可以加速动态内容的生成和响应。可以使用缓存中间件,例如Redis、Memcached等,将计算过的结果缓存到内存中,下次请求时可以直接从缓存中获取数据,从而减少数据库的查询次数和响应时间。

4.数据库查询缓存:对于频繁查询但是不经常更新的数据,例如用户信息、产品信息等,可以使用数据库查询缓存技术,将查询结果缓存到内存中,下次查询同样的数据时可以直接从缓存中获取数据,从而减少数据库的查询次数和响应时间。

5.前端性能优化:对于前端页面,可以采用一些性能优化技巧,例如压缩静态资源、使用CSS Sprite技术、异步加载JavaScript等,从而减小页面的体积和请求次数,加快页面的加载速度。

通过以上缓存技术和方法,可以有效地提升网站的速度和性能,改善用户体验,提高网站的可用性和可靠性。

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

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

相关文章

PyTorch保姆级安装教程

1 安装CUDA1.1 查找Nvidia适用的CUDA版本桌面右键,【打开 NVIDIA控制面板】查看【系统信息】查看NVIDIA的支持的CUDA的版本,下图可知支持的版本是 10.11.2 下载CUDACUDA下载官方网址https://developer.nvidia.com/cuda-toolkit-archive找到适合的版本下载…

第六章 effect.scheduler功能实现

effect.scheduler功能实现 主要先了解scheduler需要实现什么样的需求,有一下四点: 1 通过 effect 的第二个参数给定一个 scheduler 的 fn 2 effect 第一次执行的时候 还会执行 fn 3 当 响应式对象 set update 不执行fn 而是执行 scheduler 4 如果说…

面试问题【线程】

线程什么是进程什么是线程进程和线程的关系什么是并发和并行如何使用线程Thread 和 Runnable 两种开发线程的区别线程的生命周期什么是上下文切换什么是线程死锁如何避免死锁说说 sleep() 方法和 wait() 方法区别和共同点为什么我们调用 start() 方法时会执行 run() 方法&#…

Transformer学习

原论文:Attention Is All You Need。论文地址:https://arxiv.org/abs/1706.03762. Transformer是针对自然语言处理的,Google在2017年发表在Computation and Language,RNN模型记忆长度有限且无法并行化但是Tranformer解决了上述问…

解析几何北大第五版复习提纲

第一章 两向量向量积 向量积定义:a x b |a||b|sin几何意义:平行四边形面积性质: 两向量共线的充分必要条件是 a x b 0 数乘: 分配律: 求法:行列式 三向量混合积 混合积定义:对于一个六面体,…

快鲸SCRM发布口腔企业私域运营解决方案

口腔企业普遍面临着以下几方面运营痛点问题 1、获客成本居高不下,恶性竞争严重 2、管理系统落后,人员流失严重 3、客户顾虑多、决策时间长 4、老客户易流失,粘性差 以上这些痛点,不得不倒逼口腔企业向精细化运营客户迈进。 …

【LeetCode】剑指 Offer 21. 调整数组顺序使奇数位于偶数前面 p131 -- Java Version

题目链接:https://leetcode.cn/problems/diao-zheng-shu-zu-shun-xu-shi-qi-shu-wei-yu-ou-shu-qian-mian-lcof/ 1. 题目介绍(21. 调整数组顺序使奇数位于偶数前面) 输入一个整数数组,实现一个函数来调整该数组中数字的顺序&…

4自由度串联机械臂按颜色分拣物品功能的实现

1. 功能说明 本实验要实现的功能是:将黑、白两种颜色的工件分别放置在传感器上时,机械臂会根据检测到的颜色,将工件搬运至写有相应颜色字样区域。 2. 使用样机 本实验使用的样机为4自由度串联机械臂。 3. 运动功能实现 3.1 电子硬件 在这个…

快速吃透π型滤波电路-LC-RC滤波器

π型滤波器简介 π型滤波器包括两个电容器和一个电感器,它的输入和输出都呈低阻抗。π型滤波有RC和LC两种, 在输出电流不大的情况下用RC,R的取值不能太大,一般几个至几十欧姆,其优点是成本低。其缺点是电阻要消耗一些…

亚马逊二审来袭,跨境电商传统验证算法真的靠谱吗?

多个大卖突遭二审 已有卖家账号被封 近期有不少卖家在论坛上反映称自己收到了亚马逊的二次视频验证邮件。 邮件上称: 卖家必须要完成额外的身份审查,才有资格在亚马逊继续销售商品;亚马逊要求卖家出示注册时提交的身份证原件和营业执照原件…

聊聊混沌工程

这是鼎叔的第五十四篇原创文章。行业大牛和刚毕业的小白,都可以进来聊聊。欢迎关注本专栏和微信公众号《敏捷测试转型》,大量原创思考文章陆续推出。混沌工程是一门新兴学科,它不仅仅只是个技术活动,还包含如何设计能够持续协作的…

xgboost:算法数学原理

xgboost算法数学原理 1、求预测值 y^iϕ(xi)∑k1Kfk(xi),fk∈F,(1)\hat{y}_i\phi\left(\mathbf{x}_i\right)\sum_{k1}^K f_k\left(\mathbf{x}_i\right), \quad f_k \in \mathcal{F},\tag{1} y^​i​ϕ(xi​)k1∑K​fk​(xi​),fk​∈F,(1) F{f(x)wq(x)}(q:Rm→T,w∈RT)\mathca…

即时通讯开发常用加解密算法与通讯安全

平时开发工作中,我们会经常接触加密、解密的技术。尤其在今天移动互联网时代,越来越多的用户会将数据存储在云端,或使用在线的服务处理信息。这些数据有些涉及用户的隐私,有些涉及用户的财产,要是没有一套的方案来解决…

玩转结构体---【C语言】

⛩️博主主页:威化小餅干📝系列专栏:【C语言】藏宝图🎏 ✨绳锯⽊断,⽔滴⽯穿!一个编程爱好者的学习记录!✨目录结构体类型的声明结构体成员访问结构体传参前言我们是否有想过,为什么会有结构体呢…

stylelint执行插件的全过程

stylelint可以用来扩展插件去实现各种规则,接下来带大家看看stylelint是如何执行插件的 首先遍历absoluteFilePaths路径(该路径是我们执行lint命令配置的文件类型eslint --cache --max-warnings 0 \"{src,mock}/**/*.{vue,ts,tsx}\" --fix&…

Spark RDD

RDD RDD 是构建 Spark 分布式内存计算引擎的基石,如 :DAG/调度系统都衍生自 RDD RDD 是对分布式数据集的抽象,囊括所有内存/磁盘的分布式数据实体 RDD/数组差异 对比项数组RDD概念数据结构实体数据模型抽象数据跨度单机进程内跨进程&…

GC简介和监控调优

GC简介: GC(Garbage Collection)是java中的垃圾回收机制,是Java与C/C的主要区别之一,在使用JAVA的时候,一般不需要专门编写内存回收和垃圾清理代 码。这是因为在Java虚拟机中,存在自动内存管理和垃圾清扫机制。 什么…

ThreadLoca基本使用以及与synchronized的区别

文章目录1. ThreadLocal介绍1.1 官方介绍1.2 基本使用1.2.1 常用方法1.2.2 使用案例1.3 ThreadLocal类与synchronized关键字1.3.1 synchronized同步方式1.3.2 ThreadLocal与synchronized的区别2. 运用场景_事务案例2.1 转账案例2.1.1 场景构建2.1.2 引入事务2.2 常规解决方案2.…

k8s servelList(服务列表) 卡死不同步问题分析

提要容器集群版本情况:k8s 1.20客户端k8s client版本: 0.21事情是这样的,运行了一年的服务,突然有一天业务反馈服务使用异常,然后初步调查结果如下以下截图是网关异常以下截图是客户端zull(feign&#xff0…

依赖倒置DIP在系统架构中的应用

最近在对项目中的某一模块进行重构和功能的拓展。一直没想到好方法。 简单理解为: R项目 调用了 E项目的打印接口,但是E项目需要对R传来对数据传输对象DTO进行二次处理,甚至夹杂很多R项目的业务逻辑(去调用R项目的接口&#xff0…