当前位置:首页 > PHP教程 > php高级应用 > 列表

PHP扩展Swoole实现实时异步任务队列示例

发布:smiling 来源: PHP粉丝网  添加日期:2021-11-17 11:10:43 浏览: 评论:0 

这篇文章主要介绍了PHP扩展Swoole实现实时异步任务队列,结合实例形式分析了PHP扩展Swoole实现实时异步任务队列相关客户端与服务器端操作技巧,需要的朋友可以参考下。

本文实例讲述了PHP扩展Swoole实现实时异步任务队列。分享给大家供大家参考,具体如下:

假如要发100封邮件,for循环100遍,用户直接揭竿而起,什么破网站!

但实际上,我们很可能有超过1万的邮件。怎么处理这个延迟的问题?

答案就是用异步。把“发邮件”这个操作封装,然后后台异步地执行1万遍。这样的话,用户提交网页后,他所等待的时间只是“把发邮件任务请求推送进队列里”的时间。而我们的后台服务将在用户看不见的地方跑。

在实现“异步队列”这点上,有人采用MySQL表或者redis来存放待发送的邮件,然后,每分钟定时读取待发送列表,然后处理。这便是定时异步任务队列。但当前提交的任务要一分钟后才能执行,在某些实时性要求应用场景里还是不快。有些场景要求,只有一提交任务,便马上执行,但用户不需要等待返回结果。

本文将探讨用php扩展swoole实现实时异步任务队列的方案。

服务端

在打算放置脚本的目录(你也可以自行新建)新建Server.php,代码如下:

  1. <?php 
  2. class Server 
  3.   private $serv
  4.   public function __construct() 
  5.   { 
  6.     $this->serv = new swoole_server("0.0.0.0", 9501); 
  7.     $this->serv->set(array
  8.       'worker_num' => 1, //一般设置为服务器CPU数的1-4倍 
  9.       'daemonize' => 1, //以守护进程执行 
  10.       'max_request' => 10000, 
  11.       'dispatch_mode' => 2, 
  12.       'task_worker_num' => 8, //task进程的数量 
  13.       "task_ipc_mode " => 3, //使用消息队列通信,并设置为争抢模式 
  14.       //"log_file" => "log/taskqueueu.log" ,//日志 
  15.     )); 
  16.     $this->serv->on('Receive'array($this'onReceive')); 
  17.     // bind callback 
  18.     $this->serv->on('Task'array($this'onTask')); 
  19.     $this->serv->on('Finish'array($this'onFinish')); 
  20.     $this->serv->start(); 
  21.   } 
  22.   public function onReceive(swoole_server $serv$fd$from_id$data
  23.   { 
  24.     //echo "Get Message From Client {$fd}:{$data}\n"; 
  25.     // send a task to task worker. 
  26.     $serv->task($data); 
  27.   } 
  28.   public function onTask($serv$task_id$from_id$data
  29.   { 
  30.     $array = json_decode($data, true); 
  31.     if ($array['url']) { 
  32.       return $this->httpGet($array['url'], $array['param']); 
  33.     } 
  34.   } 
  35.   public function onFinish($serv$task_id$data
  36.   { 
  37.     //echo "Task {$task_id} finish\n"; 
  38.     //echo "Result: {$data}\n"; 
  39.   } 
  40.   protected function httpGet($url$data
  41.   { 
  42.     if ($data) { 
  43.       $url .= '?' . http_build_query($data); 
  44.     } 
  45.     $curlObj = curl_init(); //初始化curl, 
  46.     curl_setopt($curlObj, CURLOPT_URL, $url); //设置网址 
  47.     curl_setopt($curlObj, CURLOPT_RETURNTRANSFER, 1); //将curl_exec的结果返回 
  48.     curl_setopt($curlObj, CURLOPT_SSL_VERIFYPEER, FALSE); 
  49.     curl_setopt($curlObj, CURLOPT_SSL_VERIFYHOST, FALSE); 
  50.     curl_setopt($curlObj, CURLOPT_HEADER, 0); //是否输出返回头信息 
  51.     $response = curl_exec($curlObj); //执行 
  52.     curl_close($curlObj); //关闭会话 
  53.     return $response
  54.   } 
  55. $server = new Server(); 

客户端

启动服务后,让我们看看如何调用服务。新建测试文件Client_test.php

  1. <?php 
  2. class Client 
  3.   private $client
  4.   public function __construct() 
  5.   { 
  6.     $this->client = new swoole_client(SWOOLE_SOCK_TCP); 
  7.   } 
  8.   public function connect() 
  9.   { 
  10.     if (!$this->client->connect("127.0.0.1", 9501, 1)) { 
  11.       throw new Exception(sprintf('Swoole Error: %s'$this->client->errCode)); 
  12.     } 
  13.   } 
  14.   public function send($data
  15.   { 
  16.     if ($this->client->isConnected()) { 
  17.       if (!is_string($data)) { 
  18.         $data = json_encode($data); 
  19.       } 
  20.       return $this->client->send($data); 
  21.     } else { 
  22.       throw new Exception('Swoole Server does not connected.'); 
  23.     } 
  24.   } 
  25.   public function close() 
  26.   { 
  27.     $this->client->close(); 
  28.   } 
  29. $data = array
  30.   "url" => "http://192.168.10.19/send_mail"
  31.   "param" => array
  32.     "username" => 'test'
  33.     "password" => 'test' 
  34.   ) 
  35. ); 
  36. $client = new Client(); 
  37. $client->connect(); 
  38. if ($client->send($data)) { 
  39.   echo 'success'
  40. else { 
  41.   echo 'fail'
  42. $client->close(); 

在上面代码中,url即为任务所在地址,param为所需传递参数。

保存好代码,在命令行或者浏览器中执行Client_test.php,便实现了异步任务队列。你所填写的URL,将会在每次异步任务被提交后,以HTTP GET的方式异步执行。

Tags: Swoole PHP异步任务

分享到: