一、Redis 数据结构
要想使用 Redis 进行数据存储,首先需要了解 Redis 的数据结构,redis存储的是:key,value格式的数据,其中key都是字符串,value有5种不同的数据结构:
字符串类型 string
哈希类型 hash : map格式
列表类型 list : linkedlist格式。支持重复元素
集合类型 set : 不允许重复元素
有序集合类型 sortedset:不允许重复元素,且元素有顺序
这五种数据结构存储方式可见下表:
二、Redis 基本命令操作
针对以上五种不同的数据结构,Redis 有相应的命令来进行操作,可以达到对数据的存储、获取和删除
1、字符串型:string
存储:set key value
eg:set name oneStar
获取:get key
eg:get name
删除:del key
eg:del name
2、哈希类型:hash
存储:hset key field value
eg:hset myhash name twoStar
hset myhash age 18
获取指定的field对应的值:hget key field
获取所有的field和value:hgetall key
eg:hget myhash name
eg:hgetall myhash
删除:hdel key field
eg:hdel myhash name
3、列表类型:list
可以添加一个元素到列表的头部(左边)或者尾部(右边)
存储
lpush key value:将元素加入列表左表
rpush key value:将元素加入列表右边
eg:lpush myList a
lpush myList b
rpush myList c
获取:lrange key start end :范围获取
eg:lrange myList 0 -1
删除
lpop key: 删除列表最左边的元素,并将元素返回
eg:lpop myList
rpop key: 删除列表最右边的元素,并将元素返回
eg:rpop
4、集合类型:set
不允许重复元素
存储:sadd key value
eg:sadd myset a
获取set集合中所有元素:smembers key
eg:smembers myset
删除set集合中的某个元素:srem key value
eg:srem myset a
5、有序集合类型:sortedset
不允许重复元素,且元素有顺序.每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
存储:zadd key score value
eg:zadd mysort 60 oneStar
zadd mysort 50 twoStar
zadd mysort 80 threeStar
获取:zrange key start end [withscores]
eg1:zrange mysort 0 -1
eg2:zrange mysort 0 -1 withscores
删除:zrem key value
eg:zrem mysort oneStar
6、通用命令
keys * : 查询所有的键
eg:keys *
type key : 获取键对应的value的类型
eg:type myhash
del key:删除指定的key value
eg:del myhash
三、Redis持久化
redis是一个内存数据库,当redis服务器重启,获取电脑重启,数据会丢失,为了解决这个问题,我们可以将 redis 内存中的数据持久化保存到硬盘的文件中。
Redis 持久化机制有两种:
1、RDB 持久化机制
RDB 持久化机制是默认的方式,不需要进行配置,默认就使用这种机制,在一定的间隔时间中,检测key的变化情况,然后持久化数据,对性能影响不大。
【1】RDB 持久化机制,是根据 Redis 安装目录下的 redis.windwos.conf 文件中配置内容决定的:
save 900 1:如果 15 分钟后最少有一个 key 被改变就持久化一次
save 300 10:如果 5 分钟后最少有 10 个 key 被改变就持久化一次
save 60 10000:如果 1 分钟后最少有 10000 个 key 被改变就持久化一次
可以通过改变这个配置来指定自己想要的持久化时间和次数
【2】重新在命令行启动redis服务器,并指定配置文件名称,便可以进行持久化了
2、 AOF 持久化机制
AOF 持久化机制是使用日志记录的方式,可以记录每一条命令的操作,可以每一次命令操作后,持久化数据,执行一条语句就进行一次持久化,对性能的影响比较大。
【1】开启 AOF 持久化机制
编辑 redis.windwos.conf 文件,找到 appendonly no,将 no 改为 yes,即表示开启 AOF 持久化机制
在 redis.windwos.conf 文件中,可以找到如下信息:
# appendfsync always : 每一次操作都进行持久化
appendfsync everysec : 每隔一秒进行一次持久化
# appendfsync no : 不进行持久化
【2】重新在命令行启动redis服务器,并指定配置文件名称,便可以进行持久化了