redis学习--基础1

来源:互联网 发布:mac桌面出现ds store 编辑:程序博客网 时间:2024/05/16 08:18

Redis是一个速度非常快的非关系型数据库,可以存储键(key)和不同类型的值(value)之间的映射,可以将存储在内存中的键值对数据持久化到硬盘,可以使用复制特性来扩展度性能,还可以使用客户端分片来扩展写功能;与关系型数据库相比:不使用表,它的数据库也不会预定义或者强制去要求用户对redis存储的不通数据进行关联;与memcached相比,性能相差无几,redis能自动以两种不通的方式将数据写入硬盘,并且redis除了能存储普通的字符串之外还能存储其他4中数据结构;一般情况,用户会在redis的性能或者功能是必要的情况下才会将数据存储到redis里(对内存的要求比较高导致费用比较高昂);


Redis支持的5中数据结构:String(可自增自减),List(链表,存储的值有序-一端推入元素一端弹出,可重复),Set(集合,通过使用散列表来保证自己存储的每个字符串都是不相同的,无序),Hash(散列),Zset(有序集合),常用的前两种

1.String

常用命令:  
除了get、set、incr、decr mget等操作外,Redis还提供了下面一些操作:  
获取字符串长度  
往字符串append内容  
设置和获取字符串的某一段内容  
设置及获取字符串的某一位(bit)  
批量设置一系列字符串的内容  
  
应用场景:  
String是最常用的一种数据类型,普通的key/value存储都可以归为此类,value其实不仅是String,  
也可以是数字:比如想知道什么时候封锁一个IP地址(访问超过几次)。INCRBY命令让这些变得很容易,通过原子递增保持计数。  
  
实现方式:  
m,decr等操作时会转成数值型进行计算,此时redisObject的encoding字段为int。  

2.Lsit:一个链表,链表的每个节点都包含了一个字符串

常用命令:  
    lpush,rpush,lpop,rpop,lrange,BLPOP(阻塞版)等。  
  
应用场景:  
    Redis list的应用场景非常多,也是Redis最重要的数据结构之一。  
    我们可以轻松地实现最新消息排行等功能。  
    Lists的另一个应用就是消息队列,可以利用Lists的PUSH操作,将任务存在Lists中,然后工作线程再用POP操作将任务取出进行执行。  
  
实现方式:  
    Redis list的实现为一个双向链表,即可以支持反向查找和遍历,更方便操作,不过带来了部分额外的内存开销,Redis内部的很多实现,包括发送缓冲队列等也都是用的这个数据结构。  
  
RPOPLPUSH source destination  
  
    命令 RPOPLPUSH 在一个原子时间内,执行以下两个动作:  
    将列表 source 中的最后一个元素(尾元素)弹出,并返回给客户端。  
    将 source 弹出的元素插入到列表 destination ,作为 destination 列表的的头元素。  
    如果 source 和 destination 相同,则列表中的表尾元素被移动到表头,并返回该元素,可以把这种特殊情况视作列表的旋转(rotation)操作。  
    一个典型的例子就是服务器的监控程序:它们需要在尽可能短的时间内,并行地检查一组网站,确保它们的可访问性。  
    redis.lpush "downstream_ips", "192.168.0.10"  
    redis.lpush "downstream_ips", "192.168.0.11"  
    redis.lpush "downstream_ips", "192.168.0.12"  
    redis.lpush "downstream_ips", "192.168.0.13"  
    Then:  
    next_ip = redis.rpoplpush "downstream_ips", "downstream_ips"  
  
BLPOP  
  
  假设现在有 job 、 command 和 request 三个列表,其中 job 不存在, command 和 request 都持有非空列表。考虑以下命令:  
  BLPOP job command request 30  #阻塞30秒,0的话就是无限期阻塞,job列表为空,被跳过,紧接着command 列表的第一个元素被弹出。  
  1) "command"                             # 弹出元素所属的列表  
  2) "update system..."                    # 弹出元素所属的值   
  为什么要阻塞版本的pop呢,主要是为了避免轮询。举个简单的例子如果我们用list来实现一个工作队列。执行任务的thread可以调用阻塞版本的pop去获取任务这样就可以避免轮询去检查是否有任务存在。当任务来时候工作线程可以立即返回,也可以避免轮询带来的延迟。  


0 0
原创粉丝点击