php redis實現對200w使用者的即時推送執行個體代碼詳解

來源:互聯網
上載者:User
這篇文章主要為大家詳細介紹了php redis實現對200w使用者的即時推送,具有一定的參考價值,感興趣的小夥伴們可以參考一下

怎麼實現對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 redis實現對200w使用者的即時推送執行個體代碼詳解的內容,更多相關內容請關注topic.alibabacloud.com(www.php.cn)!

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.