peternameyakj
2024-10-15 19d0fd2c0e7860e2d5d075f926df0d190ebb34cc
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
package email.sender;
 
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.core.task.TaskExecutor;
 
import email.internal.InternalEmailSenderService;
import kernel.util.ThreadUtils;
 
/**
 * 邮件服务类,负责从短信消息队列取出短信消息并发送
 */
public class EmailServer implements InitializingBean, Runnable {
 
    private static final Logger logger = LoggerFactory.getLogger(EmailServer.class);
 
    private TaskExecutor taskExecutor;
    
    private InternalEmailSenderService internalEmailSenderService;
 
    
    /**
     * 服务运行:
     * 1. 从消息队列获取message
     * 2.调用currentProvider发送短信
     */
    public void run() {
        while (true) {
 
            try {
                EmailMessage item = EmailMessageQueue.poll();
                if (item != null) {
                    System.out.println("邮寄地址111:" + item.getTomail());
                    System.out.println("邮寄地址222:" + item.getSubject());
                    System.out.println("邮寄地址taskExecutor:" + taskExecutor);
                    if(null == taskExecutor){
                        System.out.println("TaskExecutor is not set!");
                    }else {
                        System.out.println("taskExecutor 不是空!");
                    }
                    taskExecutor.execute(new HandleRunner(item));
                }
                else {
                    /*
                     * 限速,最多1秒20个
                     */
                    ThreadUtils.sleep(50);
                }
 
            } catch (Throwable e) {
                logger.error("EmailServer taskExecutor.execute() fail", e);
 
            }
        }
    }
 
    public class HandleRunner implements Runnable {
        private EmailMessage item;
 
        public HandleRunner(EmailMessage item) {
            System.out.println("t执行到 HandleRunner!");
            this.item = item;
        }
 
        public void run() {
            try {
                System.out.println("执行HandleRunner的run!");
                if(null == internalEmailSenderService){
                    System.out.println("internalEmailSenderService is not set!");
                }else {
                    System.out.println("internalEmailSenderService 不是空!");
                }
                internalEmailSenderService.send(item);
                System.out.println("HandleRunner的run执行完毕!");
            } catch (Throwable t) {
                 logger.error("EmailServer taskExecutor.execute() fail", t);
            }
 
        }
 
    }
 
 
    public void afterPropertiesSet() throws Exception {
 
        new Thread(this, "EmailServer").start();
        if (logger.isInfoEnabled()) {
            logger.info("启动邮件发送服务!");
        }
 
    }
    
 
    public void setTaskExecutor(TaskExecutor taskExecutor) {
        this.taskExecutor = taskExecutor;
    }
 
 
    public void setInternalEmailSenderService(InternalEmailSenderService internalEmailSenderService) {
        this.internalEmailSenderService = internalEmailSenderService;
    }
 
 
 
 
 
 
}