最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

swoole如何做消息通知

来源:动视网 责编:小采 时间:2020-11-03 18:23:28
文档

swoole如何做消息通知

swoole如何做消息通知:基于swoole、redis做一个消息通知功能利用swoole开启常驻进程,需要几个按自己的情况来定,swoole进程数最好是和服务器cpu核数相等 (推荐学习: swoole视频教程)利用swoole启动的常驻进程不断的去探测redis队列里面的值,可以按键值来做一个快中慢这样的权
推荐度:
导读swoole如何做消息通知:基于swoole、redis做一个消息通知功能利用swoole开启常驻进程,需要几个按自己的情况来定,swoole进程数最好是和服务器cpu核数相等 (推荐学习: swoole视频教程)利用swoole启动的常驻进程不断的去探测redis队列里面的值,可以按键值来做一个快中慢这样的权


基于swoole、redis做一个消息通知功能

利用swoole开启常驻进程,需要几个按自己的情况来定,swoole进程数最好是和服务器cpu核数相等 (推荐学习: swoole视频教程)

利用swoole启动的常驻进程不断的去探测redis队列里面的值,可以按键值来做一个快中慢这样的权重处理,需要急需处理,数据量大的可以用多几个进程,一般的可以分配不同的进程数来执行。

下面上代码:

swoole启动代码

function run()
{
 try {
 $swoole = new swoole_server(127.0.0.1, 9999);
 $swoole->set([
 'daemonize' => 1, //是否开启守护进程
 'worker_num' => 8, //实际需要去设定
 'log_file' => __APP_LOGS_PATH__ . '/swoole.log'
 ]);
 $swoole->on('WorkerStart', 'onWorkerStart');
 $swoole->on('Receive', 'onReceive');
 $swoole->start();
 } catch (Exception $e) {
 logs(['err_code' => $e->getCode(), 'err_msg' => $e->getMessage()], 'error');
 }
}

swoole实时监测redis队列里的数据,根据键值进行权重排比

代码

function onWorkerStart(swoole_server $swoole, $worker_id)
{
 $chQuick = [0, 1, 2, 3];
 $chNormal = [4, 5];
 $chSlow = [6];
 for ($i = 1; $i <= 3000; $i++) {
 $redis = connectRedis();//断线重连redis
 $queueData = $keys = [];
 if (in_array($worker_id, $chQuick)) {
 if ($redis->llen(QUEUE_QUICK))
 $keys[] = QUEUE_QUICK;
 if ($keys)
 $queueData = $redis->brpop(QUEUE_QUICK, 5);
 } elseif (in_array($worker_id, $chNormal)) {
 if ($redis->llen(QUEUE_NORMAL))
 $keys[] = QUEUE_NORMAL;
 if ($redis->llen(QUEUE_QUICK))
 $keys[] = QUEUE_QUICK;
 if ($keys)
 $queueData = $redis->brpop(QUEUE_NORMAL, QUEUE_QUICK, 5);
 } elseif (in_array($worker_id, $chSlow)) {
 if ($redis->llen(QUEUE_SLOW))
 $keys[] = QUEUE_SLOW;
 if ($redis->llen(QUEUE_NORMAL))
 $keys[] = QUEUE_NORMAL;
 if ($redis->llen(QUEUE_QUICK))
 $keys[] = QUEUE_QUICK;
 if ($keys)
 $queueData = $redis->brpop(QUEUE_SLOW, QUEUE_QUICK, QUEUE_NORMAL, 5);
 } else {
 if ($redis->llen(QUEUE_FAIL))
 $keys[] = QUEUE_FAIL;
 if ($redis->llen(QUEUE_SLOW))
 $keys[] = QUEUE_SLOW;
 if ($redis->llen(QUEUE_NORMAL))
 $keys[] = QUEUE_NORMAL;
 if ($redis->llen(QUEUE_QUICK))
 $keys[] = QUEUE_QUICK;
 if ($keys)
 $queueData = $redis->brpop(QUEUE_FAIL, QUEUE_QUICK, QUEUE_NORMAL, QUEUE_SLOW, 5);
 }
 logs('test'.$keys.'%%'.$queueData);
 if ($queueData) {
 $queueName = $queueData[0];
 $message = $queueData[1];
 if ($worker_id == QUEUE_FAIL_WORKER_ID && $queueName == QUEUE_FAIL) {
 call_user_func_array('retryPostMessage', [&$message, &$redis]);
 } else {
 call_user_func_array('postMessage', [&$message, &$redis]);
 }
 }
 else
 {
 sleep(5);
 }
 }
sleep(10);
 $redis->close();
 unset($redis);
 method_exists($swoole, 'stop') ? $swoole->stop() : @exit;
}

里面的for循环是为了配合sleep函数来使用,三次失败的可以记入失败,可以手动去处理。

文档

swoole如何做消息通知

swoole如何做消息通知:基于swoole、redis做一个消息通知功能利用swoole开启常驻进程,需要几个按自己的情况来定,swoole进程数最好是和服务器cpu核数相等 (推荐学习: swoole视频教程)利用swoole启动的常驻进程不断的去探测redis队列里面的值,可以按键值来做一个快中慢这样的权
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top