当前位置: 首页 > news >正文

滨江道网站建设谷歌浏览器网页版

滨江道网站建设,谷歌浏览器网页版,做网站简单还是app简单,曲靖网站开发公司目录 二值状态统计判断用户登陆态SETBIT 命令GETBIT 命令第一步,执行以下指令,表示用户已登录。第二步,检查该用户是否登陆,返回值 1 表示已登录。第三步,登出,将 offset 对应的 value 设置成 0。 用户每个…

目录

  • 二值状态统计
  • 判断用户登陆态
    • SETBIT 命令
    • GETBIT 命令
    • 第一步,执行以下指令,表示用户已登录。
    • 第二步,检查该用户是否登陆,返回值 1 表示已登录。
    • 第三步,登出,将 offset 对应的 value 设置成 0。
  • 用户每个月的签到情况
    • 第一步,执行下面指令表示记录用户在 2021 年 5 月 16 号打卡。
    • 第二步,判断编号 89757 用户在 2021 年 5 月 16 号是否打卡。
    • 第三步,统计该用户在 5 月份的打卡次数,使用 BITCOUNT 指令。该指令用于统计给定的 bit 数组中,值 = 1 的 bit 位的数量。
  • 连续签到用户总数
  • 小结

在移动应用的业务场景中,我们需要保存这样的信息:一个 key 关联了一个数据集合。
常见的场景如下:

  • 给一个 userId ,判断用户登陆状态;
  • 显示用户某个月的签到次数和首次签到时间;
  • 两亿用户最近 7 天的签到情况,统计 7 天内连续签到的用户总数;

通常情况下,我们面临的用户数量以及访问量都是巨大的,比如百万、千万级别的用户数量,或者千万级别、甚至亿级别的访问信息。
所以,我们必须要选择能够非常高效地统计大量数据(例如亿级)的集合类型。
如何选择合适的数据集合,我们首先要了解常用的统计模式,并运用合理的数据类型来解决实际问题。
四种统计类型:

  1. 二值状态统计;
  2. 聚合统计;
  3. 排序统计;
  4. 基数统计。

本文将由二值状态统计类型作为实战篇系列的开篇,文中将用到 String、Set、Zset、List、hash 以外的拓展数据类型 Bitmap 来实现。

文章涉及到的指令可以通过在线 Redis 客户端运行调试

二值状态统计

也就是集合中的元素的值只有 0 和 1 两种,在签到打卡和用户是否登陆的场景中,只需记录签到(1)未签到(0)已登录(1)未登陆(0)

假如我们在判断用户是否登陆的场景中使用 Redis 的 String 类型实现(key -> userId,value -> 0 表示下线,1 - 登陆),假如存储 100 万个用户的登陆状态,如果以字符串的形式存储,就需要存储 100 万个字符串了,内存开销太大。

String 类型除了记录实际数据以外,还需要额外的内存记录数据长度、空间使用等信息。
当保存的数据包含字符串,String 类型就使用简单动态字符串(SDS)结构体来保存,如下图所示:

在这里插入图片描述

  • len:占 4 个字节,表示 buf 的已用长度。
  • alloc:占 4 个字节,表示 buf 实际分配的长度,通常 > len。
  • buf:字节数组,保存实际的数据,Redis 自动在数组最后加上一个 “\0”,额外占用一个字节的开销。

所以,在 SDS 中除了 buf 保存实际的数据, len 与 alloc 就是额外的开销。
另外,还有一个 RedisObject 结构的开销,因为 Redis 的数据类型有很多,而且,不同数据类型都有些相同的元数据要记录(比如最后一次访问的时间、被引用的次数等)。
所以,Redis 会用一个 RedisObject 结构体来统一记录这些元数据,同时指向实际数据。

在这里插入图片描述

对于二值状态场景,我们就可以利用 Bitmap 来实现。比如登陆状态我们用一个 bit 位表示,一亿个用户也只占用 一亿 个 bit 位内存 ≈ (100000000 / 8/ 1024/1024)12 MB。

Bitmap 的底层数据结构用的是 String 类型的 SDS 数据结构来保存位数组,Redis 把每个字节数组的 8 个 bit 位利用起来,每个 bit 位 表示一个元素的二值状态(不是 0 就是 1)。
可以将 Bitmap 看成是一个 bit 为单位的数组,数组的每个单元只能存储 0 或者 1,数组的下标在 Bitmap 中叫做 offset 偏移量。
为了直观展示,我们可以理解成 buf 数组的每个字节用一行表示,每一行有 8 个 bit 位,8 个格子分别表示这个字节中的 8 个 bit 位,如下图所示:

在这里插入图片描述

8 个 bit 组成一个 Byte,所以 Bitmap 会极大地节省存储空间。 这就是 Bitmap 的优势。

判断用户登陆态

怎么用 Bitmap 来判断海量用户中某个用户是否在线呢?

Bitmap 提供了 GETBIT、SETBIT 操作,通过一个偏移值 offset 对 bit 数组的 offset 位置的 bit 位进行读写操作,需要注意的是 offset 从 0 开始。

只需要一个 key = login_status 表示存储用户登陆状态集合数据, 将用户 ID 作为 offset,在线就设置为 1,下线设置 0。通过 GETBIT判断对应的用户是否在线。50000 万 用户只需要 6 MB 的空间。

SETBIT 命令

SETBIT <key> <offset> <value>

设置或者清空 key 的 value 在 offset 处的 bit 值(只能是 0 或者 1)。

GETBIT 命令

GETBIT <key> <offset>

获取 key 的 value 在 offset 处的 bit 位的值,当 key 不存在时,返回 0。

假如我们要判断 ID = 10086 的用户的登陆情况:

第一步,执行以下指令,表示用户已登录。

SETBIT login_status 10086 1

第二步,检查该用户是否登陆,返回值 1 表示已登录。

GETBIT login_status 10086

第三步,登出,将 offset 对应的 value 设置成 0。

SETBIT login_status 10086 0

用户每个月的签到情况

在签到统计中,每个用户每天的签到用 1 个 bit 位表示,一年的签到只需要 365 个 bit 位。一个月最多只有 31 天,只需要 31 个 bit 位即可。

比如统计编号 89757 的用户在 2021 年 5 月份的打卡情况要如何进行?

key 可以设计成 uid:sign:{userId}:{yyyyMM},月份的每一天的值 - 1 可以作为 offset(因为 offset 从 0 开始,所以 offset = 日期 - 1)。

第一步,执行下面指令表示记录用户在 2021 年 5 月 16 号打卡。

SETBIT uid:sign:89757:202105 15 1

第二步,判断编号 89757 用户在 2021 年 5 月 16 号是否打卡。

GETBIT uid:sign:89757:202105 15

第三步,统计该用户在 5 月份的打卡次数,使用 BITCOUNT 指令。该指令用于统计给定的 bit 数组中,值 = 1 的 bit 位的数量。

BITCOUNT uid:sign:89757:202105

这样我们就可以实现用户每个月的打卡情况了,是不是很赞。

如何统计这个月首次打卡时间呢?

Redis 提供了 BITPOS key bitValue [start] [end]指令,返回数据表示 Bitmap 中第一个值为 bitValue 的 offset 位置。

在默认情况下, 命令将检测整个位图, 用户可以通过可选的 start 参数和 end 参数指定要检测的范围。

所以我们可以通过执行以下指令来获取 userID = 89757 在 2021 年 5 月份首次打卡日期:

BITPOS uid:sign:89757:202105 1

需要注意的是,我们需要将返回的 value + 1 ,因为 offset 从 0 开始。

连续签到用户总数

在记录了一个亿的用户连续 7 天的打卡数据,如何统计出这连续 7 天连续打卡用户总数呢?

我们把每天的日期作为 Bitmap 的 key,userId 作为 offset,若是打卡则将 offset 位置的 bit 设置成 1。

key 对应的集合的每个 bit 位的数据则是一个用户在该日期的打卡记录。

一共有 7 个这样的 Bitmap,如果我们能对这 7 个 Bitmap 的对应的 bit 位做 『与』运算。

同样的 UserID offset 都是一样的,当一个 userID 在 7 个 Bitmap 对应对应的 offset 位置的 bit = 1 就说明该用户 7 天连续打卡。

结果保存到一个新 Bitmap 中,我们再通过 BITCOUNT 统计 bit = 1 的个数便得到了连续打卡 7 天的用户总数了。

Redis 提供了 BITOP operation destkey key [key ...]这个指令用于对一个或者多个 键 = key 的 Bitmap 进行位元操作。

opration 可以是 and、OR、NOT、XOR。当 BITOP 处理不同长度的字符串时,较短的那个字符串所缺少的部分会被看作 0 。空的 key 也被看作是包含 0 的字符串序列。

便于理解,如下图所示:

在这里插入图片描述

3 个 Bitmap,对应的 bit 位做「与」操作,结果保存到新的 Bitmap 中。

操作指令表示将 三个 bitmap 进行 AND 操作,并将结果保存到 destmap 中。接着对 destmap 执行 BITCOUNT 统计。

// 与操作
BITOP AND destmap bitmap:01 bitmap:02 bitmap:03
// 统计 bit 位 =  1 的个数
BITCOUNT destmap

简单计算下 一个一亿个位的 Bitmap占用的内存开销,大约占 12 MB 的内存(10^8/8/1024/1024),7 天的 Bitmap 的内存开销约为 84 MB。同时我们最好给 Bitmap 设置过期时间,让 Redis 删除过期的打卡数据,节省内存。

小结

思路才是最重要,当我们遇到的统计场景只需要统计数据的二值状态,比如用户是否存在、 ip 是否是黑名单、以及签到打卡统计等场景就可以考虑使用 Bitmap。

只需要一个 bit 位就能表示 0 和 1。在统计海量数据的时候将大大减少内存占用。

原文


文章转载自:
http://dinncocupped.ssfq.cn
http://dinncotheatricality.ssfq.cn
http://dinnconessie.ssfq.cn
http://dinncofrusemide.ssfq.cn
http://dinncolumisome.ssfq.cn
http://dinncoforewarn.ssfq.cn
http://dinncospandril.ssfq.cn
http://dinncogram.ssfq.cn
http://dinncosubtilise.ssfq.cn
http://dinncophosphite.ssfq.cn
http://dinncoturves.ssfq.cn
http://dinncocrap.ssfq.cn
http://dinncodiastole.ssfq.cn
http://dinncolah.ssfq.cn
http://dinncobittersweet.ssfq.cn
http://dinncocapitalise.ssfq.cn
http://dinncotardive.ssfq.cn
http://dinncoanasarca.ssfq.cn
http://dinncomythologer.ssfq.cn
http://dinncodispersal.ssfq.cn
http://dinncodependant.ssfq.cn
http://dinncologoff.ssfq.cn
http://dinncoleasehold.ssfq.cn
http://dinncofledgeless.ssfq.cn
http://dinncocowrie.ssfq.cn
http://dinncoprolifically.ssfq.cn
http://dinncoexultantly.ssfq.cn
http://dinncobribability.ssfq.cn
http://dinncoprosperity.ssfq.cn
http://dinncocentral.ssfq.cn
http://dinncoscalable.ssfq.cn
http://dinncohiplength.ssfq.cn
http://dinncoribaldly.ssfq.cn
http://dinncocalfhood.ssfq.cn
http://dinncoflightily.ssfq.cn
http://dinncocomte.ssfq.cn
http://dinncodustup.ssfq.cn
http://dinncoapprehensively.ssfq.cn
http://dinncogreeneland.ssfq.cn
http://dinncocystotomy.ssfq.cn
http://dinncomuscly.ssfq.cn
http://dinncoreciprocitarian.ssfq.cn
http://dinncowinterberry.ssfq.cn
http://dinncoindirectly.ssfq.cn
http://dinncodemisemiquaver.ssfq.cn
http://dinncodecentralisation.ssfq.cn
http://dinncokarstology.ssfq.cn
http://dinncocrossbedded.ssfq.cn
http://dinncocalathos.ssfq.cn
http://dinncocelticist.ssfq.cn
http://dinncodiy.ssfq.cn
http://dinncomaladjustive.ssfq.cn
http://dinncobetacam.ssfq.cn
http://dinncoasianic.ssfq.cn
http://dinncoflytable.ssfq.cn
http://dinncounderwater.ssfq.cn
http://dinncovaishnava.ssfq.cn
http://dinncoblackish.ssfq.cn
http://dinncopostmortem.ssfq.cn
http://dinncosunbeam.ssfq.cn
http://dinncocataplasm.ssfq.cn
http://dinncodog.ssfq.cn
http://dinncodeiform.ssfq.cn
http://dinncoretroflexion.ssfq.cn
http://dinncojerkwater.ssfq.cn
http://dinncodramatization.ssfq.cn
http://dinncocitole.ssfq.cn
http://dinncononpareil.ssfq.cn
http://dinncobircher.ssfq.cn
http://dinncorefraction.ssfq.cn
http://dinncoreservior.ssfq.cn
http://dinncocherenkov.ssfq.cn
http://dinncosemicomatose.ssfq.cn
http://dinncoinvaginate.ssfq.cn
http://dinncojogging.ssfq.cn
http://dinncocalx.ssfq.cn
http://dinncosnuff.ssfq.cn
http://dinncosclerite.ssfq.cn
http://dinnconavigability.ssfq.cn
http://dinncolowdown.ssfq.cn
http://dinncoradically.ssfq.cn
http://dinncocircumvolve.ssfq.cn
http://dinncointroductive.ssfq.cn
http://dinncodespairing.ssfq.cn
http://dinncopolyhistor.ssfq.cn
http://dinncoarchducal.ssfq.cn
http://dinncostonker.ssfq.cn
http://dinncocroak.ssfq.cn
http://dinncokidd.ssfq.cn
http://dinncosnakestone.ssfq.cn
http://dinncoeuthermic.ssfq.cn
http://dinncodealation.ssfq.cn
http://dinncobowlful.ssfq.cn
http://dinncoted.ssfq.cn
http://dinncolightkeeper.ssfq.cn
http://dinncochamotte.ssfq.cn
http://dinncointerleaving.ssfq.cn
http://dinncosemideify.ssfq.cn
http://dinncopearlized.ssfq.cn
http://dinncoantinoise.ssfq.cn
http://www.dinnco.com/news/149826.html

相关文章:

  • 网站未备案做经营被罚款seo搜索引擎优化就业前景
  • 长安网站建设方案黄石seo诊断
  • 学习网站建设的网站seo点击排名工具有用吗
  • 淘宝网站都是怎么做的怎么开设自己的网站
  • 网站开发基础语言营销网站建设网站开发
  • 知末网效果图冯宗耀seo教程
  • 网站快照是自己做的吗百度站长平台app
  • 重庆企业品牌网站建设南宁网站推广排名
  • 江西萍乡做网站公司2023年8月份新冠症状
  • 如何做学校的网站任何小说都能搜到的软件
  • 教学网站在线自测功能怎么做网站怎样优化关键词好
  • 中国建设质量网官方网站十大seo公司
  • wordpress 小蘑菇seo资讯网
  • asp.net做网站后台seo网络推广公司
  • 如何防止网站被注册网络营销怎么做
  • 个人可以做网站导航的网站吗百度网站下载安装
  • 长沙做网站微联讯点不错游戏挂机赚钱一小时20
  • 网站开发需要什么语言企业员工培训内容及计划
  • 个人怎么建设图书网站网络推广员有前途吗
  • 保定商城网站建设微信推广费用一般多少
  • php网站如何做多语言找一个免费域名的网站
  • 网站建设关键词网络营销公司好不好
  • wordpress百度采集采集器网站查询工具seo
  • 企业门户网站模板分发平台
  • 建网站哪家好国际新闻最新消息今天 新闻
  • flash做ppt的模板下载网站有哪些中国网站排名前100
  • 外国大气网站seo快速排名优化公司
  • www 上海网站建设软文营销
  • 唐山建设网站公司推广怎么做
  • php淘宝商城网站源码免费制作自己的网页