php redis实现对200w用户的即时推送

发布时间 - 2026-01-10 23:25:34    点击率:

怎么实现对200w用户的即时推送,这个推送可以理解为调用第三方的接口,push,sms之类的东西。

当时先写了一个demo 直接读取DB然后单个推送,结果。。可想而知

于是设计一套基于redis+php多进程的方案,用着还不错而去扩展性蛮高的,故分享之。

=============================================

具体的逻辑如下:(无视我的字体)

其实这里还可以优化的,我的设想是如果用户数据再多一些的话,可以在redis里对数据进行分割采取多List,每一个List对应多个php进程这样会更快。

下面是我实现的具体代码:

主管理脚本:应用时启动这个即可。 

<?php     //push推送配置 注:使用前请确认log文件为空    2016-04-12 
include_once(dirname (__FILE__)."/../../config.inc.php"); 
//if(exec('ps aux | grep redis_push.php | grep -v grep | wc -l') != 0) goto check; 
import('push.class.php'); 
import('Redis.class.php'); 
 
$time =time(); 
$data = array("apikey"=>'xxxx',"secret"=>'xxxx'); 
$push = new Channel($data); 
$redis = new RedisCache($Credis['host'],$Credis['port']); 
if(exec('ps aux | grep redis_push.php | grep -v grep | wc -l') != 0) goto check;//如果有推送任务 直接执行监控代码 
 
/*PUSH配置项*/ 
$config = array( 
 "file"=>"test.txt", 
 "Title"=>"sssss", 
 "Content"=>"ssssssssssssssss", 
 "OpenType"=>"0",  //1是 0否  是否跳转链接 
 "Url"=>"",     //链接地址 
 "num"=>"500",   //每次推送条数 
 "s"=>"1"      //睡眠时间 (单位:秒) 
); 
$num = 15;      //启动进程数量 
$a = $config['OpenType']==1 ? "是" : "否"; 
$c = json_encode($config); 
$info = <<<monkey 
  ************ 请确认信息是否有误*10秒后启动push任务! ************* 
  * 文件名称  : {$config['file']}; 
  * 推送标题  : {$config['Title']}; 
  * 推送内容  : {$config['Content']}; 
  * 是否跳转  : {$config['OpenType']}; 
  * 进程数量  : $num;(如果为单进程无视此项) 
  * 睡眠时间  : {$config['s']}; 
  * 日志目录  : /log; 
  ***************************************************************\n 
monkey; 
echo $info; 
sleep(3); 
$n = 1; 
while($n<=10){ 
 echo (10-$n++),"秒\n"; 
 sleep(1); 
} 
echo "------------------------- 任务已启动 -------------------------\n"; 
if($redis->Scount('push_getchannel_success')){ 
 echo "队列有未完成任务\n"; 
}else{ 
 $res = exec("php redis_getchannel.php {$config['file']}");//写入redis脚本 
 echo $res; 
} 
smtp_mail('xxxx@qq.com','推送任务已开启','请实时监测,5秒后您的手机将接收到测试推送!');//推送监控 实现定时全自动推送  
echo "\n---------------- 5秒后 test 将收到测试推送消息 ----------------\n"; 
sleep(5); 
$re = $push->BaiduPush('xxxx','xxxxx',$config['Content'],$config['Title'],'1',$config['OpenType'],$config['Url'],'xxxxx',$push); 
sleep(1); 
echo "\n---------------- 测试推送已发出!如未收到,请及时终止程序! 10秒后正式推送!!! ----------------\n"; 
$m = 1; 
while($m<=10){ 
 echo (10-$m++),"秒\n"; 
 sleep(1); 
} 
echo "\n---------------- 推送任务已经开始!请耐心等待! ----------------\n"; 
//下面设置是否多进程 
for($i=1;$i<=$num;$i++){ 
exec("php redis_push.php '{$c}' > /dev/null 2>&1 &"); 
} 
 
check: 
while(1){ 
 if(exec('ps aux | grep redis_push.php | grep -v grep | wc -l') == 0){ 
  echo "push 发送完成 用时",time()-$time,"秒"; 
  die(); 
 } 
 echo "当前进程数:",exec('ps aux | grep redis_push.php | grep -v grep | wc -l'),"个","\n"; 
 echo "当前剩余推送数量:".$redis->Scount('push_getchannel_success')."\n"; 
 sleep(10); 
} 

至于写入redis和具体的推送脚本这个靠自己的想象里就好了 我就不发了 嘿嘿

我的做法是具体的推送脚本在推送一定数量后会自动终止并调用自己本身。

因为在实际应用中发现php脚本在长时间运行之后会发生假死(可能是因为上下文切换的问题),所以我都是避免让php脚本长时间运行。

还有就是用户肯定不是固定的200w用户 每天都会有一个增量,我的方案是通过定时脚本每天把增量的用户整理进我自己设计的一个用户表自己管理。

ps:我把所有的脚本弄到了一个我自己整理的小的php原生框架统一管理,过段时间我发出来。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# php对200w用户即时推送  # php  # redis即时推送  # php用户即时推送  # php实现微信公众号主动推送消息  # 微信小程序 消息推送php服务器验证实例详解  # 解析php做推送服务端实现ios消息推送  # php ios推送(代码)  # php实现微信模板消息推送  # PHP快速推送微信模板消息  # php实现websocket实时消息推送  # php实现socket推送技术的示例  # PHP实现小程序批量通知推送  # 长时间  # 跳转  # 自己的  # 都是  # 睡眠时间  # 您的  # 我就  # 是因为  # 还可以  # 多个  # 我把  # 而去  # 写了  # 已经开始  # 更快  # 还不错  # 请及时  # 第三方  # 后会  # 此项 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率  Python数据仓库与ETL构建实战_Airflow调度流程详解  Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】  想要更高端的建设网站,这些原则一定要坚持!  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  三星、SK海力士获美批准:可向中国出口芯片制造设备  如何在万网主机上快速搭建网站?  Laravel怎么使用Intervention Image库处理图片上传和缩放  Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】  音响网站制作视频教程,隆霸音响官方网站?  Swift开发中switch语句值绑定模式  原生JS实现图片轮播切换效果  Windows驱动无法加载错误解决方法_驱动签名验证失败处理步骤  香港网站服务器数量如何影响SEO优化效果?  Laravel如何安装Breeze扩展包_Laravel用户注册登录功能快速实现【流程】  Linux系统命令中screen命令详解  高防服务器如何保障网站安全无虞?  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  如何生成腾讯云建站专用兑换码?  如何实现建站之星域名转发设置?  javascript如何操作浏览器历史记录_怎样实现无刷新导航  高性能网站服务器配置指南:安全稳定与高效建站核心方案  Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程  如何快速搭建自助建站会员专属系统?  详解jQuery停止动画——stop()方法的使用  Laravel怎么上传文件_Laravel图片上传及存储配置  C++时间戳转换成日期时间的步骤和示例代码  网站建设保证美观性,需要考虑的几点问题!  消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工  Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康  Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】  宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法  黑客如何通过漏洞一步步攻陷网站服务器?  Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比  Laravel怎么清理缓存_Laravel optimize clear命令详解  HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  Laravel如何实现多对多模型关联?(Eloquent教程)  Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  Laravel安装步骤详细教程_Laravel环境搭建指南  如何在宝塔面板中修改默认建站目录?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程  中山网站推广排名,中山信息港登录入口?  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  什么是javascript作用域_全局和局部作用域有什么区别?