Swoole Task Worker进程相关知识讲解---Task

Task 简介

task进程是swoole当中独立于worker进程的工作进程。用于处理一些耗时较长的逻辑,这些逻辑如果在工作当中处理时并不会影响worker进程处理来自于客户端的请求。由此大大提高了swoole扩展的并发能力。

在worker进程当中,通过调用 task() 方法,发送数据通知到task进程,task进程会在 onTask() 回调当中接收到这些数据并进行处理,处理完成之后调用 finish() 函数或者直接return返回消息给 worker进程,worker进程的 onFinish() 函数收到这些数据并进行处理。

注意:
1.Task进程和worker进程间通过 Unix Sock 管道通信(也可配置通过消息队列通信)

Task 使用

。。。。

Task 常见问题

  • Task传递数据大小(Task传递数据本身是没有限制的)
    数据小于8k:直接通过管道传递;
    数据大于8k:写入临时文件传递。
  • Task 传递对象(Task参数传递对象的问题)
    可以通过序列化传递一个对象的拷贝(也就是说,并不是传递了一个引用,因为在Task当中,它和worker进程是两个完全不同的进程,他们的内存空间是不一样的,因此变量存储的地方也不一样,所以,Task对于一个对象的改变并不会反映到woker进程中);
    数据库连接,网络连接对象不可这样传递,会引起 PHP 程序报错。
  • Task 的 onFinish 回调
    Task 的 onFinish 回调会发回调用task方法的worker进程(回调给调用它方法的worker进程,并不会回调给其他worker进程)
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值