一、PHP消息队列实现及应用

二、消息队列的优缺点

三、消息队列的配置和准备工作

案例如下:

下面是队列表字段及属性

四、Mysql订单队列

1、接受订单,并写入数据 order.php

<?php
//这个文件是用来接受用户的订单信息并写入队列的一个文件 //引入数据库链接类
include '../include/db.php';
//当接收到用户手机号不为空的时候 if(!empty($_GET['mobile'])){
//这里首先是订单中心的处理流程
//因为订单系统是个单独的流程 这里需要处理
//...... 这里不单独写了
//把用户提交的数据进行过滤,防止sql注入
//直接假设个订单号
$order_id = rand(10000,99999);
//生成订单信息
$insert_data = array(
'order_id'=>$order_id,
'mobile'=>$_GET['mobile'],
'created_at'=>date('Y-m-d H:i:s',time()),
'status'=>0,//0未处理 1已处理2处理中
);
//把订单信息存入到队列表中
$db = DB::getIntance();//此处是操作数据库,注意不同的框架有相应的内置的操作方法
$res = $db->insert('order_queue',$insert_data);//insert($table,$data)
if($res){
echo '插入成功'; }else{
echo '插入失败'; } }

2、队列系统处理队列中的订单并进行标识goods.php

<?php
//这个文件主要是配送系统处理队列中的订单并进行标记的一个文件
//加载数据库操作类
include '../include/db.php';
//初始化
$db = DB::getIntance();
//1:先把要处理的记录更新为等待处理(此处要锁定订单,防止处理未完成便被取用)
$waiting = array(‘status’=>0);//等待处理的数据
$lock = array(‘status’=>2);//锁定的数据
$res_lock = $db->update('order_queue',$lock,$waiting,2);//update($table,$data,$where,$limit=0)
//2:选择出刚刚更新的数据,然后进行配送系统的处理
if($res_lock){
//选择出要处理的订单的内容
$res = $db->selectAll('order_queue',$lock);//
//然后由配货系统进行配货处理
//......//此处是配货系统
//3:把处理过的程序更新为已完成
$success = array(
'status'=>1,//已完成
'updated_at'=>date('Y-m-d H:i:s',time()),
);
$res_last = $db->update('order_queue',$success,$lock);
if($res_last){
echo 'Success'.$res_last;
}else{
echo 'Fail'.$res_last;
} }else{
echo 'ALL Finished';
}

3、定时任务。每分钟执行一次goods.sh  要会shell基础

#!/bin/bash

date "+%G-%m-%d %H:%M:S"
cd /home/html/ssggw/queue_mysql/
php goods.php

4、在服务器部署下定时任务crontab -e

为了方便看结果,把定时任务结果输出到日志文件中,设定为标准输出,命令如下

执行命令保存文件:wq

新建日志文件命令

 touch /home/html/ssggw/log.log

监控日志文件

数据库中已经成功两条数据

数据库中已经成功四条数据

解耦案例结束

五、Redis

六、Redis队列实现秒杀

1、创建数据表 redis_queue

2、接受用户请求的程序user.php

<?php
//先加载redis组件
$redis = new Redis();
$redis->connect('127.0.0.1',6379);
$redis_name = "miaosha"; //接受用户id
$uid = $_GET['uid'];
//获取下redis里面已有的数量
$num = 10;//秒杀前10个
//如果当天人数少于10的时候,则加入这个队列
if($redis->lLen($redis_name)<10){
$redis->rFush($redis_name,$uid.'%'.microtime());//将用户uid(连接一个微妙)加入$fredis_name这个队列的尾部
echo "秒杀成功";
}else{
//如果当天人数已经达到了10个人,则返回秒杀已完成
echo "秒杀已结束";
} //关掉redis链接
$redis->close();

3、处理程序,即报数据写入mysql对应数据表savetodb.php

<?php
//引入操作数据库类
include '../include/db.php'; //加载redis组件
$redis = new Redis();
$redis->connect('127.0.0.1',6379);
$redis_name = "miaosha"; $db = DB::getlntance(); //死循环
while(1){
//从队列最左侧取出一个值来
$user = $redis->IPop($redis_name);
//然后判断这个值是否存在
if(!$user || $user =='nil'){
//减少服务器压力 每1秒执行一次 真正的秒杀时间会很短,不用设置
sleep(1);
//跳出循环
continue;
}
//切割出时间,uid
$user_arr = explode('%',$user);
//定义一个数组
$insert_data = array(
'uid'=>$user_arr[0],
'time_stamp'=>$user_arr[1],
);
//保存到数据库中
$res = $db->insert('redis_queue',$insert_data);
//数据库插入失败的时候的回滚机制
if(!$res){
$redis->rPush($redis_name,$user);
}
}
//释放一下redis
$redis->close();

测试

访问user.php文件url

结果

数据库表情况

数据库_Redis 入门基础到高级的更多相关文章

  1. mybatis入门基础(六)----高级映射(一对一,一对多,多对多)

    一:订单商品数据模型 1.数据库执行脚本 创建数据库表代码: CREATE TABLE items ( id INT NOT NULL AUTO_INCREMENT, itemsname ) NOT ...

  2. 《MySQL数据库从入门到精通》 高级运维人才的必备书籍

    众所周知,每年就业市场都会迎来千万量级的高校毕业生,然而企业招工难和毕业生就业难的矛盾却一直没有得到很好地解决.究其原因,主要矛盾还是在于传统的学历教育与企业实际需求相脱节.为了杜绝高校毕业生求职时常 ...

  3. Python学习入门基础教程(learning Python)--5.6 Python读文件操作高级

    前文5.2节和5.4节分别就Python下读文件操作做了基础性讲述和提升性介绍,但是仍有些问题,比如在5.4节里涉及到一个多次读文件的问题,实际上我们还没有完全阐述完毕,下面这个图片的问题在哪呢? 问 ...

  4. HTML入门基础教程相关知识

    HTML入门基础教程 html是什么,什么是html通俗解答: html是hypertext markup language的缩写,即超文本标记语言.html是用于创建可从一个平台移植到另一平台的超文 ...

  5. C#语法——反射,架构师的入门基础。

    前言 编程其实就是写代码,而写代码目的就是实现业务,所以,语法和框架也是为了实现业务而存在的.因此,不管多么高大上的目标,实质上都是业务. 所以,我认为不要把写代码上升到科学的高度.上升到艺术就可以了 ...

  6. Linux入门基础之一

    Linux 入门基础 一.Linux 系统安装 安装方法网上很多,请自行百度 二.Linux 基本操作 2.1.GNOME图形界面基本操作 操作类似于Windows系统操作 打开每一个文件夹都会打开一 ...

  7. mybatis 入门基础

    一.Mybatis介绍 MyBatis是一款一流的支持自定义SQL.存储过程和高级映射的持久化框架.MyBatis几乎消除了所有的JDBC代码,也基本不需要手工去设置参数和获取检索结果.MyBatis ...

  8. HR问了一句DB是啥?SQL是啥?DB是Database数据库,SQL是数据库语言! 然后呢? 数据库从入门到精通--入门必看!

    写在前面 本文的写作知识体系来源于我的数据库老师SDAU张承明,部分知识来自于网络,我呢对知识进行了细化和添加了自己的一些看法,并且加入了一些实例帮助理解,本文不是面向SQL高手写的,可以看作是数据库 ...

  9. mybatis入门基础(二)----原始dao的开发和mapper代理开发

    承接上一篇 mybatis入门基础(一) 看过上一篇的朋友,肯定可以看出,里面的MybatisService中存在大量的重复代码,看起来不是很清楚,但第一次那样写,是为了解mybatis的执行步骤,先 ...

随机推荐

  1. Python编程练习:使用 turtle 库完成正方形的绘制

    绘制效果: 源代码: # 正方形 import turtle turtle.setup(650, 350, 200, 200) turtle.penup() turtle.pendown() turt ...

  2. 超实用的 Nginx 极简教程,覆盖了常用场景

    概述 什么是 Nginx? Nginx (engine x) 是一款轻量级的 Web 服务器 .反向代理服务器及电子邮件(IMAP/POP3)代理服务器. 什么是反向代理? 反向代理(Reverse ...

  3. git常用命令速查:创建,修改提交,撤销,切换分支,合并分支,变基解决冲突

    创建 $ git init  #在当前目录下创建一个空的本地仓库 $ rm -rf  .git  #删除本地仓库 $ git add .  #把当前目录下的所有文件添加到暂存区 $ git commi ...

  4. idea中如何将单个java类导出为jar包文件?

    idea作为一个java开发的便利IDE工具,个人是比较喜欢的,今天来探索个小功能:  导出单个类文件为jar包! 偶有这种需求,就是某个类文件独立存在,但是需要将其导出为jar,供别人临时使用,或者 ...

  5. html 转义处理

    比如要把:<span>test</span> 这段代码当做文本原样输出在页面上,如果按照正常的方式,肯定会被转义,在页面上只能看到 text.那么要想达到预想的效果,应该怎么办 ...

  6. Word文档使用密码加密

    Word文档使用密码加密 方法如下: 文件-->信息-->保护文档-->用密码进行加密-->设置密码

  7. Velocity CheckingForNull

    Q: I want to check for null, something like this: #if ($car.fuel == null) A: There are several appro ...

  8. mysql 开发进阶篇系列 7 锁问题(innodb锁争用情况及锁模式)

    1 .获取innodb行锁争用情况 1.1 通过检查innodb_row_lock状态变量来分析系统上的行锁的争夺情况 SHOW STATUS LIKE 'innodb_row_lock%' 通过in ...

  9. Android UI(二)DridView的菜单

    Jeff Lee blog:   http://www.cnblogs.com/Alandre/  (泥沙砖瓦浆木匠),retain the url when reproduced ! Thanks ...

  10. 2012-2014 三年浙江 acm 省赛 题目 分类

    The 9th Zhejiang Provincial Collegiate Programming Contest A    Taxi Fare    25.57% (166/649)     (水 ...