php和redis实现消息队列
2024-08-28 05:12:32
php+redis消息队列是php+mysql性能不足时的一个中间间处理方案。通过这个中间的处理,保证的数据的可用性和准确性。用于服务器瞬间请求大,数据库压力大的情况。如并发量大导致的超卖、并发量大导致的数据重复情况。
流程:php接受请求和数据 -> php把数据写入redis队列中(入队) -> shell定时调用php读取队列数据写入mysql(出队)
实现代码:
入队:inqueue.php
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
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脚本
php
- #进行每分钟调用一次
- * * * * * /usr/local/nginx/html/process.sh
php
- #!/bin/bash
- #file_name : process.sh
- #author : zuoping
- php /usr/local/nginx/html/outqueue.php
*如果每分钟调用一次频率不够,可以执行多次调用脚本,如:
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
- <?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);
最新文章
- JavaScript权威设计--JavaScript表达式与运算符(简要学习笔记五)
- Webpack从入门到上线
- ASP.NET Core (Database First)
- asp.net web api CORS
- c++错误代码1
- 关于查询扩展版ESI高被引论文的说明
- appium的xpath定位
- MOSS 2010:Visual Studio 2010开发体验(14)——列表开发之事件接收器
- objective-C学习笔记(十)协议
- C++如何将一个整数输出为小数
- slf4j 之logback日志之环境安装【一】
- [BJOI2019]光线[递推]
- springmvc 项目完整示例01 需求与数据库表设计 简单的springmvc应用实例 web项目
- Find Longest common string
- Java笔记(十一)通用容器类和总结
- 关于XCode工程中PrefixHead.pch文件的使用
- docker 小结
- k64 datasheet学习笔记3---Chip Configuration之System modules
- (3)学习笔记 ) ASP.NET CORE微服务 Micro-Service ---- Consul服务治理
- 【CF61D】Eternal Victory
热门文章
- 【HANA系列】【第六篇】SAP HANA XS使用JavaScript(JS)调用存储过程(Procedures)
- 导模块的细节:(跨文件导入模块 &;模块的两种执行方式) | 包的概念与使用 | 包中的相对导入语法
- Ubuntu18.04两步纯小白傻瓜无脑式安装Caffe
- mysql——创建表、修改表、删除表(概念详细讲解)
- flutter环境配置(windows)
- PTA(Basic Level)1046.划拳
- Oracle 获取当前日期是月的第几周
- 关于maven自动部署tomcat9 步骤
- MyBatis清空数据库表数据
- Python简单主机批量管理工具