|
php+redis消息队列是php+mysql性能不足时的一个中间间处理方案。通过这个中间的处理,保证的数据的可用性和准确性。用于服务器瞬间请求大,数据库压力大的情况。如并发量大导致的超卖、并发量大导致的数据重复情况。
流程:php接受请求和数据 -> php把数据写入redis队列中(入队) -> shell定时调用php读取队列数据写入mysql(出队)
实现代码:
入队:inqueue.php
<?php
$redis = new redis();
$redis->connect(&#39;127.0.0.1&#39;,6379);
$redis -> select(&#39;1&#39;);
$redis->auth(&#39;&#39;);
$data = [a,b,c,d,e,f,g,h]; //这里可以是get或post请求过来的数据
$data = json_encode($data);
$in = $redis->rpush(&#39;queue&#39;,$data);
if($in){
echo &#34;入队成功&#34;;
}出队:outqueue.php
#!/usr/bin/php
<?php
$redis = new redis();
$redis->connect(&#39;127.0.0.1&#39;,6379);
$redis -> select(&#39;1&#39;);
$redis->auth(&#39;&#39;);
$value = $redis->lpop(&#39;queue&#39;);
$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*如果每分钟调用一次频率不够,可以执行多次调用脚本,如:
#!/bin/bash
#file_name : process.sh
#author : zuoping
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
#这样就一分钟调用了多次了。查看队列中的当前数据:
<?php
$redis = new redis();
$redis->connect(&#39;127.0.0.1&#39;,6379);
$redis -> select(&#39;1&#39;);
$redis->auth(&#39;&#39;);
$list = $redis->lrange(&#39;queue&#39;,0,-1);
var_dump($list);以上内容希望帮助到大家,更多PHP大厂PDF面试文档,PHP进阶架构视频资料,PHP精彩好文免费获取可以关注公众号:PHP开源社区,或者访问:
四年精华PHP技术文章整理合集——PHP框架篇
四年精华PHP技术文合集——微服务架构篇
四年精华PHP技术文合集——分布式架构篇
四年精华PHP技术文合集——高并发场景篇
四年精华PHP技术文章整理合集——数据库篇 |
|