php+redis消息队列是php+mysql性能不足时的一个中间间处理方案。通过这个中间的处理,保证的数据的可用性和准确性。用于服务器瞬间请求大,数据库压力大的情况。如并发量大导致的超卖、并发量大导致的数据重复情况。
流程:php接受请求和数据 -> php把数据写入redis队列中(入队) -> shell定时调用php读取队列数据写入mysql(出队)
实现代码:
入队:inqueue.php
<?php
$redis = new redis();
$redis->connect('127.0.0.1',6379);
$redis -> select('1');
$redis->auth('');
$data = [a,b,c,d,e,f,g,h]; //这里可以是get或post请求过来的数据
$data = json_encode($data);
$in = $redis->rpush('queue',$data);
if($in){
echo "入队成功";
}
出队:outqueue.php
#!/usr/bin/php
<?php
$redis = new redis();
$redis->connect('127.0.0.1',6379);
$redis -> select('1');
$redis->auth('');
$value = $redis->lpop('queue');
$value = json_decode($value,true);
shell process.sh:定时调用outqueue.php脚本
#进行每分钟调用一次
* * * * * /usr/local/nginx/html/process.sh
#!/bin/bash
#file_name : process.sh
#author : zuoping
php /usr/local/nginx/html/outqueue.php

本文介绍了如何使用PHP结合Redis构建消息队列,以解决PHP+MySQL在高并发场景下性能问题。通过将数据先写入Redis队列,再由shell定时任务读取并写入MySQL,确保数据的准确性和可用性。涉及关键步骤包括入队(inqueue.php)、出队(outqueue.php)以及shell调度脚本process.sh的实现。
最低0.47元/天 解锁文章
1万+

被折叠的 条评论
为什么被折叠?



