peternameyakj
2025-04-29 acf1c75a32aa05f34d9d60b6ae3f3e052b532e9f
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
package project.data.job;
 
import java.util.ArrayList;
import java.util.List;
 
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
 
import kernel.util.ThreadUtils;
import project.data.DataDBService;
import project.data.model.Realtime;
 
public class SaveRealtimeServer implements Runnable {
    
    private Logger logger = LoggerFactory.getLogger(SaveRealtimeServer.class);
    
    private DataDBService dataDBService;
    
    public void start() {
        new Thread(this, "SaveRealtimeServer").start();
        if (logger.isInfoEnabled()) {
            logger.info("启动SaveRealtimeServer!");
        }
 
    }
    public void run() {
        while (true) {
            try {
                int size = RealtimeQueue.size();
                /**
                 * 现量轮询一圈
                 */
                List<Realtime> list = new ArrayList<Realtime>();
                for (int i = 0; i < size; i++) {
                    Realtime item = RealtimeQueue.poll();
                    list.add(item);
 
                }
                if (list.size() > 0) {
                    dataDBService.saveBatch(list);
                }
 
            } catch (Throwable e) {
                logger.error(" run fail", e);
            } finally {
                ThreadUtils.sleep(60 * 1000);
            }
        }
    }
 
    
 
    public void setDataDBService(DataDBService dataDBService) {
        this.dataDBService = dataDBService;
    }
 
}