
一.前言
php+redis消息队列是php+mysql性能不足时的一个中间间处理方案。通过这个中间的处理,保证的数据的可用性和准确性。用于服务器瞬间请求大,数据库压力大的情况。如并发量大导致的超卖、并发量大导致的数据重复情况。
流程:php接受请求和数据 -> php把数据写入redis队列中(入队) -> shell定时调用php读取队列数据写入mysql(出队)
二.实现代码
1.入队: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 "入队成功";}
2.出队: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);
3.shell process.sh:定时调用outqueue.php脚本
#进行每分钟调用一次* * * * * usr/local/nginx/html/process.sh#!/bin/bash#file_name : process.sh#author : zuopingphp usr/local/nginx/html/outqueue.php
4.如果每分钟调用一次频率不够,可以执行多次调用脚本,如:
#!/bin/bash#file_name : process.sh#author : zuopingphp usr/local/nginx/html/outqueue.phpphp /usr/local/nginx/html/outqueue.phpphp /usr/local/nginx/html/outqueue.phpphp /usr/local/nginx/html/outqueue.phpphp /usr/local/nginx/html/outqueue.phpphp /usr/local/nginx/html/outqueue.phpphp /usr/local/nginx/html/outqueue.phpphp /usr/local/nginx/html/outqueue.phpphp /usr/local/nginx/html/outqueue.phpphp /usr/local/nginx/html/outqueue.phpphp /usr/local/nginx/html/outqueue.php#这样就一分钟调用了多次了。
5.查看队列中的当前数据:
<?php$redis = new redis();$redis->connect('127.0.0.1',6379);$redis -> select('1');$redis->auth('');$list = $redis->lrange('queue',0,-1);var_dump($list);

*声明:本文于网络整理,版权归原作者所有,如来源信息有误或侵犯权益,请联系我们删除或授权事宜




