码迷,mamicode.com
首页 > 其他好文 > 详细

关于秒杀系统的一些想法

时间:2018-02-24 00:49:04      阅读:225      评论:0      收藏:0      [点我收藏+]

标签:并发   get   服务   文章   分布   false   div   random   进程   

关于秒杀系统

       在学习过程中,经常遇到关于秒杀系统的文章,但查阅各种资料,总觉得没一篇文章能完整的讲解秒杀系统是如何实现的。

       秒杀功能常见,但完整的秒杀系统却不是那么经常用到 ,一套完整的秒杀系统涉及到 负载均衡、CDN、分布式、服务集群 等方面的知识。

 

秒杀功能代码的简单实现:

      秒杀功能的实现,其实不外乎 3 种方式:

     1. 单进程  ( 用户量大时,体验不友好),

     2. 锁 ( 用户量大时,并发,容易产生不可预期的问题 如: 死锁等),

     3. 队列  (  相对推荐 )

 

  Redis 队列的简单实现

$ttl = 4;
$random = mt_rand(1,1000).‘-‘.gettimeofday(true).‘-‘.mt_rand(1,1000);

$lock = fasle;
while (!$lock) {
    $lock = $redis->set(‘lock‘, $random, array(‘nx‘, ‘ex‘ => $ttl));
}

if ($redis->get(‘goods.num‘) <= 0) {
    echo ("秒杀已经结束");
    //删除锁
    if ($redis->get(‘lock‘) == $random) {
        $redis->del(‘lock‘);
    }
    return false;
}

$redis->decr(‘goods.num‘);
echo ("秒杀成功");
//删除锁
if ($redis->get(‘lock‘) == $random) {
    $redis->del(‘lock‘);
}
return true;

 

关于秒杀系统的一些想法

标签:并发   get   服务   文章   分布   false   div   random   进程   

原文地址:https://www.cnblogs.com/yangs0/p/8463788.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!