swoole(6)Task异步任务
一:什么是task进程?
task进程是独立与worker进程的一组进程 ,他主要处理耗时较长的业务逻辑,并且不影响worker进程处理客户端的请求.worker进程通过task()函数把数据投递到Task进程去处理

开启task功能(task功能是默认关闭的 ,开启task功能需要满足2个条件)
- 配置task进程的数量(task_worker_num)
- 注册task的回掉函数onTask和onfinish
二:task设计流程

- worker进程中,我们调用对应的task()方法发送数据通知到task worker进程
- task worker进程会在onTask()回调中接收到这些数据,并进行处理
- 处理完会可以通过finish函数或直接return消息给worker进程
- worker进程在onFinish()进程收到消息并进行处理
代码:
<?php
/**
* Created by PhpStorm.
* User: huahua
* Date: 2020/3/6
* Time: 上午10:09
*/ //基于第一个 TCP 服务器,只需要增加 onTask 和 onFinish2 个事件回调函数即可。
//另外需要设置 task 进程数量,可以根据任务的耗时和任务量配置适量的 task 进程。 $serv = new \Swoole\Server('127.0.0.1',9800); $serv->set([
'worker_num'=>2, //设置进程
//配置此参数后将会启用 task 功能。所以 Server 务必要注册 onTask、onFinish 2 个事件回调函数。如果没有注册,服务器程序将无法启动。
'task_worker_num' => 4, //配置 Task 进程的数量。
'task_ipc_mode'=>2,//设置 Task 进程与 Worker 进程之间通信的方式
]);
//监听连接进入事件
$serv->on('Connect', function ($serv, $fd) {
echo "Client: Connect.\n";
}); //监听数据接收事件
$serv->on('Receive', function ($serv, $fd, $from_id, $data) {
$data=['tid'=>time()];
$task_id = $serv->task($data);////投递到taskWorker进程组
echo "task id = {$task_id},from id = $from_id".PHP_EOL;
}); $serv->on('task',function ($serv, $task_id, $from_id, $data){
echo "task id = {$task_id},from id = $from_id,进程id =".posix_getpid().PHP_EOL;
echo '我是task任务';
$serv->finish("data -> ok");
}); $serv->on('finish',function ($serv, $task_id, $data){
echo "task id = {$task_id}".PHP_EOL;
});
//监听连接关闭事件
$serv->on('Close', function ($serv, $fd) {
echo "Client: Close.\n";
}); //启动服务器
$serv->start();
cli下运行结果:

$task_id不等于workerStart中的worker_id,而是swoole维护的任务自增长id
$from_id表示来自于哪个woker投递而来的任务,id等于worker_id值
$serv->worker_id等于workerStart中的worker_id, 此处是task_woker的id
$serv->worker_pid 此处是task_woker的进程pid
三:task任务切分
场景:假设有一台服务器专门处理前台投递的数据,利用简单的任务拆分,分配到相应的进程去处理
思路:
- 1.将一个大的任务拆分成相应份数(是由$task_worker_num数量来确定)
- 2.通过foreach循环将数据投递到指定的task进程,范围是(0-(task_worker_num-1))区间之内
- 3.执行失败的任务,需要保留,重新投递执行(进程间通讯管道方式)
$server->on('receive',function (swoole_server $server, int $fd, int $reactor_id, string $data){
for ($i=0;$i<100;$i++){
$tasks[] =['id'=>$i,'msg'=>time()];
}
$count=count($tasks);
$data=array_chunk($tasks,ceil($count/3));
foreach ($data as $k=>$v){
$server->task($v,$k); //(0-task_woker_num-1)
}
});
swoole(6)Task异步任务的更多相关文章
- Task异步编程
Task异步编程中,可以实现在等待耗时任务的同时,执行不依赖于该耗时任务结果的其他同步任务,提高效率. 1.Task异步编程方法签名及返回值: a) 签名有async 修饰符 b) 方法名以 Asyn ...
- 『审慎』.Net4.6 Task 异步函数 比 同步函数 慢5倍 踩坑经历
异步Task简单介绍 本标题有点 哗众取宠,各位都别介意(不排除个人技术能力问题) —— 接下来:我将会用一个小Demo 把 本文思想阐述清楚. .Net 4.0 就有了 Task 函数 —— 异步编 ...
- Net4.6 Task 异步函数 比 同步函数 慢5倍 踩坑经历
Net4.6 Task 异步函数 比 同步函数 慢5倍 踩坑经历 https://www.cnblogs.com/shuxiaolong/p/DotNet_Task_BUG.html 异步Task简单 ...
- C# 将 Begin 和 End 异步方法转 task 异步
在 .NET Framework 有两个不同的异步方法,一个是 Asynchronous Programming Model (APM) 另一个是 Task-based asynchronous pa ...
- c#中的Task异步编程
https://docs.microsoft.com/en-us/dotnet/csharp/programming-guide/concepts/async/index翻译 1. 引入 Task异步 ...
- Task 异步小技巧
原文地址:Task 异步小技巧 - 一事冇诚 - 博客园 (cnblogs.com) async Task 语法糖出来后,异步编程变得非常简单,适合需要耗费较长时间的任务. 有些小伙伴使用后可能会非常 ...
- [Sw] 使用 Swoole Server task/协程 处理大数据量异步任务时注意
关于 Buffered Query 和 Unbuffered Query:http://www.php.net/manual/zh/mysqlinfo.concepts.buffering.php 对 ...
- Swoole 中使用异步任务
执行异步任务 (Task) # server.php $serv = new Swoole\Server("127.0.0.1", 9501); // 设置异步任务的工作进程数量 ...
- 新手浅谈C#Task异步编程
Task是微软在.net framework 4.0发布的新的异步编程的利器,当然4.5新增了async.await,这儿我们先说Task相关. 在实际编程中,我们用的较多的是Task.Task.Fa ...
随机推荐
- 手机APP例如抖音,让 people‘s 注意力集中到了 社会进化的 优胜部分 (优胜劣汰,什么是优) + 真善美,的 “美” , 促进了2极分化, 会产生强者俞强,弱者越弱,确实促进了信息的流通,传播了有用的东东 产生了独特的价值 而 如何 能计算出这些价值呢, 需要 数学 金融 财务 货币 量化吗
手机APP例如抖音,让 people‘s 注意力集中到了 社会进化的 优胜部分 (优胜劣汰,什么是优) + 真善美,的 “美” , 促进了2极分化, 会产生 ...
- NOIP2002 过河卒(DFS,DP)
https://www.luogu.org/problem/P1002 题目描述 如图,A 点有一个过河卒,需要走到目标 B 点.卒行走规则:可以向下.或者向右.同时在棋盘上的任一点有一个对方的马(如 ...
- servletHomeWork
2. http全称是什么? 超文本传输协议(HTTP, HyperText Transfer Protocol)是互联网上应用为最广泛的一种网络协议. 3.http协议是无状态的协议是什么意思?请说明 ...
- 论文翻译——Character-level Convolutional Networks for Text Classification
论文地址 Abstract Open-text semantic parsers are designed to interpret any statement in natural language ...
- 吴裕雄--天生自然python机器学习:使用决策树预测隐形眼镜类型
解决策树如何预测患者需要佩戴的隐形眼镜类型.使用小数据 集,我们就可以利用决策树学到很多知识:眼科医生是如何判断患者需要佩戴的镜片类型:一旦 理解了决策树的工作原理,我们甚至也可以帮助人们判断需要佩戴 ...
- sequelize 应用hook 实现对分表的访问
https://github.com/cclient/sequelize-shardinghttps://www.npmjs.com/package/sequelize-sharding 实际有效的代 ...
- python中使用自定义类实例作为字典的key
python中dict类型的key值要求是不可变类型,通常来说,我们一般采用int或者str类型来作为字典的key,但是在某些场景中,会造成一定的麻烦. 如我们有一个处理http Request的规则 ...
- CPU内核、用户模式
本文由是阅读该文章做下的笔记. CPU分内核与用户模式. 三言蔽之 内核模式下,应用可以直接存取内存,能够执行任何CPU指令.一般来说驱动运行在该模式下.内核模式的应用一旦崩溃,整个操作系统都会崩溃. ...
- The file named error_log is too large
The file named errorlog is too large */--> The file named errorlog is too large 1 Problem One day ...
- springboot学习笔记:6.内置tomcat启动和外部tomcat部署总结
springboot的web项目的启动主要分为: 一.使用内置tomcat启动 启动方式: 1.IDEA中main函数启动 2.mvn springboot-run 命令 3.java -jar XX ...