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

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

php使用gearman進行任務分發操作實例詳解

瀏覽:117日期:2022-09-11 13:38:12

本文實例講述了php使用gearman進行任務分發操作。分享給大家供大家參考,具體如下:

一、安裝gearman

下載gearman源碼包

https://launchpad.net/gearmand/+download

如: gearmand-1.1.12.tar.gz

下載php的gearman擴展包

http://pecl.php.net/package/gearman

如: gearman-1.1.2.tgz

安裝gearman

> yum install boost-devel gperf libevent-devel libuuid-devel> tar xf gearmand-1.1.12.tar.gz> cd gearmand-1.1.12> ./configure> make && make install

安裝gearman的php擴展(建議php版本不要過高,因為php7的gearman擴展目前還沒有出來)

> yum install autoconf> tar xf gearman-1.1.2.tgz> cd gearman-1.1.2> /data/php56/bin/phpize> ./configure --with-php-config=/data/php56/bin/php-config> make && make install

修改php.ini

> vi /data/php56/lib/php.ini

添加如下兩項

extension_dir=/data/php56/lib/php/extensions/no-debug-zts-20131226/extension=gearman.so

查看擴展

> /data/php56/bin/php -m

二、簡單的使用gearman

gearman中請求的處理過程一般涉及三種角色:client->job->worker其中client是請求的發起者job是請求的調度者,用于把客戶的請求分發到不同的worker上進行工作worker是請求的處理者

比如這里我們要處理client向job發送一個請求,來計算兩個數之和,job負責調度worker來具體實現計算兩數之和。

首先我們編寫client.php

<?php//創建一個客戶端$client = new GearmanClient();//添加一個job服務$client->addServer(’127.0.0.1’, 4730);//doNormal是同步的,等待worker處理完成返回結果//建議不要使用do()了$ret = $client->doNormal(’sum’, serialize(array(10, 10)));if($ret) { echo ’計算結果:’, $ret, 'n';}

再編寫worker.php

<?php//創建一個worker$worker = new GearmanWorker();//添加一個job服務$worker->addServer(’127.0.0.1’, 4730);//注冊一個回調函數,用于業務處理$worker->addFunction(’sum’, function($job) { //workload()獲取客戶端發送來的序列化數據 $data = unserialize($job->workload()); return $data[0] + $data[1];});//死循環while(true) { //等待job提交的任務 $ret = $worker->work(); if ($worker->returnCode() != GEARMAN_SUCCESS) { break; }}

我們先啟動gearmand服務

> mkdir -p /usr/local/var/log> gearmand -d

運行worker文件

> /data/php56/bin/php /data/worker.php

再運行client文件

> /data/php56/bin/php /data/client.php

結果如下:

php使用gearman進行任務分發操作實例詳解

三、gearman異步的處理任務

這里我們client向job發送一個發送郵件的請求,不等待請求完成,繼續向下執行。

client.php代碼如下:

<?php//創建一個客戶端$client = new GearmanClient();//添加一個job服務$client->addServer(’127.0.0.1’, 4730);//doBackground異步,返回提交任務的句柄$ret = $client->doBackground(’sendEmail’, json_encode(array( ’email’ => ’test@qq.com’, ’title’ => ’測試異步’, ’body’ => ’異步執行好牛B的樣子’,)));//繼續執行下面的代碼echo '我的內心毫無波動,甚至還想笑n';do { sleep(1); //獲取任務句柄的狀態 //jobStatus返回的是一個數組 //第一個,表示工作是否已經知道 //第二個,工作是否在運行 //第三和第四,分別對應完成百分比的分子與分母 $status = $client->jobStatus($ret); echo '完成情況:{$status[2]}/{$status[3]}n'; if(!$status[1]) { break; }} while(true);

worker.php代碼如下:

<?php//創建一個worker$worker = new GearmanWorker();//添加一個job服務$worker->addServer(’127.0.0.1’, 4730);//注冊一個回調函數,用于業務處理$worker->addFunction(’sendEmail’, function($job) { //workload()獲取客戶端發送來的序列化數據 $data = json_decode($job->workload(), true); //模擬發送郵件所用時間 sleep(6); echo '發送{$data[’email’]}郵件成功n';});//死循環//等待job提交的任務while($worker->work());

結果如下:

php使用gearman進行任務分發操作實例詳解

四、gearman并行的執行多個任務

我們如何并行的計算兩個數的累加和? 通過addTask添加多個任務到隊列,然后進行并行計算。

client.php代碼如下:

<?php//創建一個客戶端$client = new GearmanClient();//添加一個job服務$client->addServer(’127.0.0.1’, 4730);//設置任務完成時的回調函數$client->setCompleteCallback(function($task) { //獲取由worker返回的數據 echo $task->data(), 'n';});//計算1到500的累加和//添加五個任務到隊列$client->addTask(’sum’, json_encode(array(1, 100)));$client->addTask(’sum’, json_encode(array(100, 200)));$client->addTask(’sum’, json_encode(array(200, 300)));$client->addTask(’sum’, json_encode(array(300, 400)));$client->addTask(’sum’, json_encode(array(400, 500)));//運行隊列中的任務,do系列不需要runTask()$client->runTasks();

worker.php代碼如下:

<?php//創建一個worker$worker = new GearmanWorker();//添加一個job服務$worker->addServer(’127.0.0.1’, 4730);//注冊一個回調函數,用于業務處理$worker->addFunction(’sum’, function($job) { //workload()獲取客戶端發送來的序列化數據 $data = json_decode($job->workload(), true); sleep(1); $sum = 0; for($ix = $data[0]; $ix < $data[1]; ++$ix) { $sum += $ix; } return $sum;});//死循環//等待job提交的任務while($worker->work());

我們開啟5個worker工作進程,當運行客戶端請求時,5個計算任務幾乎是同時返回結果。

結果如下:

php使用gearman進行任務分發操作實例詳解

php使用gearman進行任務分發操作實例詳解

更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP進程與線程操作技巧總結》、《PHP網絡編程技巧總結》、《PHP基本語法入門教程》、《PHP數組(Array)操作技巧大全》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家PHP程序設計有所幫助。

標簽: PHP
相關文章:
主站蜘蛛池模板: 硅胶布|电磁炉垫片|特氟龙胶带-江苏浩天复合材料有限公司 | 通用磨耗试验机-QUV耐候试验机|久宏实业百科 | 西点培训学校_法式西点培训班_西点师培训_西点蛋糕培训-广州烘趣西点烘焙培训学院 | 挖掘机挖斗和铲斗生产厂家选择徐州崛起机械制造有限公司 | UV固化机_UVLED光固化机_UV干燥机生产厂家-上海冠顶公司专业生产UV固化机设备 | 27PR跨境电商导航 | 专注外贸跨境电商 | 冷油器-冷油器换管改造-连云港灵动列管式冷油器生产厂家 | 护栏打桩机-打桩机厂家-恒新重工| 企小优-企业数字化转型服务商_网络推广_网络推广公司 | 搜木网 - 木业全产业链交易平台,免费搜货、低价买货! | 艺术生文化课培训|艺术生文化课辅导冲刺-济南启迪学校 | 安徽成考网-安徽成人高考网| 振动筛-交叉筛-螺旋筛-滚轴筛-正弦筛-方形摇摆筛「新乡振动筛厂家」 | 光谱仪_积分球_分布光度计_灯具检测生产厂家_杭州松朗光电【官网】 | 苏州同创电子有限公司 - 四探针测试仪源头厂家 | 苏州伊诺尔拆除公司_专业酒店厂房拆除_商场学校拆除_办公楼房屋拆除_家工装拆除拆旧 | 对照品_中药对照品_标准品_对照药材_「格利普」高纯中药标准品厂家-成都格利普生物科技有限公司 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | 无菌实验室规划装修设计-一体化实验室承包-北京洁净净化工程建设施工-北京航天科恩实验室装备工程技术有限公司 | 磁力抛光机_磁力研磨机_磁力去毛刺机-冠古设备厂家|维修|租赁【官网】 | 希望影视-高清影视vip热播电影电视剧免费在线抢先看 | 建大仁科-温湿度变送器|温湿度传感器|温湿度记录仪_厂家_价格-山东仁科 | 越南专线物流_东莞国际物流_东南亚专线物流_行通物流 | 通风气楼_通风天窗_屋顶风机-山东美创通风设备有限公司 | NBA直播_NBA直播免费观看直播在线_NBA直播免费高清无插件在线观看-24直播网 | 【星耀裂变】_企微SCRM_任务宝_视频号分销裂变_企业微信裂变增长_私域流量_裂变营销 | 国资灵活用工平台_全国灵活用工平台前十名-灵活用工结算小帮手 | 酒糟烘干机-豆渣烘干机-薯渣烘干机-糟渣烘干设备厂家-焦作市真节能环保设备科技有限公司 | 智能门锁电机_智能门锁离合器_智能门锁电机厂家-温州劲力智能科技有限公司 | 泰州物流公司_泰州货运公司_泰州物流专线-东鑫物流公司 | 河南中整光饰机械有限公司-抛光机,去毛刺抛光机,精密镜面抛光机,全自动抛光机械设备 | 烟气在线监测系统_烟气在线监测仪_扬尘检测仪_空气质量监测站「山东风途物联网」 | 干洗加盟网-洗衣店品牌排行-干洗设备价格-干洗连锁加盟指南 | 聚合氯化铝价格_聚合氯化铝厂家_pac絮凝剂-唐达净水官网 | 上海办公室装修,办公楼装修设计,办公空间设计,企业展厅设计_写艺装饰公司 | 二手光谱仪维修-德国OBLF光谱仪|进口斯派克光谱仪-热电ARL光谱仪-意大利GNR光谱仪-永晖检测 | 国产液相色谱仪-超高效液相色谱仪厂家-上海伍丰科学仪器有限公司 | 灌木树苗-绿化苗木-常绿乔木-价格/批发/基地 - 四川成都途美园林 | 上海网站建设-上海网站制作-上海网站设计-上海做网站公司-咏熠软件 | 全自动真空上料机_粉末真空上料机_气动真空上料机-南京奥威环保科技设备有限公司 | 首页-瓜尔胶系列-化工单体系列-油田压裂助剂-瓜尔胶厂家-山东广浦生物科技有限公司 | 上海三信|ph计|酸度计|电导率仪-艾科仪器 |