zoukankan      html  css  js  c++  java
  • Redis(二)

    Redis 有序集合(sorted set)

    Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。

    不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

    有序集合的成员是唯一的,但分数(score)却可以重复。

    集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

    实例

    redis 127.0.0.1:6379> ZADD runoobkey 1 redis
    (integer) 1
    redis 127.0.0.1:6379> ZADD runoobkey 2 mongodb
    (integer) 1
    redis 127.0.0.1:6379> ZADD runoobkey 3 mysql
    (integer) 1
    redis 127.0.0.1:6379> ZADD runoobkey 3 mysql
    (integer) 0
    redis 127.0.0.1:6379> ZADD runoobkey 4 mysql
    (integer) 0
    redis 127.0.0.1:6379> ZRANGE runoobkey 0 10 WITHSCORES
    
    1) "redis"
    2) "1"
    3) "mongodb"
    4) "2"
    5) "mysql"
    6) "4"

    在以上实例中我们通过命令 ZADD 向 redis 的有序集合中添加了三个值并关联上分数。(分数必须关联,不然报错)

    Redis 有序集合命令

    下表列出了 redis 有序集合的基本命令:

    序号命令及描述
    1 ZADD key score1 member1 [score2 member2]
    向有序集合添加一个或多个成员,或者更新已存在成员的分数
    2 ZCARD key
    获取有序集合的成员数
    3 ZCOUNT key min max
    计算在有序集合中指定区间分数的成员数
    4 ZINCRBY key increment member
    有序集合中对指定成员的分数加上增量 increment
    5 ZINTERSTORE destination numkeys key [key ...]
    计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中
    6 ZLEXCOUNT key min max
    在有序集合中计算指定字典区间内成员数量
    7 ZRANGE key start stop [WITHSCORES]
    通过索引区间返回有序集合指定区间内的成员
    8 ZRANGEBYLEX key min max [LIMIT offset count]
    通过字典区间返回有序集合的成员
    9 ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT]
    通过分数返回有序集合指定区间内的成员
    10 ZRANK key member
    返回有序集合中指定成员的索引
    11 ZREM key member [member ...]
    移除有序集合中的一个或多个成员
    12 ZREMRANGEBYLEX key min max
    移除有序集合中给定的字典区间的所有成员
    13 ZREMRANGEBYRANK key start stop
    移除有序集合中给定的排名区间的所有成员
    14 ZREMRANGEBYSCORE key min max
    移除有序集合中给定的分数区间的所有成员
    15 ZREVRANGE key start stop [WITHSCORES]
    返回有序集中指定区间内的成员,通过索引,分数从高到低
    16 ZREVRANGEBYSCORE key max min [WITHSCORES]
    返回有序集中指定分数区间内的成员,分数从高到低排序
    17 ZREVRANK key member
    返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序
    18 ZSCORE key member
    返回有序集中,成员的分数值
    19 ZUNIONSTORE destination numkeys key [key ...]
    计算给定的一个或多个有序集的并集,并存储在新的 key 中
    20 ZSCAN key cursor [MATCH pattern] [COUNT count]
    迭代有序集合中的元素(包括元素成员和元素分值)

    Redis HyperLogLog

    Redis 在 2.8.9 版本添加了 HyperLogLog 结构。

    Redis HyperLogLog 是用来做基数统计的算法,HyperLogLog 的优点是,在输入元素的数量或者体积非常非常大时,计算基数所需的空间总是固定 的、并且是很小的。

    在 Redis 里面,每个 HyperLogLog 键只需要花费 12 KB 内存,就可以计算接近 2^64 个不同元素的基 数。这和计算基数时,元素越多耗费内存就越多的集合形成鲜明对比。

    但是,因为 HyperLogLog 只会根据输入元素来计算基数,而不会储存输入元素本身,所以 HyperLogLog 不能像集合那样,返回输入的各个元素。


    什么是基数?

    比如数据集 {1, 3, 5, 7, 5, 7, 8}, 那么这个数据集的基数集为 {1, 3, 5 ,7, 8}, 基数(不重复元素)为5。 基数估计就是在误差可接受的范围内,快速计算基数。


    实例

    以下实例演示了 HyperLogLog 的工作过程:

    redis 127.0.0.1:6379> PFADD runoobkey "redis"
    
    1) (integer) 1
    
    redis 127.0.0.1:6379> PFADD runoobkey "mongodb"
    
    1) (integer) 1
    
    redis 127.0.0.1:6379> PFADD runoobkey "mysql"
    
    1) (integer) 1
    
    redis 127.0.0.1:6379> PFCOUNT runoobkey
    
    (integer) 3

    Redis HyperLogLog 命令

    下表列出了 redis HyperLogLog 的基本命令:

    序号命令及描述
    1 PFADD key element [element ...]
    添加指定元素到 HyperLogLog 中。
    2 PFCOUNT key [key ...]
    返回给定 HyperLogLog 的基数估算值。
    3 PFMERGE destkey sourcekey [sourcekey ...]
    将多个 HyperLogLog 合并为一个 HyperLogLog

    Redis 发布订阅

    Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。

    Redis 客户端可以订阅任意数量的频道。

    下图展示了频道 channel1 , 以及订阅这个频道的三个客户端 —— client2 、 client5 和 client1 之间的关系:

    当有新消息通过 PUBLISH 命令发送给频道 channel1 时, 这个消息就会被发送给订阅它的三个客户端:

    实例

    以下实例演示了发布订阅是如何工作的。在我们实例中我们创建了订阅频道名为 redisChat:

    redis 127.0.0.1:6379> SUBSCRIBE redisChat
    
    Reading messages... (press Ctrl-C to quit)
    1) "subscribe"
    2) "redisChat"
    3) (integer) 1

    现在,我们先重新开启个 redis 客户端,然后在同一个频道 redisChat 发布两次消息,订阅者就能接收到消息。

    redis 127.0.0.1:6379> PUBLISH redisChat "Redis is a great caching technique"
    
    (integer) 1
    
    redis 127.0.0.1:6379> PUBLISH redisChat "Learn redis by runoob.com"
    
    (integer) 1
    
    # 订阅者的客户端会显示如下消息
    1) "message"
    2) "redisChat"
    3) "Redis is a great caching technique"
    1) "message"
    2) "redisChat"
    3) "Learn redis by runoob.com"

    Redis 发布订阅命令

    下表列出了 redis 发布订阅常用命令:

    序号命令及描述
    1 PSUBSCRIBE pattern [pattern ...]
    订阅一个或多个符合给定模式的频道。
    2 PUBSUB subcommand [argument [argument ...]]
    查看订阅与发布系统状态。
    3 PUBLISH channel message
    将信息发送到指定的频道。
    4 PUNSUBSCRIBE [pattern [pattern ...]]
    退订所有给定模式的频道。
    5 SUBSCRIBE channel [channel ...]
    订阅给定的一个或多个频道的信息。
    6 UNSUBSCRIBE [channel [channel ...]]
    指退订给定的频道。

    Redis 事务

    Redis 事务可以一次执行多个命令, 并且带有以下三个重要的保证:

    • 批量操作在发送 EXEC 命令前被放入队列缓存。
    • 收到 EXEC 命令后进入事务执行,事务中任意命令执行失败,其余的命令依然被执行。
    • 在事务执行过程,其他客户端提交的命令请求不会插入到事务执行命令序列中。

    一个事务从开始到执行会经历以下三个阶段:

    • 开始事务。
    • 命令入队。
    • 执行事务。

    实例

    以下是一个事务的例子, 它先以 MULTI 开始一个事务, 然后将多个命令入队到事务中, 最后由 EXEC 命令触发事务, 一并执行事务中的所有命令:

    redis 127.0.0.1:6379> MULTI
    OK
    
    redis 127.0.0.1:6379> SET book-name "Mastering C++ in 21 days"
    QUEUED
    
    redis 127.0.0.1:6379> GET book-name
    QUEUED
    
    redis 127.0.0.1:6379> SADD tag "C++" "Programming" "Mastering Series"
    QUEUED
    
    redis 127.0.0.1:6379> SMEMBERS tag
    QUEUED
    
    redis 127.0.0.1:6379> EXEC
    1) OK
    2) "Mastering C++ in 21 days"
    3) (integer) 3
    4) 1) "Mastering Series"
       2) "C++"
       3) "Programming"

    单个 Redis 命令的执行是原子性的,但 Redis 没有在事务上增加任何维持原子性的机制,所以 Redis 事务的执行并不是原子性的。

    事务可以理解为一个打包的批量执行脚本,但批量指令并非原子化的操作,中间某条指令的失败不会导致前面已做指令的回滚,也不会造成后续的指令不做。

    https://www.cnblogs.com/DeepInThought/p/10720132.html

    Redis 事务命令

    下表列出了 redis 事务的相关命令:

    序号命令及描述
    1 DISCARD
    取消事务,放弃执行事务块内的所有命令。
    2 EXEC
    执行所有事务块内的命令。
    3 MULTI
    标记一个事务块的开始。
    4 UNWATCH
    取消 WATCH 命令对所有 key 的监视。
    5 WATCH key [key ...]
    监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。

    Redis 脚本

    Redis 脚本使用 Lua 解释器来执行脚本。 Redis 2.6 版本通过内嵌支持 Lua 环境。执行脚本的常用命令为 EVAL

    语法

    Eval 命令的基本语法如下:

    redis 127.0.0.1:6379> EVAL script numkeys key [key ...] arg [arg ...]

    实例

    以下实例演示了 redis 脚本工作过程:

    redis 127.0.0.1:6379> EVAL "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 key1 key2 first second
    
    1) "key1"
    2) "key2"
    3) "first"
    4) "second"

    Redis 脚本命令

    下表列出了 redis 脚本常用命令:

    序号命令及描述
    1 EVAL script numkeys key [key ...] arg [arg ...]
    执行 Lua 脚本。
    2 EVALSHA sha1 numkeys key [key ...] arg [arg ...]
    执行 Lua 脚本。
    3 SCRIPT EXISTS script [script ...]
    查看指定的脚本是否已经被保存在缓存当中。
    4 SCRIPT FLUSH
    从脚本缓存中移除所有脚本。
    5 SCRIPT KILL
    杀死当前正在运行的 Lua 脚本。
    6 SCRIPT LOAD script
    将脚本 script 添加到脚本缓存中,但并不立即执行这个脚本。

    Redis 连接

    Redis 连接命令主要是用于连接 redis 服务。

    实例

    以下实例演示了客户端如何通过密码验证连接到 redis 服务,并检测服务是否在运行:

    redis 127.0.0.1:6379> AUTH "password"
    OK
    redis 127.0.0.1:6379> PING
    PONG

    Redis 连接命令

    下表列出了 redis 连接的基本命令:

    序号命令及描述
    1 AUTH password
    验证密码是否正确
    2 ECHO message
    打印字符串
    3 PING
    查看服务是否运行
    4 QUIT
    关闭当前连接
    5 SELECT index
    切换到指定的数据库

    Redis 服务器

    Redis 服务器命令主要是用于管理 redis 服务。

    https://www.runoob.com/redis/redis-server.html

    Redis GEO

    Redis GEO 主要用于存储地理位置信息,并对存储的信息进行操作,该功能在 Redis 3.2 版本新增。

    https://www.runoob.com/redis/redis-geo.html

     

  • 相关阅读:
    持久化 XSS:ServiceWorkers 利用
    preg_replace引发的phpmyadmin(4.3.0-4.6.2)命令执行漏洞
    seacms6.5 注入漏洞1
    渗透中常见的网络端口
    composer安装指定版本的ThinkPHP
    php-fpm以root权限运行
    ntp网络时间服务器地址
    查看*.dll文件是32位还是64位的方法
    从经典案例学习SSRF漏洞的产生原因和修复方法
    Apache将AllowOverride设置为All以后出现403 Forbidden的解决方法
  • 原文地址:https://www.cnblogs.com/baldprogrammer/p/13675156.html
Copyright © 2011-2022 走看看