Redis 是一个高性能(读写频次高)的key-value的db,它支持数据持久化,支持一些基本的数据结构。它的操作具有原子性,还支持数据的备份等功能。
安装、启动
-
- 安装:Redis 安装 | 菜鸟教程
- 启动redis服务:redis-server.exe redis.windows.conf
- 连接本地 redis 服务:redis-cli.exe -h 127.0.0.1 -p 6379
redis 配置 [5]
-
- redis 有 master 端和 slave 端,启动的时候有deamon模式和非deamon
- timeout :可以指定客户端闲置多久自动关闭
- loglevel notice、logfile stdout:可以指定 日志级别、日志记录方式
- 可以指定 db的数量,地址,名字
- save 可以指定同步到本地数据的前提条件,比如说 300秒内有10次操作
- appendfsync 可以指定是否每次操作都同步到本地数据,有三种方式,等操作系统同步( 由操作系统自动调度刷磁盘?)、每次更新完数据之后都会调用同步(性能差)和 每秒同步一次。如果否的话,可能断电会丢失一部分操作,同时也可以指定备份数据名
疑问:appendfsync everysec 跟 save 不是会冲突?
Ans:append记录的对象是 redis的写命令(比如 RPUSH list "A"),不是数据本身,存储的文件格式是 .aof;save 的记录对象是数据本身,存储的文件格式是 .rdb。所以它们的存储文件不一样。当打开了 append的时候,redis重启优先从append存的数据恢复[4]。
-
- 可以指定存储到本地数据的时候,是否压缩,默认是有的,默认压缩格式是LZF
- 作为 slave 的时候,可以指定默认链接的 master地址、密码
- 作为 master 的时候,可以指定 同时最多有多少个客户端链接自己,达到限制数量后拒绝新的客户端链接;向客户端发送应答时,是否合并小包
- vm-page 可以指定是否启用虚拟内存(就是redis会把 冷数据swap到磁盘中,访问多的页面换到内存里),虚拟内存的文件地址,定义大于 XX大小的数据都放在虚拟内存(磁盘)里,设置swap的page数量(我理解其实就是大小?),设置 并发访问swap文件的线程数量,如果设置为0,就意味着所有对swap文件的访问都是串行的
- 同一主机上的多个redis实例 是否公用配置
- hash-max-zipmap-entries:某个哈希对象超过某个阈值的时候,采用另一种更节省内存的存储方式(把唯一的id 做md5处理,这样更节省内存[1]),但是如果这个阈值配置得太大了,可能造成每次查找都要遍历全局 非常消耗CPU的结果[2]
- activerehashing :是否开启 渐进式 rehash,需要rehash是因为 数据到达某个值之后,出现哈希冲突,这时候需要rehash,但是又不能影响当前的使用,所以需要分治地、 渐进地 进行rehash[3]
基础类型设值、取值
-
- 基础设置是 SET GET
- 列表是 lpush lrange
- 哈希是 HSET HGET
- 集合是 sadd smembers
- 有序集合是 zadd
redis key
-
- key可以有过期时间,也可以配置为永不过期
- key可以正则批量查找
- 可以 以key为单位 从一个db移动到另一个db
- key可以被重命名
- key可以被遍历,也可以按照正则(pattern)被遍历
redis string
-
- 它可以设值,,可以一个命令同时取值设值,可以批量一次设置多个值,设置值的时候可以指定过期时间,可以一个命令判断不存在才设置值,判断不存在才设置值也可以批量搞。
- 它可以取值,可以按照范围取值,可以批量一次取多个key,可以按位取值,可以取字符串长度
- 修改:可以一个命令 给key对应的数值加一,可以给val 加指定数字,同理也可以减一或减去指定数值
- 改string:可以给val后面append一小段新的字符串
redis hash
-
- 可以批量删除key,可以批量设置key,可以在没这个key的时候才设置
- 可以存储、获取、检测key是否存在
- 可以给val加指定增量
- 可以获取某哈希表的所有key,并遍历它们,也可以按照正则条件选择需要遍历的 去遍历
- 可以获取某哈希表key的数量
redis list
-
- 它本质是双向链表,所以可以从头尾pop数据
- 可以从一个列表转移某数据到另一个列表中
- 列表数据可以按照索引获取,可以获取指定范围的值,
- 列表前后都可以增加新值,可以一次插入多个值
- 可以按val移除列表元素(按照不同参数 可以移除指定个该val的元素,或者 完全移除所有该val的元素),可以只保留指定区间的元素。
- 可以添加一个或多个值
redis set
-
- 可以比较两个集合的差异,并存储差异
- 可以算集合的交集,并存储交集
- 可以判断某元素是否属于该set
- 可以算并集,并存储并集
- 可以迭代
redis sorted set(它比set多一个score,所有元素通过score排序):
-
- 可以按照分数的区间返回数值
- 可以按照顺序返回数据
- 可以迭代
- 可以批量操作分数,整体增加多少多少
参考:
[1] 哈希内存优化:https://blog.csdn.net/hobbs136/article/details/7625873?locationNum=5
[2] 阈值过大导致CPU过高:https://blog.csdn.net/justin051/article/details/84354087
[3] 渐进式哈希:https://www.cnblogs.com/williamjie/p/11205593.html
[4] redis的数据备份:https://zhuanlan.zhihu.com/p/106997927
[5] redis配置:https://www.runoob.com/redis/redis-conf.html