Swoft2.x 小白学习笔记 (三) --- Task、协程
介绍swoft中
1、Task
2、协程
一:Task任务:
1、配置,在 app/bean.php文件中加入
'httpServer' => [
// ...
'on' => [
SwooleEvent::TASK => \bean(TaskListener::class), // Enable task must task and finish event
SwooleEvent::FINISH => \bean(FinishListener::class)
],
/* @see HttpServer::$setting */
'setting' => [
'task_worker_num' => 12,
'task_enable_coroutine' => true,
'worker_num' => 2
]
],
2、定时任务
1、安装 composer require swoft/crontab
2、配置
'httpServer' => [
// ...
'process' => [
'crontab' => bean(Swoft\Crontab\Process\CrontabProcess::class)
],
// ...
], 3、定义,在/app/Task/Crontab/ 文件夹中新建文件 <?php namespace App\Task\Crontab; use Swoft\Crontab\Annotaion\Mapping\Cron;
use Swoft\Crontab\Annotaion\Mapping\Scheduled; /**
* Class DemoCronTask
* @package App\Task\Crontab
*
* @Scheduled(name="demoCronTask") //声明定时任务
*/
class DemoCronTask{ /**
* @Cron("*") //每秒执行
*/
public function secondTask(){
var_dump("--111----",date('Y-m-d H:i:s', time()));
} /**
* @Cron("0 * * * * *") //每分钟执行
*/
public function miunteTask(){
var_dump("222------",date('Y-m-d H:i:s', time()));
}
}
3、协程、异步任务
(1)、声明一个任务,在 /app/Task/Task/ 文件夹新建文件
<?php declare(strict_types=1); namespace App\Task\Task; use Swoft\Task\Annotation\Mapping\Task;
use Swoft\Task\Annotation\Mapping\TaskMapping; /**
* Class DemoTask
*
* @since 2.0
* @Task(name="demoV2Task") //标记类是一个任务
*/
class DemoTask
{
/**
* @TaskMapping(name="list") //映射名称
*
* @param int $id
* @param string $default
*
* @return array
*/
public function getList(int $id): array
{
var_dump("------------"); sleep(5); return [
'list' => [1, 3, 3],
'id' => $id
];
} /**
* @param int $id
* @return bool
*
* @TaskMapping(name="putLists")
*/
public function putList(int $id) : bool
{
if($id > 5)
return true; return false;
}
}
(2)、任务投递
// 协程投递
$data = Task::co('demoV2Task', 'list', [12]); //异步投递
$data = Task::async('demoV2Task', 'list', [12]);
(3)、异步投递如果需要关注异步任务处理结果,可以添加监听器,在文件夹 /app/Task/Listener/ 下新建文件
<?php namespace App\Task\Listener; use Swoft\Log\Helper\CLog;
use function context;
use Swoft\Event\Annotation\Mapping\Listener;
use Swoft\Event\EventHandlerInterface;
use Swoft\Event\EventInterface;
use Swoft\Task\TaskEvent; /**
* Class DemoListener
* @package App\Task\Listener
* @Listener(event=TaskEvent::FINISH) //参数必须带Finsh
*/
class DemoListener implements EventHandlerInterface{ /**
* @param EventInterface $event
*
* @throws \Swoft\Exception\SwoftException
*/
public function handle(EventInterface $event): void
{
// TODO: Implement handle() method.
$fId = context()->getTaskUniqid(); // var_dump($fId);
CLog::info(\context()->getTaskUniqid()); $taskData = context()->getTaskData();
// var_dump($taskData); CLog::info(\context()->getTaskData());
}
}
二:协程 : https://www.swoft.org/docs/2.x/zh-CN/common/co.html
use Swoft\Co;
//创建一个协程
Co::create(function(){
// to do
sleep(3);
var_dump("--2222----"); }); //并发
$request = [
'method' => function () {
sleep(8); return "";
},
'staticMethod' => function () {
sleep(5); return "";
},
'closure' => function () {
sleep(2); return "";
}
]; $resd = Co::multi($request);//同时执行,同步,会阻塞
注意:Task中有两个地方还未清楚
1、协程投递任务时是阻塞( $data = Task::co('demoV2Task','list',[2],10); )。
2、使用 Co::multi() 执行并发时会阻塞。
3、异步监听的地方,所有监听器只有带了参数 @Listener(event=TaskEvent::FINISH) 都会执行一遍。
查看文档:
Task : https://www.swoft.org/docs/2.x/zh-CN/task/index.html
协程 : https://www.swoft.org/docs/2.x/zh-CN/common/co.html
Swoft2.x 小白学习笔记 (三) --- Task、协程的更多相关文章
- Swoft2.x 小白学习笔记 (一) ---控制器
Swoft通过官方文档进行学习,这里不做介绍,直接上手. 涉及到Swoft方面:(配置.注意的坑) 1.控制器(路由.验证器.中间件) 2.mysql (Model使用).Redis配置及通用池 3 ...
- lua学习笔记13:协程具体解释和举例
一.coroutine.create创建协程 參数是协程的主函数,返回一个thread对象 co = coroutine.create(function() print("coroutine ...
- Swoft2.x 小白学习笔记 (二) --- mysql、redis
介绍swoft中 1.mysql. 2.Redis 一.mysql使用: 1.配置,在 app\bean.php文件中 'db' => [ 'class' => Database::cla ...
- Swoft2.x 小白学习笔记 (四) --- RPC
介绍 swoft 中 RPC使用:搭建访问服务端和客户端 RPC服务端: 一.配置,在文件 /app/bean.php中添加 return [ 'rpcServer' => [ 'class' ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- [Firefly引擎][学习笔记三][已完结]所需模块封装
原地址:http://www.9miao.com/question-15-54671.html 学习笔记一传送门学习笔记二传送门 学习笔记三导读: 笔记三主要就是各个模块的封装了,这里贴 ...
- JSP学习笔记(三):简单的Tomcat Web服务器
注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...
- java之jvm学习笔记三(Class文件检验器)
java之jvm学习笔记三(Class文件检验器) 前面的学习我们知道了class文件被类装载器所装载,但是在装载class文件之前或之后,class文件实际上还需要被校验,这就是今天的学习主题,cl ...
- VSTO学习笔记(三) 开发Office 2010 64位COM加载项
原文:VSTO学习笔记(三) 开发Office 2010 64位COM加载项 一.加载项简介 Office提供了多种用于扩展Office应用程序功能的模式,常见的有: 1.Office 自动化程序(A ...
随机推荐
- 调用七牛云存储文件,返回url
文档地址:https://developer.qiniu.com/kodo/sdk/1283/javascript#2 npm引入 npm install qiniu-js 例子: var obser ...
- javascript面向对象 用new创建一个基于原型的javascript对象
//创建一个类 其实就是个对象 var Student={ name:"robot", height:1.6, run:function(){ console.log(this.n ...
- .NetCore 读取配置文件
1.创建config.json配置,并设置成始终复制 2.需要安装 nuget 包 Microsoft.Extensions.Configuration .Microsoft.Extensions.C ...
- [Shell]常用语法
赋值 FILE=$1 //=两边不能有空格 echo $FILE 逻辑判断 表达式 .if [ expression ]; then ... fi //[]两边必须有空格 . if [[ expres ...
- Java中jdk代理和cglib代理
代理模式 给某一个对象提供一个代理,并由代理对象控制对原对象的引用.在一些情况下,一个客户不想或者不能够直接引用一个对象,而代理对象可以在客户端和目标对象之间起到中介的作用. 在Java中代理模式从实 ...
- 2016多校7.14 Warmup 题解
先讲1007,是一个数位dp,询问一个区间内,各位数的和是一个素数的数字的个数.其实我并不会数位dp,这题直接套用了上次多校lyf队长的dp代码,改了点返回参数没想到直接AC了.代码如下: #incl ...
- CF860E Arkady and a Nobody-men
CF860E Arkady and a Nobody-men 类比LNOI2014 LCA那个题,其实树剖可以过....(用树状数组区间加区间求和更快!) 巧妙的nlogn做法是: blog~ (其实 ...
- 20.包含min函数的栈 Java
题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1)). 思路 借助辅助栈实现: 压栈时:若辅助栈为空,则将节点压入辅助栈.否则,当当前节点小于 ...
- dubbo服务层面上的负载均衡和高可用
dubbo上的服务层可以做集群,来达到负载均衡和高可用,很简单,只需要在不同的服务器节点上向同一个zk(内网环境)注册相同的服务 注意就是,消费者不能在同一个zk做这种集群操作的 转载请注明博客出处: ...
- MySQL-UDF和MOF提权
MOF提权 MOF文件是mysql数据库的扩展文件(在c:/windows/system32/wbem/mof/nullevt.mof) 叫做”托管对象格式”,其作用是每隔五秒就会去监控进程创建和死亡 ...