Netty心跳机制的使用实例

本文介绍了使用Netty实现心跳机制的案例。客户端通过Protostuff序列化对象,并利用IdleStateHandler处理读写超时,当检测到无数据交换时发送PING,服务端接收到后回应PONG。若长时间未收到客户端消息,服务端将关闭连接。
摘要由CSDN通过智能技术生成

我们将客户端对服务端发送的数据封装成MyRequest对象,服务端的回应封装成MyResponse对象,我们用Protostuff来序列化,底层通信实现采用Netty,实现心跳机制,当客户端一段时间没有向服务端发出请求就主动发一个PING过去,告诉服务端自己还活着,服务端接收后就回个PONG;服务端一段时间没收到请求就断开与客户端的长连接。

关于Protostuff的使用看这篇Protostuff序列化框架的使用及Objenesis的使用

我们将MyRequest,MyResponse,PING,PONG封装成Message,客户端服务端之间传输的数据类。

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
// 在我的项目里该类的无参构造器是必须的,
// 因为在反序列化时我用的是Java的反射机制来实例化
@NoArgsConstructor 
@AllArgsConstructor
public class Message {
   
    private byte type;
    private RpcRequest request;
    private RpcResponse response;

    public Message(byte type) {
   
        this.type = type;
    }

    public static Message buildRequest(RpcRequest request) {
   
        return new Message(Message.REQUEST, request, null);
    }

    public static Message buildResponse(RpcResponse response) {
   
        return new Message(Message.RESPONSE, null, response);
    }

    public static final byte PING = 1;
    public static final byte PONG = 1 << 1;
    public static final byte REQUEST = 1 << 2;
    public static final byte RESPONSE = 1 << 3;
    public static final Message PING_MSG = new Message(Message.PING);
    public static final Message PONG_MSG = new Message(Message.PONG);
}

统一后我们只需在相应的编码器,解码器里对数据类型进行判断,再做相应的处理即可。

客户端的Netty代码:

			this.bootstrap.group(group).channel(NioSocketChannel.class)
             
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值