subscriber.php 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * Created by PhpStorm.
  5. * User: stanley-king
  6. * Date: 2017/2/24
  7. * Time: 下午5:04
  8. */
  9. namespace message;
  10. use Thread;
  11. use Log;
  12. use Redis;
  13. use Exception;
  14. use StatesHelper;
  15. class subscriber extends Thread
  16. {
  17. private $mConfig;
  18. private $mStates;
  19. public function __construct($states)
  20. {
  21. $this->mConfig = C('redis');
  22. $this->mStates = $states;
  23. }
  24. function run()
  25. {
  26. @date_default_timezone_set('Asia/Shanghai');
  27. while (true)
  28. {
  29. try
  30. {
  31. $redis = new Redis; //多线程版本不能定义为类成员变量,可能和redis库的设计有关。
  32. $ret = $redis->pconnect($this->mConfig['master']['host'], $this->mConfig['master']['port']);
  33. $redis->setOption(Redis::OPT_READ_TIMEOUT, 3600);
  34. if($ret == false) {
  35. Log::record("redis 连接失败.",Log::ERR);
  36. } else {
  37. Log::record("redis 连接成功.",Log::DEBUG);
  38. }
  39. Log::record("Message thread start run....",Log::DEBUG);
  40. $redis->subscribe(all_channels(), function ($redis,$chan,$msg)
  41. {
  42. $this->synchronized(function() use ($redis,$chan,$msg) {
  43. handler_redis($redis,$chan,$msg);
  44. });
  45. });
  46. Log::record("Message thread quit....",Log::DEBUG);
  47. }
  48. catch (Exception $ex)
  49. {
  50. Log::record("subscriber quit err={$ex->getMessage()} code={$ex->getCode()}");
  51. sleep(5);
  52. }
  53. }
  54. }
  55. public function dispatch($channel,$msg)
  56. {
  57. if(empty($msg)) return false;
  58. $msg = json_decode($msg,true);
  59. if($msg == false || !is_array($msg)) {
  60. return false;
  61. }
  62. $ret = true;
  63. if($channel == 'ch_index') {
  64. StatesHelper::onIndex($this->mStates,$msg);
  65. } elseif($channel == 'searcher') {
  66. StatesHelper::onSearcher($this->mStates,$msg);
  67. } elseif($channel == 'activity') {
  68. StatesHelper::onActivity($this->mStates,$msg);
  69. } elseif($channel == 'goods') {
  70. StatesHelper::onGoods($this->mStates,$msg);
  71. } elseif($channel == 'refill') {
  72. StatesHelper::onRefill($this->mStates,$msg);
  73. } else {
  74. $ret = false;
  75. }
  76. return $ret;
  77. }
  78. }