vince
2024-05-20 75bdadc0c4e468217b93142d965cd92ee52838ec
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
package com.fzzy.protocol.bhzn.v0.server;
 
 
import com.ld.io.api.HeartbeatProvider;
import com.ld.io.api.IoSession;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
 
/**
 * 提供心跳信息
 *
 * @author Andy
 */
@Slf4j
@Service
public class BhznGrainV0HeartbeatImpl implements HeartbeatProvider {
 
    @Override
    public byte[] provide(IoSession session) {
        //直接根据主机SESSIOn判断
        IoSession session1 = BhznGrainV0ServerUtils.getSession();
 
        Long lastBeatTime = BhznGrainV0ServerUtils.getHearBeat(session1);
 
        if (null == lastBeatTime) {
            return null;
        }
 
        //如果最后一次终端心跳时间距离当前时间大于 终端心跳时间的3次,则判断为离线
        long deTime = System.currentTimeMillis() - lastBeatTime;
 
        if (deTime > (BhznGrainV0ServerUtils.HEART_BEAT_TIME * 3 * 1000)) {
            log.info("-----------超过{}秒未获取到心跳信息,判定终端离线,踢出连接------------{}-{}", deTime, session.getAddress(), session.getPort());
 
           // session.destroy();
        }
 
        return null;
    }
}