zm
2020-05-18 a18bfacbf56b401f6e0fdae8710fbca4df8cff77
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
116
117
118
119
120
package com.codingapi.tm.redis.service.impl;
 
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.codingapi.tm.config.ConfigReader;
import com.codingapi.tm.netty.model.TxGroup;
import com.codingapi.tm.redis.service.RedisServerService;
import org.apache.commons.lang.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.HashOperations;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.ValueOperations;
import org.springframework.stereotype.Service;
 
import java.util.ArrayList;
import java.util.List;
import java.util.Set;
import java.util.concurrent.TimeUnit;
 
/**
 * create by lorne on 2017/11/11
 */
@Service
public class RedisServerServiceImpl implements RedisServerService{
 
    @Autowired
    private RedisTemplate<String, String> redisTemplate;
 
    @Autowired
    private ConfigReader configReader;
 
    private Logger logger = LoggerFactory.getLogger(RedisServerServiceImpl.class);
 
    public String loadNotifyJson() {
        Set<String> keys =  redisTemplate.keys(configReader.getKeyPrefixCompensate()+"*");
        ValueOperations<String,String> value =  redisTemplate.opsForValue();
        JSONArray jsonArray = new JSONArray();
        for(String key:keys){
            String json = value.get(key);
            JSONObject jsonObject = new JSONObject();
            jsonObject.put("key",key);
            jsonObject.put("value",JSONObject.parse(json));
            jsonArray.add(jsonObject);
        }
        return jsonArray.toJSONString();
    }
 
    @Override
    public void saveTransaction(String key, String json) {
        logger.info("redis save key:"+key+", val:"+json);
        ValueOperations<String, String> value = redisTemplate.opsForValue();
        value.set(key, json, configReader.getRedisSaveMaxTime(), TimeUnit.SECONDS);
    }
 
 
    @Override
    public TxGroup getTxGroupByKey(String key) {
        logger.info("redis get key:"+key);
        ValueOperations<String, String> value = redisTemplate.opsForValue();
        String json = value.get(key);
        if (StringUtils.isEmpty(json)) {
            return null;
        }
        return TxGroup.parser(json);
    }
 
 
    @Override
    public void saveCompensateMsg(String name, String json) {
        ValueOperations<String, String> value = redisTemplate.opsForValue();
        value.set(name, json);
    }
 
    @Override
    public List<String> getKeys(String key) {
        Set<String> keys = redisTemplate.keys(key);
        List<String> list = new ArrayList<String>();
        for (String k : keys) {
            list.add(k);
        }
        return list;
    }
 
    @Override
    public List<String> getValuesByKeys(List<String> keys) {
        ValueOperations<String, String> value = redisTemplate.opsForValue();
        List<String> list = new ArrayList<>();
        for (String key : keys) {
            String json = value.get(key);
            list.add(json);
        }
        return list;
    }
 
    @Override
    public String getValueByKey(String key) {
        ValueOperations<String, String> value = redisTemplate.opsForValue();
        return value.get(key);
    }
 
    @Override
    public void deleteKey(String key) {
        redisTemplate.delete(key);
    }
 
    @Override
    public void saveLoadBalance(String groupName, String key, String data) {
        HashOperations<String, String, String> value = redisTemplate.opsForHash();
        value.put(groupName,key,data);
    }
 
 
    @Override
    public String getLoadBalance(String groupName, String key) {
        HashOperations<String, String, String> value = redisTemplate.opsForHash();
        return value.get(groupName,key);
    }
}