sync_my.php
1.6 KB
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
85
86
87
88
89
<?php
class SyncEmailMy{
static $maxGo = 0;
public static function sync(){
while (1){
// if(self::$maxGo >= 50){
// co::sleep(1);
// continue;
// }
$id = redis()->lPop('sync_email_lists_my');
// _echo('读取到'.$id);
if($id && is_numeric($id)){
// 占用当前的id,占用2小时
if(redis()->add('just_sync_'.$id,time(),600)){
self::go($id);
}
// co::sleep(0.2);
}else{
sleep(1);
}
}
}
public static function go($id){
// go(function ($id){
// self::$maxGo++;
try{
// 开始同步
(new \Service\SyncMail($id))->isUidAfter(2)->sync();
}catch (Throwable $e){
_echo($e->getMessage());
}
// co::defer(function () use ($id){
// self::$maxGo--;
// 30秒后 消除占用
redis()->expire('just_sync_'.$id,30);
\Lib\Log::getInstance()->write();
// db()->close();
// });
// },$id);
}
}
// 进程管理器
$pm = new \Swoole\Process\Manager();
// 启动业务进程
$pm->addBatch(100,function (\Swoole\Process\Pool $pool, int $worker_id){
//error_reporting();
include_once __DIR__."/../vendor/autoload.php";
_echo('子进程重新启动了==>'.$worker_id);
\Lib\DbPool::$clientNumber = 60;
SyncEmailMy::sync();
},false);
$pm->start();