redis 常用命令
redis 介绍
1、基于内存key-value 的非关系型数据库
2、基于c语言编写的,可以支持多种语言api //set 每秒11万次,取get 81000 次
3、支持数据持久化
4、多种数据类型:string 、hash、list 、set、sorted set
使用场景:
1、取最新的n个数据的操作
2、排行榜,取top n个数据 //最佳人气前10
3、精确的设置过期时间
4、计数器
5、实时系统、反垃圾系统
6、pub、sub发布订阅构建实时消息系统
7、构建消息队列
8、缓存
String:缓存、限流、计数器、分布式锁、分布式session
Hash:存储用户信息、用户主页访问量、组合查询
List:微博关注人时间轴列表、简单队列
Set:赞、踩、标签、共同好友
Zset: 排行榜
cmd 下访问redis
redis-cli.exe -h host -p port -a password
加 --raw 防止中文乱码
退出当前返回到windows命令:quit
key
key * 获取所有的key
select 0 选择第一个库
move myString 1 将当前的数据库key移动到某个数据库、目标库由、则不能移动
flush db 清除指定库
randomkey 获取随机key 的值
type key 获取键对应的值类型
set key1 value1 设置key
get key1 获取key
mset key1 value1 [key2 value2] 批量设置
mget key1 key2 批量获取
del key1 删除 key
exists key 判断是否存在key
expire key 10 设置key10秒过期
pexpire key 10 设置key 10 毫秒过期
数据类型及命令
一、String
set keyname value1 设置
get keyname 获取
getrange name 0 -1 字符串分段
getset keyname new_value 设置新值、返回旧值
mset key1 value1 [key2 value2 ] 批量设置
setnx key value 不存在就插入,存在就插入失败
setex key time value 设置key 同时设置 过期时间
setrange key index value 从指定下标替换值
incr key 给key对应的值递增
incrby key 10 给key 对应的值按所给的量递增
decr key 递减
decrby key 10 按指定值递减
incrbyfloat key 10.2 增减浮点数
append key value 给key对应的值追加value
strlen key 获取key值长度
getbit/setbit/bitcount/bitop 位操作
二、Hash
hset key field value 一个key一个字段
hget key name 获取 指定key指定字段的值
hmset key field value [field value] 批量设置(name haha age 18 sex "男")
hmget key field1 filed2 filed3 批量获取key对应字段值
hgetall key 获取所有(字段和值)
hexists key filed 查看字段是否存在
hsetnx key filed value 设置key 中不存在的field
hincrby key filed 1 字段递增1
hdel key filed 删除字段
hkeys key 获取key对应的所有字段
hvals key 获取key对应字段中的所有值
hlen key 长度
三、List
lpush key 1 2 3 左插入
rpush key 4 5 6 右插入
lrange key 0 1 数据集合
l'pop key 从左弹出元素
rpop key 从右弹出元素
llen key 长度
lrem key count value 删除
lindex key 2 获取指定索引的值
lset key 2 n 给指定索引设值
ltrim key start stop 从指定位置start 删除到stop中的值
linsert key before a 在最前面插入a
linsert key after a 在后面插入a
rpoplpush list list2 转移列表的数据
四、set
sadd key aa bb cc cuan 创建集合 (aa bb cc)
smembers key 获取集合
srem key member 删除集合成员
sismember key member1 判断成员member1是否在集合中
scard key 集合成员个数
sdiff key1 key2 ... 取两个或多个集合差集
sinter key1 key2 ... 取两个或多个集合交集
sunion key1 key2 ... 取两个或多个集合并集
srandmember 随机获取集合中的元素
spop 从集合中弹出一个元素
五、zset
zadd zset 1 one
zadd zset 2 two
zadd zset 3 three
zincrby zset 1 one 增长分数
zscore zset two 获取分数
zrange zset 0 -1 withscores 范围值
zrangebyscore zset 10 25 withscores 指定范围的值
zrangebyscore zset 10 25 withscores limit 1 2 分页
Zrevrangebyscore zset 10 25 withscores 指定范围的值
zcard zset 元素数量
Zcount zset 获得指定分数范围内的元素个数
Zrem zset one two 删除一个或多个元素
Zremrangebyrank zset 0 1 按照排名范围删除元素
Zremrangebyscore zset 0 1 按照分数范围删除元素
Zrank zset 0 -1 分数最小的元素排名为0
Zrevrank zset 0 -1 分数最大的元素排名为0
Zinterstore
zunionstore rank:last_week 7 rank:20150323 rank:20150324 rank:20150325 weights 1 1 1 1 1 1 1
排序
sort listkey(列表key) 默认asc排序
sort listkey alpaha desc limit 0 2 字母排序
sort list by it:* desc 倒序
sort list by it:* desc get it:* get参数
sort list by it:* desc get it:* store sorc:result sort命令之store参数:表示把sort查询的结果集保存起来
订阅与发布:
订阅频道:subscribe chat1
发布消息:publish chat1 "hell0 ni hao"
查看频道:pubsub channels
查看某个频道的订阅者数量: pubsub numsub chat1
退订指定频道: unsubscrible chat1 , punsubscribe java.*
订阅一组频道: psubscribe java.*
redis事物:
隔离性,原子性,
步骤: 开始事务,执行命令,提交事务
multi //开启事务
sadd myset a b c
sadd myset e f g
lpush mylist aa bb cc
lpush mylist dd ff gg
服务器管理
dump.rdb
appendonly.aof
//BgRewriteAof 异步执行一个aop(appendOnly file)文件重写
会创建当前一个AOF文件体积的优化版本
//BgSave 后台异步保存数据到磁盘,会在当前目录下创建文件dump.rdb
//save同步保存数据到磁盘,会阻塞主进程,别的客户端无法连接
//client kill 关闭客户端连接
//client list 列出所有的客户端
//给客户端设置一个名称
client setname myclient1
client getname
config get port
//configRewrite 对redis的配置文件进行改写
rdb
save 900 1
save 300 10
save 60 10000
aop备份处理
appendonly yes 开启持久化
appendfsync everysec 每秒备份一次
命令:
bgsave异步保存数据到磁盘(快照保存)
lastsave返回上次成功保存到磁盘的unix的时间戳
shutdown同步保存到服务器并关闭redis服务器
bgrewriteaof文件压缩处理(命令)