电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

php使用Swoole實現毫秒級定時任務的方法

瀏覽:137日期:2022-09-09 09:22:28

項目開發中,如果有定時任務的業務要求,我們會使用linux的crontab來解決,但是它的最小粒度是分鐘級別,如果要求粒度是秒級別的,甚至毫秒級別的,crontab就無法滿足,值得慶幸的是swoole提供的強大的毫秒定時器。

應用場景舉例

我們可能會遇到這樣的場景:

場景一:每隔30秒獲取一次本機內存使用率

場景二:2分鐘后執行報表發送任務

場景三:每天凌晨2點鐘定時請求第三方接口,如果接口有數據返回則停止任務,如果接口由于某種原因沒有響應或者沒有數據返回則5分鐘后繼續嘗試請求該接口,嘗試5次后仍然失敗則停止該任務

以上的三個場景我們都可以歸納為定時任務的范疇。

Swoole毫秒定時器

Swoole提供了異步毫秒定時器函數:

swoole_timer_tick(int $msec, callable $callback):設置一個間隔時鐘定時器,每隔$msec毫秒執行一次$callback,類似于javascript中的setInterval()。

swoole_timer_after(int $after_time_ms, mixed $callback_function):在指定的時間$after_time_ms后執行$callback_function,類似于javascript的setTimeout()。

swoole_timer_clear(int $timer_id):刪除指定id的定時器,類似于javascript的clearInterval()。

解決方案

對于場景一,經常用在系統檢測統計方面,實時性要求比較高,但又能控制好頻率,多用于后臺服務器性能監控,可以生成可視化圖表。可以是30秒獲取一次內存使用率,也可以是10秒,而crontab最小粒度只能設置為1分鐘。

swoole_timer_tick(30000, function($timer) use ($task_id) { // 啟用定時器,每30秒執行一次 $memPercent = $this->getMemoryUsage(); //計算內存使用率 echo date(’Y-m-d H:i:s’) . ’當前內存使用率:’.$memPercent.'n'; });

對于場景二,直接定義xx時間后執行某項任務的話,貌似crontab比較困難,而使用swoole的swoole_timer_after可以實現:

swoole_timer_after(120000, function() use ($str) { //2分鐘后執行 $this->sendReport(); //發送報表 echo 'send report, $strn'; });

對于場景三,用來作嘗試請求,請求失敗后繼續,如果成功則停止請求。用crontab也能解決,但是比較傻,比如設置每隔5分鐘請求一次,不管成功會失敗都會去執行一次。而用swoole定時器則智能多了。

swoole_timer_tick(5*60*1000, function($timer) use ($url) { // 啟用定時器,每5分鐘執行一次 $rs = $this->postUrl($url); if ($rs) { //業務代碼... swoole_timer_clear($timer); // 停止定時器 echo date(’Y-m-d H:i:s’). '請求接口任務執行成功n'; } else { echo date(’Y-m-d H:i:s’). '請求接口失敗,5分鐘后再次嘗試n'; } });

示例代碼

新建文件srcAppTask.php:

namespace HellowebaSwoole; use swoole_server; /** * 任務調度 */ class Task { protected $serv; protected $host = ’127.0.0.1’; protected $port = 9506; // 進程名稱 protected $taskName = ’swooleTask’; // PID路徑 protected $pidPath = ’/run/swooletask.pid’; // 設置運行時參數 protected $options = [ ’worker_num’ => 4, //worker進程數,一般設置為CPU數的1-4倍 ’daemonize’ => true, //啟用守護進程 ’log_file’ => ’/data/log/swoole-task.log’, //指定swoole錯誤日志文件 ’log_level’ => 0, //日志級別 范圍是0-5,0-DEBUG,1-TRACE,2-INFO,3-NOTICE,4-WARNING,5-ERROR ’dispatch_mode’ => 1, //數據包分發策略,1-輪詢模式 ’task_worker_num’ => 4, //task進程的數量 ’task_ipc_mode’ => 3, //使用消息隊列通信,并設置為爭搶模式 ]; public function __construct($options = []) { date_default_timezone_set(’PRC’); // 構建Server對象,監聽127.0.0.1:9506端口 $this->serv = new swoole_server($this->host, $this->port); if (!empty($options)) { $this->options = array_merge($this->options, $options); } $this->serv->set($this->options); // 注冊事件 $this->serv->on(’Start’, [$this, ’onStart’]); $this->serv->on(’Connect’, [$this, ’onConnect’]); $this->serv->on(’Receive’, [$this, ’onReceive’]); $this->serv->on(’Task’, [$this, ’onTask’]); $this->serv->on(’Finish’, [$this, ’onFinish’]); $this->serv->on(’Close’, [$this, ’onClose’]); } public function start() { // Run worker $this->serv->start(); } public function onStart($serv) { // 設置進程名 cli_set_process_title($this->taskName); //記錄進程id,腳本實現自動重啟 $pid = '{$serv->master_pid}n{$serv->manager_pid}'; file_put_contents($this->pidPath, $pid); } //監聽連接進入事件 public function onConnect($serv, $fd, $from_id) { $serv->send( $fd, 'Hello {$fd}!' ); } // 監聽數據接收事件 public function onReceive(swoole_server $serv, $fd, $from_id, $data) { echo 'Get Message From Client {$fd}:{$data}n'; //$this->writeLog(’接收客戶端參數:’.$fd .’-’.$data); $res[’result’] = ’success’; $serv->send($fd, json_encode($res)); // 同步返回消息給客戶端 $serv->task($data); // 執行異步任務 } /** * @param $serv swoole_server swoole_server對象 * @param $task_id int 任務id * @param $fromid int 投遞任務的worker_id * @param $data string 投遞的數據 */ public function onTask(swoole_server $serv, $task_id, $from_id, $data) { swoole_timer_tick(30000, function($timer) use ($task_id) { // 啟用定時器,每30秒執行一次 $memPercent = $this->getMemoryUsage(); echo date(’Y-m-d H:i:s’) . ’當前內存使用率:’.$memPercent.'n'; }); } /** * @param $serv swoole_server swoole_server對象 * @param $task_id int 任務id * @param $data string 任務返回的數據 */ public function onFinish(swoole_server $serv, $task_id, $data) { // } // 監聽連接關閉事件 public function onClose($serv, $fd, $from_id) { echo 'Client {$fd} close connectionn'; } public function stop() { $this->serv->stop(); } private function getMemoryUsage() { // MEMORY if (false === ($str = @file('/proc/meminfo'))) return false; $str = implode('', $str); preg_match_all('/MemTotals{0,}:+s{0,}([d.]+).+?MemFrees{0,}:+s{0,}([d.]+).+?Cacheds{0,}:+s{0,}([d.]+).+?SwapTotals{0,}:+s{0,}([d.]+).+?SwapFrees{0,}:+s{0,}([d.]+)/s', $str, $buf); //preg_match_all('/Bufferss{0,}:+s{0,}([d.]+)/s', $str, $buffers); $memTotal = round($buf[1][0]/1024, 2); $memFree = round($buf[2][0]/1024, 2); $memUsed = $memTotal - $memFree; $memPercent = (floatval($memTotal)!=0) ? round($memUsed/$memTotal*100,2):0; return $memPercent; } }

我們以場景一為例,在onTask啟用定時任務,每隔30秒計算一次內存使用率。實際應用中可以把計算好的內存按時間寫入數據庫等存儲中,然后可以根據前端需求用來渲染成統計圖表,如:

php使用Swoole實現毫秒級定時任務的方法

接著服務端代碼 publictaskServer.php :

<?phprequire dirname(__DIR__) . ’/vendor/autoload.php’; use HellowebaSwooleTask; $opt = [ ’daemonize’ => false ]; $ser = new Task($opt); $ser->start();

客戶端代碼 publictaskClient.php :

<?phpclass Client { private $client; public function __construct() { $this->client = new swoole_client(SWOOLE_SOCK_TCP); } public function connect() { if( !$this->client->connect('127.0.0.1', 9506 , 1) ) { echo 'Error: {$this->client->errMsg}[{$this->client->errCode}]n'; } fwrite(STDOUT, '請輸入消息 Please input msg:'); $msg = trim(fgets(STDIN)); $this->client->send( $msg ); $message = $this->client->recv(); echo 'Get Message From Server:{$message}n'; } } $client = new Client(); $client->connect();

驗證效果

1.啟動服務端:

php taskServer.php

2.客戶端輸入:

另開命令行窗口,執行

[root@localhost public]# php taskClient.php

請輸入消息 Please input msg:hello

Get Message From Server:{'result':'success'} [root@localhost public]#

3.服務端返回:

php使用Swoole實現毫秒級定時任務的方法

如果返回上圖中的結果,則定時任務正常運行,我們會發現每隔30秒會輸出一條信息。

總結

到此這篇關于php使用Swoole實現毫秒級定時任務的方法的文章就介紹到這了,更多相關php Swoole實現毫秒級定時任務內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: PHP
相關文章:
主站蜘蛛池模板: 国际船舶网 - 船厂、船舶、造船、船舶设备、航运及海洋工程等相关行业综合信息平台 | 上海璟文空运首页_一级航空货运代理公司_机场快递当日达 | 不锈钢列管式冷凝器,换热器厂家-无锡飞尔诺环境工程有限公司 | 雾度仪_雾度计_透光率雾度仪价格-三恩时(3nh)光电雾度仪厂家 | 儿童语言障碍训练-武汉优佳加感统文化发展有限公司 | PE一体化污水处理设备_地埋式生活污水净化槽定制厂家-岩康塑业 | 物联网卡_物联网卡购买平台_移动物联网卡办理_移动联通电信流量卡通信模组采购平台? | 杭州中策电线|中策电缆|中策电线|杭州中策电缆|杭州中策电缆永通集团有限公司 | 学校用栓剂模,玻璃瓶轧盖钳,小型安瓿熔封机,实验室安瓿熔封机-长沙中亚制药设备有限公司 | 全屋整木定制-橱柜,家具定制-四川峨眉山龙马木业有限公司 | app开发|app开发公司|小程序开发|物联网开发||北京网站制作|--前潮网络 | 压力喷雾干燥机,喷雾干燥设备,柱塞隔膜泵-无锡市闻华干燥设备有限公司 | 医养体检包_公卫随访箱_慢病随访包_家签随访包_随访一体机-济南易享医疗科技有限公司 | 隧道风机_DWEX边墙风机_SDS射流风机-绍兴市上虞科瑞风机有限公司 | 钢格板|热镀锌钢格板|钢格栅板|钢格栅|格栅板-安平县昊泽丝网制品有限公司 | 步进电机_agv电机_伺服马达-伺服轮毂电机-和利时电机 | 油液红外光谱仪-油液监测系统-燃油嗅探仪-上海冉超光电科技有限公司 | 充气膜专家-气膜馆-PTFE膜结构-ETFE膜结构-商业街膜结构-奥克金鼎 | 仿古瓦,仿古金属瓦,铝瓦,铜瓦,铝合金瓦-西安东申景观艺术工程有限公司 | 防火阀、排烟防火阀、电动防火阀产品生产销售商-德州凯亿空调设备有限公司 | 工业设计,人工智能,体验式3D展示的智能技术交流服务平台-纳金网 J.S.Bach 圣巴赫_高端背景音乐系统_官网 | 济南ISO9000认证咨询代理公司,ISO9001认证,CMA实验室认证,ISO/TS16949认证,服务体系认证,资产管理体系认证,SC食品生产许可证- 济南创远企业管理咨询有限公司 郑州电线电缆厂家-防火|低压|低烟无卤电缆-河南明星电缆 | 尼龙PA610树脂,尼龙PA612树脂,尼龙PA1010树脂,透明尼龙-谷骐科技【官网】 | 温室大棚建设|水肥一体化|物联网系统 | 锂电叉车,电动叉车_厂家-山东博峻智能科技有限公司 | 污水处理设备-海普欧环保集团有限公司| 耳模扫描仪-定制耳机设计软件-DLP打印机-asiga打印机-fitshape「飞特西普」 | 硅胶布|电磁炉垫片|特氟龙胶带-江苏浩天复合材料有限公司 | 岛津二手液相色谱仪,岛津10A液相,安捷伦二手液相,安捷伦1100液相-杭州森尼欧科学仪器有限公司 | 齿轮减速电机一体机_蜗轮蜗杆减速马达-德国BOSERL齿轮减速机带电机生产厂家 | 一技任务网_有一技之长,就来技术任务网 | RV减速机-蜗轮蜗杆减速机-洗车机减速机-减速机厂家-艾思捷 | 理化生实验室设备,吊装实验室设备,顶装实验室设备,实验室成套设备厂家,校园功能室设备,智慧书法教室方案 - 东莞市惠森教学设备有限公司 | 【铜排折弯机,钢丝折弯成型机,汽车发泡钢丝折弯机,线材折弯机厂家,线材成型机,铁线折弯机】贝朗折弯机厂家_东莞市贝朗自动化设备有限公司 | 招商帮-一站式网络营销服务|搜索营销推广|信息流推广|短视视频营销推广|互联网整合营销|网络推广代运营|招商帮企业招商好帮手 | 地磅-电子地磅维修-电子吊秤-汽车衡-无人值守系统-公路治超-鹰牌衡器 | 南京交通事故律师-专打交通事故的南京律师 | 一体化污水处理设备_生活污水处理设备_全自动加药装置厂家-明基环保 | 热风机_工业热风机生产厂家上海冠顶公司提供专业热风机图片价格实惠 | 语料库-提供经典范文,文案句子,常用文书,您的写作得力助手 | 钢格板|镀锌钢格板|热镀锌钢格板|格栅板|钢格板|钢格栅板|热浸锌钢格板|平台钢格板|镀锌钢格栅板|热镀锌钢格栅板|平台钢格栅板|不锈钢钢格栅板 - 专业钢格板厂家 |