菜鸟笔记
提升您的技术认知

Redis 笔记 第5页

Redis数据结构之HperLogLog

菜鸟阅读 : 2229赞(1)

一、HyperLogLog HyperLogLog是用来做基数统计的。 其可以非常省内存的去统计各种计数,比如注册ip数、每日访问IP数、页面实时UV(PV肯定字符串就搞定了)、在线用户数等在对准确性不是很重要的应用场景。   H...

布隆过滤器的方式解决缓存穿透问题

菜鸟阅读 : 2435赞(1)

1、原理 布隆过滤器的巨大用处就是,能够迅速判断一个元素是否在一个集合中。因此他有如下三个使用场景: 网页爬虫对URL的去重,避免爬取相同的URL地址 反垃圾邮件,从数十亿个垃圾邮件列表中判断某邮箱是否垃圾邮箱(同理,垃圾短信) 缓存穿透,...

缓存穿透,缓存击穿,缓存雪崩解决方案分析

菜鸟阅读 : 1436赞(2)

前言 设计一个缓存系统,不得不要考虑的问题就是:缓存穿透、缓存击穿与失效时的雪崩效应。 缓存穿透 缓存穿透是指查询一个一定不存在的数据,由于缓存是不命中时被动写的,并且出于容错考虑,如果从存储层查不到数据则不写入缓存,这将导致这个不存在的数...

REDIS缓存穿透,缓存击穿,缓存雪崩详解

菜鸟阅读 : 1533赞(1)

一、前言 在我们日常的开发中,无不都是使用数据库来进行数据的存储,由于一般的系统任务中通常不会存在高并发的情况,所以这样看起来并没有什么问题,可是一旦涉及大数据量的需求,比如一些商品抢购的情景,或者是主页访问量瞬间较大的时候,单一使用数据库...

redis分布式锁深度剖析

菜鸟阅读 : 1720赞(1)

redis分布式锁的实现主要是基于redis的setnx 命令(setnx命令解释见:http://doc.redisfans.com/string/setnx.html),我们来看一下setnx命令的作用: 1、redis分布式锁的基本实...

Redis的并发竞争问题

菜鸟阅读 : 1669赞(1)

Redis的并发竞争问题,主要是发生在并发写竞争。 考虑到redis没有像db中的sql语句,update val = val + 10 where ...,无法使用这种方式进行对数据的更新。 假如有某个key = "price", &nb...

Redis 单线程 为何却需要事务处理并发问题

菜鸟阅读 : 1854赞(1)

Redis是单线程处理,也就是命令会顺序执行。那么为什么会存在并发问题呢? 个人理解是,虽然redis是单线程,但是可以同时有多个客户端访问,每个客户端会有 一个线程。客户端访问之间存在竞争。 简单的总结下,其实redis本事是不会存在并发...

Redis常见对象类型的底层数据结构

菜鸟阅读 : 1035赞(1)

Redis是一个基于内存中的数据结构存储系统,可以用作数据库、缓存和消息中间件。Redis支持五种常见对象类型:字符串(String)、哈希(Hash)、列表(List)、集合(Set)以及有序集合(Zset),我们在日常工作中也会经常使用...

redis做消息队列

菜鸟阅读 : 1856赞(1)

Redis消息队列 在程序员这个圈子打拼了太多年,见过太多的程序员使用redis,其中一部分喜欢把redis做缓存(cache)使用,其中最典型的当属存储用户session,除此之外,把redis作为消息队列使用也不在少数,可见redis在...

15张图解Redis为什么这么快

菜鸟阅读 : 1259赞(2)

作为一名服务端工程师,工作中你肯定和 Redis 打过交道。Redis 为什么快,这点想必你也知道,至少为了面试也做过准备。很多人知道 Redis 快仅仅因为它是基于内存实现的,对于其它原因倒是模棱两可。 那么今天就和菜鸟一起看看: 基于内...