hot_mail_3.php
2.3 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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
<?php
use Model\listsSql;
/**
* 把预热的邮件进行归档处理 减少数量量
* @author:dc
* @time 2025/1/17 17:10
* Class HotMail
*/
class HotMailArchive {
public function __construct(){
$this->db = db();
$this->start();
}
/**
* shopk那边的预热邮箱
* @var array
*/
private $hotEmail = [];
/**
* @var \Lib\Db|\Lib\DbPool
*/
private $db;
/**
* @author:dc
* @time 2024/7/18 14:04
*/
private function start(){
_echo('启动预热邮件归档处理 '.getmypid());
$id = 0;
while (1){
$id = $this->run($id);
if($id === 0){
break;
}
}
}
private function run($id):int {
$floder = $this->db->first(\Model\folderSql::first(['id.>'=>$id]));
if($floder){
$this->move($floder['id']);
return $floder['id'];
}else{
return 0;
}
}
public function move($fid){
_echo('正在移动 '.$fid);
$list = $this->db->all(\Model\listsSql::first(dbWhere(['folder_id'=>$fid,'is_hots'=>1])).'0000');
if($list){
$this->db->transaction(function () use ($list){
foreach ($list as $item){
try {
$ret = $this->db->throw()->insert('lists_hot',$item,false);
}catch (Throwable $e){
$this->db->delete('lists_hot',['id'=>$item['id']]);
unset($item['updated_at']);
$ret = $this->db->throw()->insert('lists_hot',$item,false);
}
if($ret){
$this->db->delete(listsSql::$table,['id'=>$item['id']]);
}
}
return true;
});
$list = null;
$this->move($fid);
}
}
}
include_once "../vendor/autoload.php";
new HotMailArchive();
_echo('执行完成 等待下次执行');
//
//swoole_set_process_name('hot-email-run-man');
//
//$pm = new Swoole\Process\Manager();
//
//$pm->addBatch(3,function (){
//
// swoole_set_process_name('hot-email-run');
//
// include_once "../vendor/autoload.php";
//
// new HotMail();
//
// exit();
//},true);
//
//$pm->start();