forked from yuntian001/multi-process-queue
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathJob.php
executable file
·84 lines (69 loc) · 1.93 KB
/
Job.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
<?php
namespace MPQueue;
use MPQueue\Config\ProcessConfig;
use MPQueue\Config\QueueConfig;
abstract class Job
{
/**
* 任务超时时间(单位秒,超时后会直接失败不会重试任务)
* 0代表永不超时 null代表使用队列超时设置(投递时配置的队列超时时间而不是运行进程加载的配置时间)
* @var int
*/
protected $timeout = null;
/**
* 最大失败次数 0代表出错不重试 null代表使用队列最大失败次数
* @var null
*/
protected $fail_number = null;
/**
* 任务失败后延迟几秒重新投递 0代表出错立即投递 null代表使用队列延迟秒数
* @var int
*/
protected $fail_expire = null;
/**
* 返回队列任务超时秒数/0(0代表不超时)
* @return int|null
*/
public function getTimeout()
{
return $this->timeout;
}
/**
* 返回允许最大失败次数
* @return int|null
*/
public function getFailNumber()
{
return $this->fail_number;
}
/**
* 返回失败后延迟重试时间
* @return int|null
*/
public function getFailExpire()
{
return $this->fail_expire;
}
/**
* 任务执行方法
* @return mixed
*/
abstract public function handle();
/**
* 任务超时后被调用(先于队列的handle调用 除非返回false 否则不再调用队列的fail_handle)
* @param array $jobInfo 任务详细信息数组
*/
public function timeout_handle(array $jobInfo){
return false;
}
/**
* 任务失败后被调用
* @param array $jobInfo 任务详细信息数组
* @param \Throwable $e 错误异常对象
* @return mixed (先于队列的handle调用 除非返回false 否则不再调用队列的fail_handle)
*/
public function fail_handle(array $jobInfo,\Throwable $e)
{
return false;
}
}