key 操做
- 删除 key:del key
- 批量删除key:redis-cli -a(密码)keys “QXJ_*”| xargs redis-cli -a(密码)del
- 查看全部的 key(一次性遍历整个数据库,生产上慎重使用):keys [pattern]
利用 cursor 分页查询记录(渐进的遍历整个数据库,生产上推荐):scan cursor [MATCH pattern] [COUNT count]redis
scan 0 match '*order*' count 20
- 序列化给定 key,并返回被序列化的值:dump key
- 检查给定 key 是否存在:exists key
- 为 key 设置过时时间(秒)/ (时间戳)/(毫秒):expire key seconds / expireat key timestamp / pexpire key milliseconds
- 移除 key 的过时时间,key 将持久保存:persist key
- 以毫秒为单位返回 key 的剩余过时时间:pttl key
- 返回 key 所存储的值得类型:type key
- 返回从当前数据库中随机选择的一个key:randomkey
原子的重命名一个key :rename oldkey newkey数据库
Redis 的超时处理机制?
- 当 client 主动访问 key 会先对 key 进行超时判断,过期的 key 会马上删除。
- master 的后台,会每秒作 10 次以下操做 — 随机选取 100 个key校验是否过时,若是有25个以上的 key 过时了,马上额外随机选取下 100 个key(不计算在10次以内)。
Redis 的中文显示问题?
在 redis-cli 中使用中文时,必须打开 --raw 选项,才能正常显示中文。bash
/usr/bin/redis-cli --raw
string 操做
- 保存 key 和 value(nx 表示 key 不存在的时候才赋值,xx 相反):set key value [ex 秒数] / [px 毫秒数] [nx] /[xx]
- 仅当 key 不存在的时候才赋值(经常使用来作分布式锁):setnx key value
- 原子的设置 key 的值,并返回 key 的旧值(配合 setnx 实现分布式锁):getset key value
- 批量设置 key、value 的值:mset key1 value1 ... keyN valueN
- 获取/批量获取 value 值:get key / mget key1....keyN
- 对 key 的值作加1或减1操做:incr/decr key
- 对 key 的值指定加/减某个数值:incrby/decrby key integer、incrbyfloat key floatnumber
- 对 key 的 value 追加值:append key value
- 返回截取过的 key 的字符串值,注意并不修改 key 的值:substr key start end
- 位操做(位置相反,右边表示低位,offset 过大,则会在中间填充0):setbit key offset value、getbit key offset
list 操做
- 向列表左边插入元素:lpush key value [value ...]
- 从列表右边移出元素:rpop key
在 key 对应 list 的特定位置以前或以后添加字符串元素:linsert key before|after pivot value数据结构
linsert mylist before "world" "there"
- 返回 key 对应 list 的长度:llen key
- 经过索引获取列表中的元素:lindex key index
- 获取列表指定范围内的元素(-1 表示最后一个元素):lrange key start end
- 保留指定区间内元素:ltrim key start end
- 设置list中指定下标的元素值:lset key index value
从列表右边移出元素的阻塞方式,采起先到先服务原则,timeout 未获取到则返回 nil:brpop key [key ...] timeoutapp
set 操做
- 添加元素:sadd key value
- 移除元素,成功返回1:srem key
- 移除集合中的一个随机元素并返回:spop key
- 返回集合中一个或多个随机数:srandmember key count
- 根据 key 得到集合中的全部成员:smembers key
- 判断 member 是否在 set 中:sismember key member
- 获取集合的成员数:scard key
- 把 member 从 source 集合转移到 des 集合:smove source des member
- 返回给定集合的差集:sdiff key1 key2
- 返回给定集合的并集:sunion key1 key2
- 返回给定集合的交集:sinter key1 key2...keyN
zset 操做
hash 操做
- 存储/批量存储 hash 值:hset key field value / hmset key field1 value1 field2 value2
- 获取/批量获取 hash 值:hget key field / hmget key filed1....fieldN
- 获得 hash 中的全部值:hgetall key
- 测试指定 field 是否存在:hexists key field
- 删除一个或多个哈希字段:hdel key field1 [field2]
- 返回 hash 的全部 field:hkeys key
- 返回指定 hash 的 field 数量:hlen key
HyperLogLog 操做
HyperLogLog 主要解决大数据应用中的非精确计数(可能多也可能少,可是会在一个合理的范围) 操做,它能够接受多个元素做为输入,并给出输入元素的基数估算值,基数指的是集合中不一样元素的数量。分布式
HyperLogLog 的优势是,即便输入元素的数量或者体积很是很是大,计算基数所需的空间老是固定的、而且是很小的。在 Redis 里面,每一个 HyperLogLog 键只须要花费 12 KB 内存,就能够计算接近 2^64 个不一样元素的基数。关于数据偏差,在一个大小为 12k 的 key 所存储的 hyperloglog 集合基数计算的偏差约是 0.81%。函数
由于 HyperLogLog 只会根据输入元素来计算基数,而不会储存输入元素自己,因此 HyperLogLog 不能像集合那样,返回输入的各个元素。测试
HyperLogLog 的这个数据结构能够很是省内存的去统计各类计数,好比注册 IP 数、每日访问 IP 数、页面实时UV 、在线用户数等。大数据
- 将元素添加至 HyperLogLog :pfadd key element [element ...]
- 返回给定 HyperLogLog 的基数估算值(多个 HyperLogLog 会先对 HyperLogLog 做并集处理):pfcount key [key ...]
- 合并多个 HyperLogLog:pfmerge destkey sourcekey [sourcekey ...]