redisi redis经典系列

Redis系列第一篇之SPEC协议上面的编码结果包含两个元素的数组,第一个元素由(1,2,3)构成的子数组,第二个元素由一个Bulk String(+Hello)和一个Error(-World)组成的数组 。一个Array的单个元素可能为NULL 。
因为SSL规定通信双方直到他们发送或收到更改密码规格协议信息时才能开始使用前面已经协商好的密码套件 。这个协议只是一个开始使用加密的标志,它应该是握手协议完成的表现 。
在spec相比deployment多了一个serviceName配置 , 该值就是对应的headless service 。
Finagle:一个允许开发者使用Java、Scala或其他JVM语言来构建异步RPC服务器和客户端的库,主要用于Twitter的后端服务 。iago:一个负载生成器 , 用来在产品正式发布前做流量负载测试 。
Redis的LRU缓存淘汰算法实现在实现LRU算法过程中 , 无非两种操作,查找和修改,使用散列数组实现查找时间复杂度为O(1) , 使用双向链表实现修改复杂度为O(1),并且双向链表还可以维护访问顺序,所以使用这种方式 , 可以达到O(1) 。
当要缓存某个数据的时候,先在链表中查找这个数据 。如果没有找到,则直接将数据放到链表的尾部;如果找到了,我们就把它移动到链表的尾部,然后淘汰头部数据 。
Redis 内存淘汰机制有以下几种策略:noeviction:当内存不足以容纳新写入数据时,新写入操作会报错 。(Redis 默认策略)allkeys-lru:当内存不足以容纳新写入数据时,在键空间中,移除最近最少使用的 Key 。
LRU (less recently used)是Redis唯一支持的回收算法,当缓存占用的内存空间达到设置的最大空间时,会自动驱逐老的数据 。
譬如,在一台 8G 机子上部署了 4 个 redis 服务点,每一个服务点分配 5G 的内存大小 , 减少内存紧张的情况,由此获取更为稳健的服务 。
如何用redis实现分布式锁1、如果想要实现可重入的分布式锁的话,需要在设置value的时候加上线程信息和加锁次数的信息 。但是这是简单的思路 , 如果加上过期时间等问题之后,可重入锁就可能比较复杂了 。
2、事务1加个三个行锁和间隙锁 。场景1,场景3会发生锁等待。间隙锁与查询不冲突 ,  场景2不会锁等待 。分析: RC隔离级别: 事务1加的都是行锁 。场景1会发生锁等待,场景2 , 场景3不会发生锁等待 。
3、使用分布式锁要满足的几个条件:系统是一个分布式系统(关键是分布式,单机的可以使用ReentrantLock或者synchronized代码块来实现)共享资源(各个系统访问同一个资源,资源的载体可能是传统关系型数据库或者NoSQL) 。
4、原理很简单 , set 一个 锁-key,如果成功则说明加锁成功,反之则失败 。
5、那这时候,我们就需要一个跨平台、跨语言的加锁方式 。redis就是其中最方便的一种 。使用redis实现并发锁,主要是靠两个redis的命令:setnx和getset 。
6、此时就需要使用分布式锁了 。简而言之,分布式锁就是用来控制同一时刻,只有一个线程可以访问被保护的资源 。可以使用 SETNX key value 命令实现互斥的特性 。
Redis怎么实现分布式锁1、如果没有其他线程占用,则就可以通过添加分布式锁来占用这个资源,然后再执行后续的任务,在任务执行完成之后,再释放分布式锁,其他线程就可以继续使用这个资源了 。
2、使用分布式锁要满足的几个条件:系统是一个分布式系统(关键是分布式,单机的可以使用ReentrantLock或者synchronized代码块来实现)共享资源(各个系统访问同一个资源 , 资源的载体可能是传统关系型数据库或者NoSQL) 。
3、requestId:这个东西实际上就是用来标识他是哪一个请求进行的加锁,因为在分布式锁中 , 我们要知道一件事,就是加锁的和解锁的,必须是同一个客户端才可以 。
Redis的Setnx命令实现分布式锁可以在再次获取锁时,如果锁被占用就get值,判断值是否是当前线程存的随机值,如果是则再次执行 set 命令重新上锁;当然为了保证原子性这些操作都要用 lua 脚本来执行 。
释放锁时,删除相应的记录 。基于Redis的分布式锁使用Redis的SETNX命令(Set if Not eXists)来实现分布式锁 。SETNX命令在键不存在时设置值,并返回1;如果键已存在,不执行任何操作,并返回0 。
SETNX不同:SETNX(SETifNoteXists),该命令在key不存在时设置key的值 , 如果key存在,不做任何操作 。Redishash数据结构可以存储多个键值对,所以我们可以使用Redishash实现分布式锁 。
使用redis实现并发锁,主要是靠两个redis的命令:setnx和getset 。那我们的设计思路就是:上面的代码使用了一个RedisService的类,里面主要是简单封装了一下redis的操作 , 你可以替换为自己的service 。
【redisi redis经典系列】命令是: setnx expire 添加分布式锁的同时,添加一个锁锁过期的时间 。这样,当加锁线程退出之后 , 至少等一段时间之后,锁是有机会释放掉的 。这里有一个小问题是,这两个命令是分开执行的 , 不是原子操作 。

    推荐阅读