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

商丘做网站的哪家好百度趋势搜索

商丘做网站的哪家好,百度趋势搜索,建湖做网站找哪家好,茂名网站制作1.简述 redis队列一般用于缓解数据库压力 ,诸如秒杀,邮件群发,消息推送等等 redis的加入能很好的 帮助系统中 各个模块解耦。 而Redis不仅可作为缓存服务器,还可用作消息队列。它的列表类型天生支持用作消息队列。如下图所示…

1.简述

redis队列一般用于缓解数据库压力  ,诸如秒杀,邮件群发,消息推送等等

redis的加入能很好的  帮助系统中 各个模块解耦。

而Redis不仅可作为缓存服务器,还可用作消息队列。它的列表类型天生支持用作消息队列。如下图所示:

对于服务器减少io 压力 有一定的帮助

2.秒杀的原理

秒杀基本原理比较简单

用户点击抢购按钮 ->  把uid 和时间存入redis的队列中  -> 服务器中有一个入库程序不停轮询redis队列是否有数据 -> 如果有存入数据库

这里面有2点需要注意一下:

1. 插入队列的时候 ,需要判断库传,不能出现多插入

2. 在入库的时候 如果出现数据插入失败的情况  需要进行回滚

3.秒杀的代码实现

用户操作秒杀:

header("Content-type: text/html; charset=utf-8");
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);$redis_name= "miaosha";
//库存
$nums = 10;
//用户id
$user_id = $_GET['uid'];
if(($redis->llen($redis_name)) <  $nums ){$redis->lpush($redis_name,json_encode(array('uid'=>$user_id,'time'=>microtime())));echo $user_id."秒杀成功!";exit();
}else{echo "秒杀失败!";exit();
}
$redis->close();

后台处理秒杀队列:

header("Content-type: text/html; charset=utf-8");
error_reporting(E_ALL);
require_once './db.php';
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);$redis_name = "miaosha";//数据库
$configs =array('host'=>'127.0.0.1','port'=>'3306','user'=>'***','passwd'=>'','dbname'=>'test');
$mysql = new MMysql($configs);//处理开始
while ($count = $redis->lLen($redis_name)) {$task = $redis->rpop($redis_name);$taskdata = json_decode($task, true);$data = array('uid'=>$taskdata['uid'],'time'=>$taskdata['time'],);$rs = $mysql->insert('redis',$data);if(!$rs){//由于我们是在右边取,所以如果数据插入失败了要从左边放回去(重新排队),以免影响队列中其他元素的处理$redis->lpush($redis_name,$task);echo "处理失败<br>";}else{echo "处理成功<br>";}sleep(1);
}$redis->close();

4.关于redis里的锁

4.1  先说一下乐观锁

乐观锁,顾名思义,乐观的认为数据不会被修改,只有当更新时才去判断数据是否被修改过,通常用版本号或时间戳来实现。

redis中的事务通过watch和multi来实现。

WATCH命令可以监控一个或多个键,一旦其中有一个键被修改(或删除),之后的事务就不会执行。监控一直持续到EXEC命令(事务中的命令是在EXEC之后才执行的,所以在MULTI命令后可以修改WATCH监控的键值)

$redis = new Redis();
$redis->connect('127.0.0.1', 6379, 60);//
$tnums = $redis->get('goods_stock_nums');//设置商品的库存
if($tnums==0){echo "活动已经结束,明天请早end!";exit();
}//监视该key
$redis->watch('goods_stock_nums');//sleep(5);
//开启事务
$redis->multi();//修改库存数
$redis->decr('goods_stock_nums');//提交事务,如果在此期间有其他请求修改了该key,那么事务会失败
if ($redis->exec()) {echo '抢购成功suc';
} else {echo '数据错误,请重新再试fail';
}

可以看到我在程序中加入了sleep(5) 这行代码。

这是方便我在客户端去实验

如果我在运行上面这段代码过程中,我用客户端修改了这个值。

那么上面这段代码就会失败,返回  数据错误,请重新再试fail

4.2  再说一下 悲观锁

function getRedis()
{$redis = new Redis();$redis->connect('127.0.0.1', 6379, 60);return $redis;
}function lock($key, $random)
{$redis = getRedis();return $redis->set($key, $random, ['nx', 'ex' => 3]);
}function unlock($key, $random)
{$redis = getRedis();//使用lua脚本保证原子性$script = 'if redis.call("get",KEYS[1]) == ARGV[1] then return redis.call("del",KEYS[1]) else return 0 end';return $redis->eval($script, [$key, $random], 1);
}function decrGoodsStockNums()
{$redis = getRedis();//获取商品库存数$ret = $redis->get('goods_stock_nums');if ($ret === false) {return false;}if ($ret <= 0) {return false;}$random = mt_rand();//先获取锁if (lock('goods_stock_nums_lock', $random)) {//修改库存数$redis->decr('goods_stock_nums');//释放锁unlock('goods_stock_nums_lock', $random);return true;} else {usleep(100);decrGoodsStockNums();}
}decrGoodsStockNums();

上面这段引用别人的代码

但是这种锁的机制还是不能保证事务的安全

http://www.dtcms.com/wzjs/161636.html

相关文章:

  • 做网站运营需要做哪些网站收录入口申请查询
  • wordpress相关文章插件seo搜索引擎优化知乎
  • 网站域名301重定向百度助手app下载安装
  • 深圳网站定制价格表文件关键词搜索工具
  • 西安北郊做网站公司全媒体运营师培训
  • 上海的网站建设公司哪家好怎么在百度投放广告
  • 青岛做网站建设价格站长平台官网
  • 网站推广方案设计seo发展前景怎么样啊
  • 喀什百度做网站多少钱为什么外包会是简历污点
  • 在线网站建设培训班响应式网站模板的优势
  • app定制开发哪个公司好seo关键词排名
  • 做互联网网站待遇网络营销名词解释
  • 卖印花图案设计网站口碑营销方案
  • 武汉做营销型网站百度问一问付费咨询
  • 邢台专业做移动网站网页设计费用报价
  • 汽车租赁网站建设内容深圳企业黄页网
  • 宝鸡做网站企业宣传软文范例
  • 室内在线设计网站百度应用商店app
  • 房产网站运营方案自贡网站seo
  • 陶哲轩博客wordpress济南网站seo优化
  • 设计一个网站代码成品网站货源1688在线
  • 自己做的网站页面错误创建app平台
  • 内蒙古网站建设南宁seo公司
  • 网站建设 源码关键词搜索排名软件
  • 微信网站模板seo优化网站技术排名百度推广
  • 寝室网页设计图片app排名优化公司
  • 网站建设合同付款约定小程序开发需要哪些技术
  • 企业网站是否可以做淘宝客德州百度推广公司
  • iis网站突然无法访问seo网站结构优化的方法
  • 宁波企业网站建设公司怎样在百度上免费建网站