ディレクトリ 検索
Cluster cluster addslots(集群 槽位) cluster count failure reports(集群计数失败报告) cluster countkeysinslot cluster delslots cluster failover cluster forget cluster getkeysinslot cluster info cluster keyslot(集群键槽) cluster meet cluster nodes(集群节点) cluster replicate(集群复制) cluster reset(集群重置) cluster saveconfig cluster set config epoch cluster setslot cluster slaves cluster slots readonly readwrite Connection auth echo ping quit select swapdb Geo geoadd geodist geohash geopos georadius georadiusbymember Hashes hdel hexists hget hgetall hincrby hincrbyfloat hkeys hlen hmget hmset hscan hset hsetnx hstrlen hvals HyperLogLog pfadd pfcount pfmerge Keys del dump exists expire expireat keys migrate move object persist pexpire pexpireat pttl randomkey rename renamenx restore scan sort touch ttl type unlink wait Lists blpop brpop brpoplpush lindex linsert llen lpop lpush lpushx lrange lrem lset ltrim rpop rpoplpush rpush rpushx Pub/Sub psubscribe publish pubsub punsubscribe subscribe unsubscribe Scripting eval evalsha script debug script exists script flush script kill script load Server bgrewriteaof bgsave client getname client kill client list client pause client reply client setname command command count command getkeys command info config get config resetstat config rewrite config set dbsize debug object debug segfault flushall flushdb info lastsave monitor role save shutdown slaveof slowlog time Sets sadd scard sdiff sdiffstore sinter sinterstore sismember smembers smove spop srandmember srem sscan sunion sunionstore Sorted Sets zadd zcard zcount zincrby zinterstore zlexcount zrange zrangebylex zrangebyscore zrank zrem zremrangebylex zremrangebyrank zremrangebyscore zrevrange zrevrangebylex zrevrangebyscore zrevrank zscan zscore zunionstore Strings append bitcount bitfield bitop bitpos decr decrby get getbit getrange getset incr incrby incrbyfloat mget mset msetnx psetex set setbit setex setnx setrange strlen Transactions discard exec multi unwatch watch
テキスト

BITCOUNT key [start end]

自2.6.0起可用。

时间复杂度: O(N)

计算字符串中的设置位数(人口计数)。

默认情况下,会检查字符串中包含的所有字节。只能在传递附加参数 start end 的间隔中指定计数操作。

与 GETRANGE 命令类似,开始和结束可以包含负值,以便从字符串的末尾开始索引字节,其中-1是最后一个字节,-2是倒数第二个字符,等等。

不存在的键被视为空字符串,因此该命令将返回零。

返回值

整数回复

位数设置为1。

例子

redis>  SET mykey "foobar" "OK" redis>  BITCOUNT mykey (integer) 26 redis>  BITCOUNT mykey 0 0 (integer) 4 redis>  BITCOUNT mykey 1 1 (integer) 6

模式:使用位图的实时指标

位图是某些类型信息的非常节省空间的表示。一个例子是需要用户访问历史记录的 Web 应用程序,例如,可以确定哪些用户是测试版功能的良好目标。

使用 SETBIT 命令可以很轻松地完成,每天用一个小渐进整数标识。例如,第0天是应用程序上线的第一天,第二天的第1天等等。

每次用户执行页面查看时,应用程序都可以在当天使用 SETBIT 命令访问网站,并设置当天对应的位。

稍后,知道用户访问网站的单天数量简单地调用 BITCOUNT 命令对位图将是微不足道的。

在名为“ 使用Redis位图的快速简单实时指标 ”的文章中介绍了使用用户标识代替天数的类似模式。

性能考虑

在上述计算日期的示例中,即使10年后应用程序处于联机状态,我们仍然只有365*10每位用户的数据位,即每位用户只有456个字节。有了这个数据量,BITCOUNT 仍然像任何其他O(1)Redis命令一样快,如 GET 或 INCR 。

当位图很大时,有两种选择:

  • 采取每次修改位图时分离的密钥。使用小型 Redis Lua 脚本,这可以非常高效并且原子化。

  • 使用 BITCOUNT 开始结束可选参数递增地运行位图,累积客户端的结果,并可选择将结果缓存到密钥中。

前の記事: 次の記事: