一、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爬虫学习之日志记录模块

    这次的代码就是一个日志记录模块,代码很容易懂,注释很详细,也不需要安装什么库.提供的功能是日志可以显示在屏幕上并且保存在日志文件中.调用的方式也很简单,测试代码里面有. 源代码: #encoding= ...

  2. Hadoop 电话通信清单

    一.实例要求 现有一批电话通信清单,记录了用户A拨打某些特殊号码(如120,10086,13800138000等)的记录.需要做一个统计结果,记录拨打给用户B的所有用户A. 二.测试样例 样例输入: ...

  3. Javascript高级编程学习笔记(58)—— 事件(2)事件处理程序

    事件处理程序 事件处理程序即响应某个事件的函数 事件处理程序以 “on” 开头 如“onclick”,“onload” HTML事件处理程序 某个元素支持的每种事件都可以使用一个与响应的事件处理程序同 ...

  4. 吴恩达机器学习笔记5-梯度下降I(Gradient descent intuition)

    梯度下降是一个用来求函数最小值的算法,我们将使用梯度下降算法来求出代价函数

  5. Android精通之Handler讲解

    版权声明:未经博主允许不得转载 一:简介 [达叔有道]软件技术人员,时代作者,从 Android 到全栈之路,我相信你也可以!阅读他的文章,会上瘾!You and me, we are family ...

  6. python之asyncio

    asyncio是Python 3.4版本引入的标准库,直接内置了对异步IO的支持. asnycio是用来编写并发代码的库,python3.5以后使用async/await语法. asyncio 被用作 ...

  7. FileZilla 使用笔记

    FileZilla 使用了三年了,一些功能其实还没有主动去发现,这次接着项目忙完的空闲时间整理一下 Tips,提高工作效率,方便以后查阅. 一.好用的功能 1.Site Manager - 站点管理器 ...

  8. 利用vi编辑器创建和编辑正文文件(二)

    末行模式下的命令 1.       w:写文件,将编辑的内容保存到文件系统. 2.       w!:如果只读文件,强制写入系统. 3.       q!:退出vi,但文件内容修改的话,系统要提示是否 ...

  9. Nexus私服搭建

    maven私服的搭建 --> maven -->{ 1,本地仓库(从中央仓库下载保存到本地的或者自己到网上下载的jar文件包) 2,远程仓库 -->{ 1,中央仓库(maven官方j ...

  10. Django | 页面数据的缓存与使用

    为什么要使用缓存? 一个动态网站的基本权衡点就是,它是动态的. 每次用户请求页面,服务器会重新计算.从开销处理的角度来看,这比你读取一个现成的标准文件的代价要昂贵的多 使用缓存,将多用户访问时基本相同 ...