peternameyakj
2024-10-24 7621191445c6f37f0d8253657560be6202778395
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
package smsbao.sender;
 
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.core.task.TaskExecutor;
 
import kernel.util.ThreadUtils;
import smsbao.internal.InternalSmsSenderService;
 
/**
 * 短信服务类,负责从短信消息队列取出短信消息并发送
 */
public class SmsServer implements InitializingBean, Runnable {
 
    private static final Logger logger = LoggerFactory.getLogger(SmsServer.class);
 
    private TaskExecutor taskExecutor;
 
    private InternalSmsSenderService internalSmsSenderService;
 
    /**
     * 服务运行: 1. 从消息队列获取message 2.调用currentProvider发送短信
     */
    public void run() {
        while (true) {
 
            try {
                SmsMessage item = SmsMessageQueue.poll();
 
                if (item != null) {
 
                    taskExecutor.execute(new HandleRunner(item));
                } else {
                    /*
                     * 限速,最多1秒2个
                     */
                    ThreadUtils.sleep(500);
                }
 
            } catch (Throwable e) {
                logger.error("SmsServer taskExecutor.execute() fail", e);
 
            }
        }
    }
 
    public class HandleRunner implements Runnable {
        private SmsMessage item;
 
        public HandleRunner(SmsMessage item) {
            this.item = item;
        }
 
        public void run() {
            try {
                internalSmsSenderService.send(item);
            } catch (Throwable t) {
                logger.error("SmsServer taskExecutor.execute() fail", t);
            }
 
        }
 
    }
 
    public void afterPropertiesSet() throws Exception {
 
        new Thread(this, "SmsbaoServer").start();
        if (logger.isInfoEnabled()) {
            logger.info("启动短信(Smsbao)服务!");
        }
 
    }
 
    public void setTaskExecutor(TaskExecutor taskExecutor) {
        this.taskExecutor = taskExecutor;
    }
 
    public void setInternalSmsSenderService(InternalSmsSenderService internalSmsSenderService) {
        this.internalSmsSenderService = internalSmsSenderService;
    }
 
}