ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

开发中为什么要使用Redis缓存

2022-07-27 11:31:32  阅读:166  来源: 互联网

标签:缓存 单机 Redis redis 并发 开发 IO mysql


用缓存,主要有两个用途:高性能高并发

高并发:mysql单机支撑到2000QPS 就开始容易报警了 如果大量的请求直接打到mysql上

将会引起mysql的宕机

而redis 是k-v式操作 单机支撑的并发量高达几万十几万 单机的承载并发量是mysql单机的几十倍

而且redis自身也有较好的容灾性 在master服务器宕机后 可以利用哨兵机制快速选举出一个slave作为

master继续工作

高性能:redis非常快 每秒可执行大概 110000次的set操作 81000次的get操作

有可能一些复杂的sql语句在执行时最多可能耗时几百ms 而使用缓存之后 将查询出来的结果放入

缓存当中 当下次 再有人查 就会直接在缓存中读取 耗时几ms 这就得益于 redis的几个特点 首先mysql会与磁盘进行交互

而redis是纯内存操作 所以非常快 使用了 k-v形式的hashmap的存储形式 时间复杂度都是o(1) 使用了单线程+epoll形式的IO多路复用的IO机制 所以 就避免了上下文切换 以及锁的消耗 而且尽量减少了网络IO的时间消耗 同时redis支持自身的

一定规则的淘汰策略 可以按时清理缓存中的数据量 。

在处理以上两点的问题之上 再选择合适的缓存模式 例如 最常用的 用于读多写少的 旁路缓存模式。

标签:缓存,单机,Redis,redis,并发,开发,IO,mysql
来源: https://www.cnblogs.com/lzbbbb/p/16524227.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有