自动化立体仓库 - WCS系统
zhangc
2025-03-11 d5449236ef0b3adafb3e4cc872f50479efa0ce7b
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
package com.zy.core.netty.cache;
 
import io.netty.channel.Channel;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.RestController;
 
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
 
/**
 * Channel缓存 ==>> {
 *                   key: uuid
 *                   value: Channel
 *                 }
 * Created by vincent on 2019-04-02
 */
@Slf4j
@RestController
public class ChannelCache {
 
    private static Map<String, Channel> channelGroup = new ConcurrentHashMap<>();
 
    public static void setChannel(String uuid, Channel channel) {
        // todo 缓存标记 ===>> 分布式系统
//        String hostName = SystemProperties.HOST_NAME;
        if (getChannel(uuid) == channel) {
            return;
        }
        removeChannel(uuid);
        channelGroup.put(uuid, channel);
    }
 
    public static Channel getChannel(String uuid) {
        return channelGroup.get(uuid);
    }
 
    public static void removeChannel(String uuid) {
        Channel channel = getChannel(uuid);
        if (null == channel) {
            return;
        }
        channelGroup.remove(uuid);
        channel.close();
    }
 
    public static String removeChannel(Channel channel) {
        String key = null;
        for (Map.Entry<String, Channel> entry : channelGroup.entrySet()) {
            if (entry.getValue() == channel) {
                key = entry.getKey();
                break;
            }
        }
        if (null != key) {
            channelGroup.remove(key);
            return key;
        }
        return null;
    }
 
 
}