redis的使用
Redis 安装
- 当前redis最新稳定版本是4.0.9
- 当前ubuntu虚拟机中已经安装好了redis,以下步骤可以跳过 最新稳定版本下载链接: http://download.redis.io/releases/redis-4.0.9.tar.gz
-
step1:下载
-
step2:解压
tar xzf redis-4.0.9.tar.gz
-
step3:移动,放到usr/local⽬录下
sudo mv ./redis-4.0.9 /usr/local/redis/
-
step4:进⼊redis⽬录
cd /usr/local/redis/
-
step5:生成
sudo make
-
step6:测试,这段运⾏时间会较⻓
sudo make test
-
step7:安装,将redis的命令安装到
/usr/local/bin/
⽬录sudo make install
-
step8:安装完成后,我们进入目录
/usr/local/bin
中查看cd /usr/local/bin
ls -all- redis-server redis服务器
- redis-cli redis命令行客户端
- redis-benchmark redis性能测试工具
- redis-check-aof AOF文件修复工具
- redis-check-rdb RDB文件检索工具
-
step9:配置⽂件,移动到
/etc/
⽬录下-
配置⽂件⽬录为
/usr/local/redis/redis.conf
sudo cp /usr/local/redis/redis.conf /etc/redis/
-
其他补充
Mac 上安装 Redis:
- 安装 Homebrew:
- 使用 brew 安装 Redis
- https://www.cnblogs.com/cloudshadow/p/mac_brew_install_redis.html
配置
-
Redis的配置信息在
/etc/redis/redis.conf
下。 -
查看
sudo vi /etc/redis/redis.conf
核心配置选项
- 绑定ip:如果需要远程访问,可将此⾏注释,或绑定⼀个真实ip
bind 127.0.0.1
- 端⼝,默认为6379
port 6379
-
是否以守护进程运⾏
- 如果以守护进程运⾏,则不会在命令⾏阻塞,类似于服务
- 如果以⾮守护进程运⾏,则当前终端被阻塞
- 设置为yes表示守护进程,设置为no表示⾮守护进程
- 推荐设置为yes
daemonize yes
-
数据⽂件
dbfilename dump.rdb
- 数据⽂件存储路径
dir /var/lib/redis
- ⽇志⽂件
logfile "/var/log/redis/redis-server.log"
- 数据库,默认有16个
database 16
- 主从复制,类似于双机备份。
slaveof
参考资料
redis配置信息http://blog.csdn.net/ljphilp/article/details/52934933
-
服务器端
-
服务器端的命令为redis-server
-
可以使⽤help查看帮助⽂档
redis-server --help
- 个人习惯
ps aux | grep redis 查看redis服务器进程
sudo kill -9 pid 杀死redis服务器
sudo redis-server /etc/redis/redis.conf 指定加载的配置文件
客户端
- 客户端的命令为redis-cli
- 可以使⽤help查看帮助⽂档
redis-cli --help
-
连接redis
redis-cli
-
运⾏测试命令
ping
-
切换数据库
-
数据库没有名称,默认有16个,通过0-15来标识,连接redis默认选择第一个数据库
select 10
string类型
- 字符串类型是 Redis 中最为基础的数据存储类型,它在 Redis 中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等。在Redis中字符串类型的Value最多可以容纳的数据长度是512M。
保存
如果设置的键不存在则为添加,如果设置的键已经存在则修改
-
设置键值
set key value
-
例1:设置键为
name
值为itcast
的数据set name itcast
-
设置键值及过期时间,以秒为单位
setex key seconds value
-
例2:设置键为
aa
值为aa
过期时间为3秒的数据setex aa 3 aa
-
设置多个键值
mset key1 value1 key2 value2 ...
-
例3:设置键为
a1
值为python
、键为a2
值为java
、键为a3
值为c
mset a1 python a2 java a3 c
-
追加值
append key value
-
例4:向键为
a1
中追加值haha
append a1 haha
获取
-
获取:根据键获取值,如果不存在此键则返回
nil
get key
-
例5:获取键
name
的值get name
-
根据多个键获取多个值
mget key1 key2 ...
-
例6:获取键
a1、a2、a3
的值mget a1 a2 a3
删除
详⻅下节键的操作,删除键时会将值删除
键命令
-
查找键,参数⽀持正则表达式
keys pattern
-
例1:查看所有键
keys *
-
例2:查看名称中包含
a
的键keys a*
-
判断键是否存在,如果存在返回
1
,不存在返回0
exists key1
-
例3:判断键
a1
是否存在exists a1
-
查看键对应的
value
的类型type key
-
例4:查看键
a1
的值类型,为redis⽀持的五种类型中的⼀种type a1
-
删除键及对应的值
del key1 key2 ...
-
例5:删除键
a2、a3
del a2 a3
-
设置过期时间,以秒为单位
-
如果没有指定过期时间则⼀直存在,直到使⽤
DEL
移除expire key seconds
-
例6:设置键
a1
的过期时间为3秒expire a1 3
-
查看有效时间,以秒为单位
ttl key
-
例7:查看键
bb
的有效时间ttl bb
hash类型
- hash⽤于存储对象,对象的结构为属性、值
- 值的类型为string
增加、修改
-
设置单个属性
hset key field value
-
例1:设置键
user
的属性name
为itheima
hset user name itheima
-
设置多个属性
hmset key field1 value1 field2 value2 ...
-
例2:设置键
u2
的属性name
为itcast
、属性age
为11
hmset u2 name itcast age 11
获取
-
获取指定键所有的属性
hkeys key
-
例3:获取键u2的所有属性
hkeys u2
-
获取⼀个属性的值
hget key field
-
例4:获取键
u2
属性name
的值hget u2 name
-
获取多个属性的值
hmget key field1 field2 ...
-
例5:获取键
u2
属性name
、age
的值hmget u2 name age
-
获取所有属性的值
hvals key
-
例6:获取键
u2
所有属性的值hvals u2
删除
- 删除整个hash键及值,使⽤del命令
-
删除属性,属性对应的值会被⼀起删除
hdel key field1 field2 ...
-
例7:删除键
u2
的属性age
hdel u2 age
可能出现的错误
MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist on disk. Commands that may modify the data set are disabled. Please check Redis logs for details about the error.
Redis被配置为保存数据库快照,但它目前不能持久化到硬盘。用来修改集合数据的命令不能用
- 原因:
- 强制关闭Redis快照导致不能持久化。
- 解决方案:
- 运行config set stop-writes-on-bgsave-error no 命令后,关闭配置项stop-writes-on-bgsave-error解决该问题。
list类型
- 列表的元素类型为string
- 按照插⼊顺序排序
增加
-
在左侧插⼊数据
lpush key value1 value2 ...
-
例1:从键为
a1
的列表左侧加⼊数据a 、 b 、c
lpush a1 a b c
-
在右侧插⼊数据
rpush key value1 value2 ...
-
例2:从键为
a1
的列表右侧加⼊数据0、1
rpush a1 0 1
-
在指定元素的前或后插⼊新元素
linsert key before或after 现有元素 新元素
-
例3:在键为
a1
的列表中元素b
前加⼊3
linsert a1 before b 3
获取
-
返回列表⾥指定范围内的元素
start
、stop
为元素的下标索引- 索引从左侧开始,第⼀个元素为0
- 索引可以是负数,表示从尾部开始计数,如
-1
表示最后⼀个元素
lrange key start stop
-
例4:获取键为
a1
的列表所有元素lrange a1 0 -1
设置指定索引位置的元素值
- 索引从左侧开始,第⼀个元素为0
-
索引可以是负数,表示尾部开始计数,如
-1
表示最后⼀个元素lset key index value
-
例5:修改键为
a1
的列表中下标为1
的元素值为z
lset a 1 z
删除
-
删除指定元素
- 将列表中前
count
次出现的值为value
的元素移除 - count > 0: 从头往尾移除
- count < 0: 从尾往头移除
- count = 0: 移除所有
lrem key count value
- 将列表中前
-
例6.1:向列表
a2
中加⼊元素a、b、a、b、a、b
lpush a2 a b a b a b
-
例6.2:从
a2
列表右侧开始删除2个b
lrem a2 -2 b
-
例6.3:查看列表
a2
的所有元素lrange a2 0 -1
set类型
- ⽆序集合
- 元素为string类型
- 元素具有唯⼀性,不重复
- 说明:对于集合没有修改操作
增加
-
添加元素
sadd key member1 member2 ...
-
例1:向键
a3
的集合中添加元素zhangsan
、lisi
、wangwu
sadd a3 zhangsan sili wangwu
获取
-
返回所有的元素
smembers key
-
例2:获取键
a3
的集合中所有元素smembers a3
删除
-
删除指定元素
srem key
-
例3:删除键
a3
的集合中元素wangwu
srem a3 wangwu
zset类型
- sorted set,有序集合
- 元素为string类型
- 元素具有唯⼀性,不重复
- 每个元素都会关联⼀个double类型的score,表示权重,通过权重将元素从⼩到⼤排序
- 说明:没有修改操作
增加
-
添加
zadd key score1 member1 score2 member2 ...
-
例1:向键
a4
的集合中添加元素lisi
、wangwu
、zhaoliu
、zhangsan
,权重分别为4、5、6、3
zadd a4 4 lisi 5 wangwu 6 zhaoliu 3 zhangsan
获取
- 返回指定范围内的元素
- start、stop为元素的下标索引
- 索引从左侧开始,第⼀个元素为0
-
索引可以是负数,表示从尾部开始计数,如
-1
表示最后⼀个元素zrange key start stop
-
例2:获取键
a4
的集合中所有元素zrange a4 0 -1
-
返回
score
值在min
和max
之间的成员zrangebyscore key min max
-
例3:获取键
a4
的集合中权限值在5和6之间
的成员zrangebyscore a4 5 6
-
返回成员
member
的score
值zscore key member
-
例4:获取键
a4
的集合中元素zhangsan
的权重zscore a4 zhangsan
删除
-
删除指定元素
zrem key member1 member2 ...
-
例5:删除集合
a4
中元素zhangsan
zrem a4 zhangsan
-
删除权重在指定范围的元素
zremrangebyscore key min max
-
例6:删除集合
a4
中权限在5、6之间
的元素zremrangebyscore a4 5 6
安装包
安装Redis的有3种方式https://github.com/andymccurdy/redis-py
- 第一种:进⼊虚拟环境,联⽹安装包redis
pip install redis
- 第二种:进⼊虚拟环境,联⽹安装包redis
easy_install redis
- 第三种:到中⽂官⽹-客户端下载redis包的源码,使⽤源码安装
一步步执行 wget https://github.com/andymccurdy/redis-py/archive/master.zip
unzip master.zip
cd redis-py-master
sudo python setup.py install
调⽤模块
- 引⼊模块
from redis import StrictRedis
- 这个模块中提供了
StrictRedis对象
,⽤于连接redis服务器,并按照不同类型提供 了不同⽅法,进⾏交互操作