一个小小的签到功能,到底用MySQL还是Redis?


prtyaa
prtyaa 2023-12-31 22:46:49 51699
分类专栏: 资讯

现在的网站和app开发中,签到是一个很常见的功能

如微博签到送积分,签到排行榜

如移动app ,签到送流量等活动,

用户签到是提高用户粘性的有效手段,用的好能事半功倍!

下面我们从技术方面看看常用的实现手段:

一. 方案1

直接存到数据库MySQL

用户表如下:

last_checkin_time 上次签到时间

checkin_count 连续签到次数

记录每个用户签到信息

签到流程

1.用户第一次签到

last_checkin_time = time()
checkin_count=1

2.用户非第一次签到,且当天已签到

什么也不做,返回已签到。

3.用户非第一次签到,且当天还未签到

a.昨天也有签到

last_checkin_time = time()
checkin_count= checkin_count+1

b.昨天没有签到

last_checkin_time = time()  
checkin_count=1

使用yii实现的代码如下:

//0点
$today_0 = strtotime(date('y-m-d'));
//昨天0点
$yesterday_0 = $today_0-24*60*60;
$last_checkin_time = $model->last_checkin_time;if(empty($last_checkin_time)){
 //first checkin
 $model->last_checkin_time = time();
 $model->checkin_count = 1;  
}else{
 if($today_0 < $last_checkin_time){
  //checkin ed 当天已签到过
  return json_encode(['code' => 0, 'msg' => '已签到成功']);
 } //昨天签到过 if($last_checkin_time < $today_0 && $last_checkin_time > $yesterday_0){
  $model->last_checkin_time = time();
  $model->checkin_count = $model->checkin_count + 1; 
 }else{
  //昨天没签到过,重新计数
  $model->last_checkin_time = time();
  $model->checkin_count = 1;
 }}$rs = $model->save();

二. 方案2

redis实现方案,使用bitmap来实现,bitmap是redis 2.2版本开始支持的功能,一般用于标识状态,

另外 ,用bitmap进行当天有多少人签到非常的方便,使用bitcount

$count = $redis->BITCOUNT($key);

签到流程

设置两个bitmap ,

一个以每天日期为key ,每个uid为偏移量

一个以用户uid为key ,当天在一年中的索引为偏移量,

这样记录一个用户一年的签到情况仅需要365*1bit

以下是签到代码

//每天一个key
  $key = 'checkin_' . date('ymd');
  if($redis->getbit($key, $uid)){
   //已签到   return json_encode(['code' => 0, 'msg' => '已签到成功']);
  }else{
   //签到   $redis->setbit($key, $uid, 1);
   $redis->setbit('checkin_'.$uid , date('z'), 1);
  }

以下是用户连续签到计算

public static function getUserCheckinCount($uid){
  $key =  'checkin_'.$uid;
  $index = date('z');
  $n = 0;
  for($i = $index; $i>=0;$i--){
   $bit = Yii::$app->redis->getbit($key, $i);   if($bit == 0) break;
   $n++;  }  return $n;
 }

以下是计算一天签到用户数

$key = 'checkin_' . date('ymd');
$redis = Yii::$app->redis;$count = $redis->BITCOUNT($key);

还有什么需求呢?可以自己试着去实现

三. 优缺点比较

1.直接MySQL

思路简单,容易实现;

缺点:

  • 占用空间大,表更新比较多,影响性能,数据量大时需要用cache辅助;

2.Redis bitmap

优点是:

  • 占用空间很小,纯内存操作,速度快;

缺点是 :

  • 记录的信息有限,只有一个标识位;
  • 偏移量不能大于2^32,512M;大概可以标识5亿个bit位,绝大多数的应用都是够用的啦;
  • 偏移量很大的时候可能造成 Redis 服务器被阻塞;所以要考虑切分。

好啦,两种方式介绍完了,各有利弊,你喜欢哪种方式呢?

网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。

本文链接:https://www.xckfsq.com/news/show.html?id=33440
赞同 0
评论 0 条
prtyaaL2
粉丝 1 发表 2553 + 关注 私信
上周热门
如何使用 StarRocks 管理和优化数据湖中的数据?  2947
【软件正版化】软件正版化工作要点  2867
统信UOS试玩黑神话:悟空  2828
信刻光盘安全隔离与信息交换系统  2723
镜舟科技与中启乘数科技达成战略合作,共筑数据服务新生态  1256
grub引导程序无法找到指定设备和分区  1221
华为全联接大会2024丨软通动力分论坛精彩议程抢先看!  164
点击报名 | 京东2025校招进校行程预告  163
2024海洋能源产业融合发展论坛暨博览会同期活动-海洋能源与数字化智能化论坛成功举办  162
华为纯血鸿蒙正式版9月底见!但Mate 70的内情还得接着挖...  157
本周热议
我的信创开放社区兼职赚钱历程 40
今天你签到了吗? 27
如何玩转信创开放社区—从小白进阶到专家 15
信创开放社区邀请他人注册的具体步骤如下 15
方德桌面操作系统 14
用抖音玩法闯信创开放社区——用平台宣传企业产品服务 13
我有15积分有什么用? 13
如何让你先人一步获得悬赏问题信息?(创作者必看) 12
2024中国信创产业发展大会暨中国信息科技创新与应用博览会 9
中央国家机关政府采购中心:应当将CPU、操作系统符合安全可靠测评要求纳入采购需求 8

加入交流群

请使用微信扫一扫!