阅读模式:

php+redis实现消息队列

查看:19807  :2  类型:  来源:php自学网  标签 php消息队列 shell redis

        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

*如果每分钟调用一次频率不够,可以执行多次调用脚本,如:

#!/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('127.0.0.1',6379);
$redis -> select('1');
$redis->auth('');

$list = $redis->lrange('queue',0,-1);
var_dump($list);
分享到:
4 5
最新看法:
何 遇  时间 2018-09-26 17:17:53  中国浙江杭州电信
沙发
这个是你自己做的网站吗? 回复
站长 2018-09-27 14:39 中国广东深圳电信
嗯。自己做的个人博客 回复
回复:[主题]
表情:
 提交
清空

我的看法:

IN: