php+redis实现消息队列

编程

php+redis消息队列是php+mysql性能不足时的一个中间处理方案。通过这个中间的处理,保证的数据的可用性和准确性。用于服务器瞬间请求大,数据库压力大的情况。如并发量大导致的超卖、并发量大导致的数据重复情况。

流程:php接受请求和数据 -> php把数据写入redis队列中(入队) -> shell定时调用php读取队列数据写入mysql(出队)

实现代码:

入队:inqueue.php

<?php

$redis=newredis();

$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=newredis();

$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=newredis();

$redis->connect("127.0.0.1",6379);

$redis->select("1");

$redis->auth("");

$list=$redis->lrange("queue",0,-1);

var_dump($list);

以上内容希望帮助到大家, 很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家 ,需要戳这里   PHP进阶架构师>>>视频、面试文档免费获取

以上是 php+redis实现消息队列 的全部内容, 来源链接: utcz.com/z/517356.html

回到顶部