zj
2025-10-17 bbc4713b23778aebc1eb3d46cb04d539179d883d
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
package com.yami.trading;
 
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Autowired;
 
import com.yami.trading.common.config.ThreadPool;
import com.yami.trading.common.manager.sms.SmsMessage;
import com.yami.trading.common.manager.sms.SmsMessageQueue;
import com.yami.trading.common.util.ThreadUtils;
import com.yami.trading.service.InternalSmsSenderService;
 
/**
 * 短信服务类,负责从短信消息队列取出短信消息并发送
 */
public class SmsServer implements InitializingBean, Runnable {
    
    @Autowired
    private InternalSmsSenderService internalSmsSenderService;
 
    private static final Logger logger = LoggerFactory.getLogger(SmsServer.class);
 
    /**
     * 服务运行: 1. 从消息队列获取message 2.调用currentProvider发送短信
     */
    public void run() {
        while (true) {
            try {
                SmsMessage  item = SmsMessageQueue.poll();
                if (null!=item) {
                    internalSmsSenderService.send(item);
                } else {
                    ThreadUtils.sleep(500);
                }
            } catch (Throwable e) {
                logger.error("SmsServer taskExecutor.execute() fail", e);
            }
        }
    }
 
    public void afterPropertiesSet() throws Exception {
        logger.info("启动短信(Smsbao)服务!");
        ThreadPool.getFixedTaskExecutor(1,"SmsbaoServer").execute(this);
    }
}