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去获取任务这样就可以避免轮询去检查是否有任务存在。当任务来时候工作线程可以立即返回,也可以避免轮询带来的延迟。
- redis学习--基础1
- redis 学习--基础1 build and run
- Redis基础学习笔记
- redis的基础学习
- redis 基础学习
- redis基础学习
- redis基础学习总结
- Redis基础学习
- redis基础学习
- Redis学习笔记之redis基础
- Redis学习笔记之redis基础
- redis 学习篇(基础)
- 学习redis基础命令网站
- Redis零起点-探索Redis,学习Redis基础用法
- Redis-基础-1
- Redis基础(1)
- redis数据库1-基础
- redis学习系列(三-1)--redis基础类型初探(字符串)
- spring事物配置,声明式事务管理和基于@Transactional注解的使用
- Unreal Engine 4 —— 使用ProceduralMeshComponent实现模型实时切割
- CentOS 关闭防火墙和SELINUX配置
- opacity兼容ie8
- /etc/ld.so.conf 动态库
- redis学习--基础1
- 陆辰妮
- 多元线性回归的python实现
- JavaScript typeof() 这个函数是干什么用的?有几个参数,每个参数代表什么?
- RPC
- 如何使用CSS栅格布局创建一个简单页面布局
- 在Linux下使用gradle自动打包
- Spring Java ajaxfileupload.js 上传头像 3.0
- dwr WebContextFactory 工厂模式