数据库_Redis 入门基础到高级
一、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 入门基础到高级的更多相关文章
- mybatis入门基础(六)----高级映射(一对一,一对多,多对多)
一:订单商品数据模型 1.数据库执行脚本 创建数据库表代码: CREATE TABLE items ( id INT NOT NULL AUTO_INCREMENT, itemsname ) NOT ...
- 《MySQL数据库从入门到精通》 高级运维人才的必备书籍
众所周知,每年就业市场都会迎来千万量级的高校毕业生,然而企业招工难和毕业生就业难的矛盾却一直没有得到很好地解决.究其原因,主要矛盾还是在于传统的学历教育与企业实际需求相脱节.为了杜绝高校毕业生求职时常 ...
- Python学习入门基础教程(learning Python)--5.6 Python读文件操作高级
前文5.2节和5.4节分别就Python下读文件操作做了基础性讲述和提升性介绍,但是仍有些问题,比如在5.4节里涉及到一个多次读文件的问题,实际上我们还没有完全阐述完毕,下面这个图片的问题在哪呢? 问 ...
- HTML入门基础教程相关知识
HTML入门基础教程 html是什么,什么是html通俗解答: html是hypertext markup language的缩写,即超文本标记语言.html是用于创建可从一个平台移植到另一平台的超文 ...
- C#语法——反射,架构师的入门基础。
前言 编程其实就是写代码,而写代码目的就是实现业务,所以,语法和框架也是为了实现业务而存在的.因此,不管多么高大上的目标,实质上都是业务. 所以,我认为不要把写代码上升到科学的高度.上升到艺术就可以了 ...
- Linux入门基础之一
Linux 入门基础 一.Linux 系统安装 安装方法网上很多,请自行百度 二.Linux 基本操作 2.1.GNOME图形界面基本操作 操作类似于Windows系统操作 打开每一个文件夹都会打开一 ...
- mybatis 入门基础
一.Mybatis介绍 MyBatis是一款一流的支持自定义SQL.存储过程和高级映射的持久化框架.MyBatis几乎消除了所有的JDBC代码,也基本不需要手工去设置参数和获取检索结果.MyBatis ...
- HR问了一句DB是啥?SQL是啥?DB是Database数据库,SQL是数据库语言! 然后呢? 数据库从入门到精通--入门必看!
写在前面 本文的写作知识体系来源于我的数据库老师SDAU张承明,部分知识来自于网络,我呢对知识进行了细化和添加了自己的一些看法,并且加入了一些实例帮助理解,本文不是面向SQL高手写的,可以看作是数据库 ...
- mybatis入门基础(二)----原始dao的开发和mapper代理开发
承接上一篇 mybatis入门基础(一) 看过上一篇的朋友,肯定可以看出,里面的MybatisService中存在大量的重复代码,看起来不是很清楚,但第一次那样写,是为了解mybatis的执行步骤,先 ...
随机推荐
- Python编程练习:使用 turtle 库完成玫瑰花的绘制
绘制效果: 源代码: import turtle # 设置初始位置 turtle.penup() turtle.left(90) turtle.fd(200) turtle.pendown() tur ...
- 谈谈Java中的代理模式
首先来看一下代理模式的定义:为其他对象提供一种代理以控制对这个对象的访问.在某些情况下,一个对象不适合或者不能直接引用另一个对象,而代理对象可以在客户端和目标对象之间起到中介的作用, 其特征是代理类与 ...
- Javascript高级编程学习笔记(24)—— 函数表达式(2)闭包
昨天的文章中主要记录了,函数表达式与函数声明的区别 以及在JS中如何安全地使用递归 那么既然要深入地理解JS中的函数,闭包就是一个绕不开的概念 闭包 JS高编一书中对闭包的概念定义如下: 闭包是指有权 ...
- Ubuntu18.04搭建nodejs环境
首先安装sudo apt install curl 然后安装命令(当前最新版本是0.33.2,最新版本可以在https://github.com/creationix/nvm查看): curl -o- ...
- 吴恩达机器学习笔记51-初始值重建的压缩表示与选择主成分的数量K(Reconstruction from Compressed Representation & Choosing The Number K Of Principal Components)
一.初始值重建的压缩表示 在PCA算法里我们可能需要把1000 维的数据压缩100 维特征,或具有三维数据压缩到一二维表示.所以,如果这是一个压缩算法,应该能回到这个压缩表示,回到原有的高维数据的一种 ...
- PHP安装BCMath扩展
我们都知道,大多数编程语言对于浮点型数据格式遵循 IEEE 754 标准,PHP也不例外,这就会导致在使用浮点数运算的过程中会有精度丢失的问题.PHP提供了BCMath库来支持更加精确的计算.但是我的 ...
- jQuery实现遮罩层
1.1 背景半透明遮罩层样式 需要一个黑色(当然也可以其他)背景,且须设置为绝对定位,以下是项目中用到的css样式: /* 半透明的遮罩层 */ #overlay { background: #000 ...
- No bean named 'xxxxx' is defined异常,已解决,这个坑很难发现,你get了吗
出现No bean named 'xxxxx' is defined异常 没有定义名为xxx的bean 如果你的代码写的都对,根本问题只有一个地方出错了,那就是你的 basePackage=的包名路径 ...
- PHP验证码生成及图片处理(GD库)
GD库是php处理图形的扩展库,GD库提供了一系列用来处理图片的API,使用GD库可以处理图片,或者生成图片,也可以给图片加水印. 本章实现了生成图片并绘画各种形状.图片的压缩.中文字符水印及图片水印 ...
- 如何优雅的关闭golang的channel
How to Gracefully Close Channels,这篇博客讲了如何优雅的关闭channel的技巧,好好研读,收获良多. 众所周知,在golang中,关闭或者向已关闭的channel发送 ...