我是靠谱客的博主 机灵魔镜,最近开发中收集的这篇文章主要介绍redis.php,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 "入队成功";

}

出队:outqueue.php#!/usr/bin/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);

最后

以上就是机灵魔镜为你收集整理的redis.php,php+redis实现消息队列的全部内容,希望文章能够帮你解决redis.php,php+redis实现消息队列所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(52)

评论列表共有 0 条评论

立即
投稿
返回
顶部