缓存雪崩 和 缓存穿透 问题及解决方案----->(浅谈)
缓存雪崩: 缓存同一时间大面积的失败,所以后面的请求都会落到数据库上,造成数据库短时间内承受大量请求而崩掉
解决方案: 事前:尽量保证整个redis集群的高可用性,发现机器宕机尽快补上
事中:本地ehcache缓存+hystrix限流&降级,避免MySQL崩掉
事后:利用redis持久化机制保存的数据尽快恢复缓存
缓存穿透: 简答点说就是大量请求的Key根本不存在于缓存中,导致请求直接到了数据库上,根本没有经过缓存这一次层.
解决方案: 最基本的就是首先做好参数校验,一些不合法的参数请求直接抛出异常信息返回给客户端.比如查询的数据库id不能小于0,传入的邮箱格式不对的时候直接返回错误消息给客户端等等.
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
死信队列和延迟队列的使用?
死信消息: 1.消息被拒绝(Basic.Reject或Basic.Nack)并且设置 requeue 参数的值为 false 2.消息过期了 3.队列达到最大的长度 过期消息: 在 rabbitmq 中存在2种方可设置消息的过期时间 第一种通过队列设置:在队列申明的时候使用 x-message-ttl 参数,单位为毫秒,这种设置后,该队列中所有的消息都存在相同的过期时间 第二种通过对单个消息设置,是设置消息属性的 expiration 参数的值,单位为毫秒。那么每条消息的过期时间都不一样。 如果同时使用这2种方法,那么以过期时间小的那个数值为准。当消息达到过期时间还没有被消费,那么那个消息就成为了一个 死信 消息。 延时队列:在rabbitmq中不存在延时队列,但是我们可以通过设置消息的过期时间和死信队列来模拟出延时队列。消费者监听死信交换器绑定的队列,而不要监听消息发送的队列。 有了以上的基础知识,我们完成以下需求: 需求:用户在系统中创建一个订单,如果超过时间用户没有进行支付,那么自动取消订单。 分析: 1、上面这个情况,我们就适合使用延时队列来实现,那么延时队列如何创建 2、延...
- 下一篇
PHP + Redis 实现简单消息队列
Redis做消息队列的好处在于它的轻量级,高并发,延迟敏感,应用场景有 即时数据分析、秒杀计数器、缓存等 Redis做消息队列待解决的问题: 1、消息的可靠性: 没有相应的机制保证消息的消费,当消费者消费失败的时候,消息体丢失,需要手动处理。生产者只管向队列中插入数据,不管消费者是否成功消费。 2、消费者挂掉消息不会丢失,但是需要重新触发一下消费者,才能够继续消费消息。 代码如下: lib.php是工具文件,里面有数据库的连接、Redis的连接: <?php /** * 获取数据库连接 * * @param $host * @param $username * @param $password * @param $database * @return mysqli */ function getDBConnection($host, $username, $password, $database){ $connection = new mysqli('p:'.$host, $username, $password, $database); if (!$co...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- CentOS8安装Docker,最新的服务器搭配容器使用
- CentOS7安装Docker,走上虚拟化容器引擎之路
- Linux系统CentOS6、CentOS7手动修改IP地址
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- Docker安装Oracle12C,快速搭建Oracle学习环境
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS7,CentOS8安装Elasticsearch6.8.6