三、Redis持久化
1、RDB 持久化机制
2、 AOF 持久化机制
一、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的变化情况,然后持久化数据,对性能影响不大。