key redis 遍历_redis 入门

0dafdaedb37485f199e6d9d1dad04717.png

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值