redist 3 常用命令

Redis常用命令集
1)连接操作命令

quit:关闭连接(connection)
auth:简单密码认证
help cmd: 查看cmd帮助,例如:help quit

2)持久化

save:将数据同步保存到磁盘
bgsave:将数据异步保存到磁盘
lastsave:返回上次成功将数据保存到磁盘的Unix时戳
shundown:将数据同步保存到磁盘,然后关闭服务

3)远程服务控制

info:提供服务器的信息和统计
monitor:实时转储收到的请求
slaveof:改变复制策略设置
config:在运行时配置Redis服务器

4)对value操作的命令

exists(key):确认一个key是否存在
del(key):删除一个key
type(key):返回值的类型
keys(pattern):返回满足给定pattern的所有key
randomkey:随机返回key空间的一个
keyrename(oldname, newname):重命名key
dbsize:返回当前数据库中key的数目
expire:设定一个key的过期时间(s)
ttl:查看一个key的过期时间,-1 永久 -2 已经过期了
select(index):按索引查询
move(key, dbindex):移动当前数据库中的key到dbindex数据库
flushdb:删除当前选择数据库中的所有key
flushall:删除所有数据库中的所有key

5)String

set(key, value):给数据库中名称为key的string赋予值value
get(key):返回数据库中名称为key的string的value
getset(key, value):给名称为key的string赋予上一次的value
mget(key1, key2,…, key N):返回库中多个string的value
setnx(key, value):添加string,名称为key,值为value
setex(key, time, value):向库中添加string,设定过期时间time
mset(key N, value N):批量设置多个string的值
msetnx(key N, value N):如果所有名称为key i的string都不存在
incr(key):名称为key的string增1操作
incrby(key, integer):名称为key的string增加integer
decr(key):名称为key的string减1操作
decrby(key, integer):名称为key的string减少integer
append(key, value):名称为key的string的值附加value
substr(key, start, end):返回名称为key的string的value的子串

6)List (链表,查询慢,增删速度快)

rpush(key, value):在名称为key的list尾添加一个值为value的元素
lpush(key, value):在名称为key的list头添加一个值为value的 元素
llen(key):返回名称为key的list的长度
lrange(key, start, end):返回名称为key的list中start至end之间的元素
ltrim(key, start, end):截取名称为key的list
lindex(key, index):返回名称为key的list中index位置的元素
lset(key, index, value):给名称为key的list中index位置的元素赋值
lrem(key, count, value):删除count个key的list中值为value的元素
lpop(key):返回并删除名称为key的list中的首元素
rpop(key):返回并删除名称为key的list中的尾元素
blpop(key1, key2,… key N, timeout):lpop命令的block版本。
brpop(key1, key2,… key N, timeout):rpop的block版本。
rpoplpush(srckey, dstkey):返回并删除名称为srckey的list的尾元素,并将该元素添加到名称为dstkey的list的头部

7)Set (无序,不可重复)

sadd(key, member):添加元素member
srem(key, member) :删除元素member
spop(key) :随机返回并删除set中一个元素
smove(srckey, dstkey, member) :移到集合元素
scard(key) :返回名称为key的set的基数
sismember(key, member) : 判断是否 存在。
sinter(key1, key2,…key N) :求交集
sinterstore(dstkey, (keys)) :求交集并将交集保存到dstkey的集合
sunion(key1, (keys)) :求并集
sunionstore(dstkey, (keys)) :求并集并将并集保存到dstkey的集合
sdiff(key1, (keys)) :求差集
sdiffstore(dstkey, (keys)) :求差集并将差集保存到dstkey的集合
smembers(key) :返回名称为key的set的所有元素
srandmember(key) :随机返回名称为key的set的一个元素

7.1 set 有序set (排行榜使用)

zadd set3 100 aaa 200 bbbb 400 cccc :想集合中添加元素 数字为排序使用
zscore set3 aaa :获取 aaa 的分数
zrem set aaa :删除 aaa 元素
(正序 zrange 倒叙 zrevrange)
zrange set3 0 2 :查询0 到 2 的元素,不带分数。
zrange set3 0 -1 withscores :查询所有 并带上分数显示
zrangebyscore set3 199 300 withscores :查询199~300 分数范围内的所有元素 并带上分数显示
zrangebyscore set3 199 300 withscores limit 0 1 :限制 limit 限制 只查询 0 到 1
zrevrange set3 0 -1 withscores :倒叙查询所有 并带上分数显示
zremrangebyrank set3 0 1 :按照排名 删除 0-1 范围的 元素
zremrangebyscore set3 199 401 :按照分数 删除 199 ~ 401 范围的 元素

zrank set3 ccc :查询 ccc 的排名
zrevrank set3 ccc :查询 ccc 的倒叙排名

8)Hash

hset(key, field, value):向名称为key的hash中添加元素field
hget(key, field):返回名称为key的hash中field对应的value
hmget(key, (fields)):返回名称为key的hash中field i对应的value
hmset(key, (fields)):向名称为key的hash中添加元素field
hincrby(key, field, integer):将名称为key的hash中field的value增加integer
hexists(key, field):名称为key的hash中是否存在键为field的域
hdel(key, field):删除名称为key的hash中键为field的域
hlen(key):返回名称为key的hash中元素个数
hkeys(key):返回名称为key的hash中所有键
hvals(key):返回名称为key的hash中所有键对应的value
hgetall(key):返回名称为key的hash中所有的键(field)及其对应的value

Redis高级应用

1、安全性

设置客户端连接后进行任何操作指定前需要密码,一个外部用户可以再一秒钟进行150W次访问,具体操作密码修改设置redis.conf里面的requirepass属性给予密码,当然我这里给的是primos 

之后如果想操作可以采用登陆的时候就授权使用:
sudo /opt/java/redis/bin/redis-cli -a primos
或者是进入以后auth primos然后就可以随意操作了

2、主从复制

做这个操作的时候我准备了两个虚拟机,ip分别是192.168.15.128和192.168.15.133
通过主从复制可以允许多个slave server拥有和master server相同的数据库副本
具体配置是在slave上面配置slave
slaveof 192.168.15.128 6379
masterauth primos
如果没有主从同步那么就检查一下是不是防火墙的问题,我用的是ufw,设置一下sudo ufw allow 6379就可以了
这个时候可以通过info查看具体的情况

3、事务处理

redis对事务的支持还比较简单,redis只能保证一个client发起的事务中的命令可以连续执行,而中间不会插入其他client的命令。当一个client在一个连接中发出multi命令时,这个连接会进入一个事务的上下文,连接后续命令不会立即执行,而是先放到一个队列中,当执行exec命令时,redis会顺序的执行队列中的所有命令。
比如我下面的一个例子
set age 100
multi
set age 10
set age 20
exec
get age --这个内容就应该是20
multi
set age 20
set age 10
exec
get age --这个时候的内容就成了10,充分体现了一下按照队列顺序执行的方式
discard 取消所有事务,也就是事务回滚
不过在redis事务执行有个别错误的时候,事务不会回滚,会把不错误的内容执行,错误的内容直接放弃,目前最新的是2.6.7也有这个问题的
乐观锁
watch key如果没watch的key有改动那么outdate的事务是不能执行的

4、持久化机制

RDB 方式: 默认redis 持久化方式。(时候内存充裕的 保存方式)
(运行时会将数据复制一份到内存中,然后压缩,写入硬盘 dump.rdb的二进制文件中,如果数据有 1G 那么在运行备份时,就需要有2G 的内存空间,否则可能出现宕机。所有需要内存比较大)
持久化时机:
1、在服务器正常关闭
接受到客户端传递的 shutdown命令时,
2、redis.conf 配置的规则
save 900 1 #每900 秒 内有超过1个可以发生变化,则 dump 内存快照
save 300 10 #每300 秒 内有超过10个可以发生变化,则 dump 内存快照
save 60 10000 #每60 秒 内有超过10000个可以发生变化,则 dump 内存快照

AOF 持久化:基于日志功能的持久化, 会将日志保存到 appendonly.adf 中。
机制:会保存所有改变key状态的语句,数据恢复时,将所有语句执行一遍,就会得到最终还原的结果。
有点:安全,占用资源少。
缺点:以后日志文件会特别大。数据还原速度特别大。
配置方式: 打开 redis.conf找到 appendonly no 改为 yes
下面是具体配置
appendfsync eveysec #每秒保存一次。
appendfsync always #key 发生变化即保存一次。

如果对数据安全要求非常高的话,可以两种都使用。
如果能承受 数分钟内数据丢失的话,可以使用 RDB .
两种都用的情况下,redis重启时,默认使用AOF 来还原数据。

5、发布订阅消息

sbusribe publish操作,其实就类似linux下面的消息发布
开启一个 redis-cli 订阅 xxx 频道 * 代表通配送 可以写 xx* 代表 xx 开头的所有频道。
sbusribe xxx
再开启一个 redis-cli 发布消息到 xxx 频道
publish xxx ‘hello’

这时,订阅客户端就能收到 hello 消息

6、虚拟内存的使用

可以配置vm功能,保存路径,最大内存上线,页面多少,页面大小,最大工作线程
临时修改ip地址ifconfig eth0 192.168.15.129

Redis-cli参数

Usage: redis-cli [OPTIONS] [cmd [arg [arg …]]]
-h Server hostname (default: 127.0.0.1)
-p Server port (default: 6379)
-s Server socket (overrides hostname and port)
-a Password to use when connecting to the server
-r Execute specified command N times
-i When -r is used, waits seconds per command.
It is possible to specify sub-second times like -i 0.1
-n Database number
-x Read last argument from STDIN
-d Multi-bulk delimiter in for raw formatting (default: \n)
-c Enable cluster mode (follow -ASK and -MOVED redirections)
–raw Use raw formatting for replies (default when STDOUT is not a tty)
–latency Enter a special mode continuously sampling latency
–slave Simulate a slave showing commands received from the master
–pipe Transfer raw Redis protocol from stdin to server
–bigkeys Sample Redis keys looking for big keys
–eval Send an EVAL command using the Lua script at
–help Output this help and exit
–version Output version and exit

Examples:
cat /etc/passwd | redis-cli -x set mypasswd
redis-cli get mypasswd
redis-cli -r 100 lpush mylist x
redis-cli -r 100 -i 1 info | grep used_memory_human:
redis-cli --eval myscript.lua key1 key2 , arg1 arg2 arg3
(Note: when using --eval the comma separates KEYS[] from ARGV[] items)

常用命令:

1) 查看keys个数

keys * // 查看所有keys

keys prefix_* // 查看前缀为"prefix_"的所有keys

2) 清空数据库

flushdb // 清除当前数据库的所有keys

flushall // 清除所有数据库的所有keys

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值