php利用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 "入队成功"; } 1 2 3 4 5 6 7 8 9 10 11 12 出队: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); 1 2 3 4 5 6 7 8 9 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 1 2 3 4 5 6 如果每分钟调用一次频率不够,可以执行多次调用脚本,如: #!/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 #这样就一分钟调用了多次了。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 查看队列中的当前数据: <?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);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值