redis从入门到精通2--Redis数据结构、基本命令操作、持久化
文章目录
一、redis数据结构
要想使用 Redis 进行数据存储,首先需要了解 Redis 的数据结构,redis存储的是:key,value格式的数据,其中key都是字符串,value有5种不同的数据结构:
- 字符串类型 string
- 哈希类型 hash : map格式
- 列表类型 list : linkedlist格式。支持重复元素
- 集合类型 set : 不允许重复元素
- 有序集合类型 sortedset:不允许重复元素,且元素有顺序
这五种数据结构存储方式可见下表:
二、redis基本操作命令
针对以上五种不同的数据结构,Redis 有相应的命令来进行操作,可以达到对数据的存储、获取和删除
1.字符串型:String
存储:set key value
如:set name oneStar
获取:get key
如:get name
删除:del key
如:del name
2.哈希类型:Hash
存储:hset key field value
如:
hset myhash name twoStar
hset myhash age 18
获取指定的field对应的值:hget key field
如:hget myhash name
获取所有的field和value:hgetall key
如:hgetall myhash
删除:hdel key field
如:hdel myhash name
3.列表类型:List
可以添加一个元素到列表的头部(左边)或者尾部(右边)
存储:
lpush key value:将元素加入列表左表
rpush key value:将元素加入列表右边
如:
lpush myList a
lpush myList b
rpush myList c
获取:
lrange key start end :范围获取
如:lrange myList 0 -1
注:Redis Lrange 返回列表中指定区间内的元素,区间以偏移量 START 和 END 指定。 其中 0 表示列表的第一个元素, 1 表示列表的第二个元素,以此类推。 你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。
删除:
lpop key: 删除列表最左边的元素,并将元素返回
如:lpop myList
rpop key: 删除列表最右边的元素,并将元素返回
如:rpop myList
4.集合类型:Set
不允许重复元素
存储:sadd key value
如:sadd myset a
获取set集合中所有元素:smembers key
如:smembers myset
删除set集合中的某个元素:srem key value
如:srem myset a
5.有序集合类型:sortedset
不允许重复元素,且元素有顺序.每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
存储:zadd key score value
如:zadd mysort 60 oneStar
zadd mysort 50 twoStar
zadd mysort 80 threeStar
获取:zrange key start end [withscores] 获取的成员从小到大排列
注:
1.如果想从大到小排列 用zrevrange
2.加上 withscores 的话可以将分值以及value都显示出来,否则只显示value
如:zrange mysort 0 -1
zrange mysort 0 -1 withscores
删除:zrem key value
如:zrem mysort oneStar
6.通用命令
keys * : 查询所有的键
type key : 获取键对应的value的类型
del key:删除指定的key value
三、Redis持久化
redis是一个内存数据库,当redis服务器重启,获取电脑重启,数据会丢失,为了解决这个问题,我们可以将 redis 内存中的数据持久化保存到硬盘的文件中。
Redis 持久化机制有两种:
1.RDB持久化机制
RDB 持久化机制是默认的方式,不需要进行配置,默认就使用这种机制,在一定的间隔时间中,检测key的变化情况,然后持久化数据,对性能影响不大。
(1) RDB 持久化机制,是根据 Redis 安装目录下的 redis.windwos.conf 文件中配置内容决定的:
save 900 1 save 300 10 save 60 10000
save 900 1:如果 15 分钟后最少有一个 key 被改变就持久化一次
save 300 10:如果 5 分钟后最少有 10 个 key 被改变就持久化一次
save 60 10000:如果 1 分钟后最少有 10000 个 key 被改变就持久化一次
可以通过改变这个配置来指定自己想要的持久化时间和次数
(2) 重新在命令行启动redis服务器,并指定配置文件名称,便可以进行持久化了
D:\Redis\redis-2.8.9> .\redis-server.exe .\redis.windows.conf
2.AOF持久化机制
AOF 持久化机制是使用日志记录的方式,可以记录每一条命令的操作,可以每一次命令操作后,持久化数据,执行一条语句就进行一次持久化,对性能的影响比较大。
(1) 开启 AOF 持久化机制
编辑 redis.windwos.conf 文件,找到 appendonly no,将 no 改为 yes,即表示开启 AOF 持久化机制
在 redis.windwos.conf 文件中,可以找到如下信息:
# appendfsync always : 每一次操作都进行持久化 appendfsync everysec : 每隔一秒进行一次持久化 # appendfsync no : 不进行持久化
(2) 重新在命令行启动redis服务器,并指定配置文件名称,便可以进行持久化了
D:\Redis\redis-2.8.9> .\redis-server.exe .\redis.windows.conf
- 点赞
- 收藏
- 分享
- 文章举报
- Redis入门级指南---客户端命令基本操作
- Redis 5种数据类型及基本的命令操作(新手入门)
- Linux命令-基本操作及文件操作常用命令--详解Linux入门到精通系列
- Redis从入门到放弃 之 常用命令和基本数据类型操作
- 4、Redis从入门到放弃 之 常用命令和基本数据类型操作
- PHP+redis的一些基本操作命令
- Redis5种数据结构的内部编码及应用场景和基本命令
- redis基本操作命令
- Redis入门到精通-Redis持久化机制
- HBASE入门概念和基本操作命令
- linux学习入门2-3——bash命令基本操作(linuxcast.net)(bash部分快捷键、uname、history、通配符、切换用户、作业管理(前台、后台运行,暂停等操作))
- redis基本操作命令
- redis入门(06)各种类型的操作命令
- Redis(2)- 基本数据结构和操作
- redis中的数据结构基本的操作
- Jedis对Redis的基本命令操作
- Git入门——'查询命令'总结与文件的基本操作
- redis基本操作命令
- kafka入门-基本命令操作
- Redis的数据结构及操作命令