Netty断线重连

时间:2023-12-17 20:39:08

Netty断线重连

最近使用Netty开发一个中转服务,需要一直保持与Server端的连接,网络中断后需要可以自动重连,查询官网资料,实现方案很简单,核心思想是在channelUnregistered钩子函数里执行重连。

创建连接

需要把configureBootstrap重构为一个函数,方便后续复用

  1. EventLoopGroup group = new NioEventLoopGroup(); 

  2. private volatile Bootstrap bootstrap; 


  3. public void init(String host, int port) throws RobotException { 

  4. this.serverIp = host; 

  5. this.serverPort = port; 

  6. try { 

  7. // 创建并初始化 Netty 客户端 Bootstrap 对象 

  8. bootstrap = configureBootstrap(new Bootstrap(),group); 

  9. bootstrap.option(ChannelOption.TCP_NODELAY, true); 

  10. doConnect(bootstrap); 



  11. catch(Exception ex){ 

  12. ex.printStackTrace(); 

  13. throw new RobotException("connect remote control server error!",ex.getCause()); 






  14. Bootstrap configureBootstrap(Bootstrap b, EventLoopGroup g) { 

  15. b.group(g).channel(NioSocketChannel.class) 

  16. .remoteAddress(serverIp, serverPort) 

  17. .handler(new ChannelInitializer<SocketChannel>() { 

  18. @Override 

  19. public void initChannel(SocketChannel channel) throws Exception { 

  20. ChannelPipeline pipeline = channel.pipeline(); 

  21. // 编解码器 

  22. pipeline.addLast(protoCodec); 

  23. // 请求处理 

  24. pipeline.addLast(RobotClient.this); 



  25. }); 


  26. return b; 




  27. void doConnect(Bootstrap b) { 

  28. try { 


  29. ChannelFuture future = b.connect(); 

  30. future.addListener(new ChannelFutureListener() { 

  31. @Override 

  32. public void operationComplete(ChannelFuture future) throws Exception { 

  33. if (future.isSuccess()) { 

  34. System.out.println("Started Tcp Client: " + serverIp); 

  35. } else { 

  36. System.out.println("Started Tcp Client Failed: "); 



  37. if (future.cause() != null) { 

  38. future.cause().printStackTrace(); 






  39. }); 

  40. } catch (Exception e) { 

  41. e.printStackTrace(); 





断线重连

来看断线重连的关键代码:

  1. @ChannelHandler.Sharable 

  2. public class RobotClient extends SimpleChannelInboundHandler<RobotProto> { 

  3. @Override 

  4. public void channelUnregistered(ChannelHandlerContext ctx) throws Exception { 

  5. // 状态重置 

  6. isConnected = false; 

  7. this.serverStatus = -1; 


  8. final EventLoop loop = ctx.channel().eventLoop(); 

  9. loop.schedule(new Runnable() { 

  10. @Override 

  11. public void run() { 

  12. doConnect(configureBootstrap(new Bootstrap(), loop)); 



  13. }, 1, TimeUnit.SECONDS); 





需要注意,Client类需要添加@ChannelHandler.Sharable注解,否则重连时会报错


作者:Jadepeng
出处:jqpeng的技术记事本--http://www.cnblogs.com/xiaoqi
您的支持是对博主最大的鼓励,感谢您的认真阅读。
本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。